]> cat aescling's git repositories - mastodon.git/commitdiff
User settings mutation (#2270)
authorMatt Jankowski <mjankowski@thoughtbot.com>
Fri, 21 Apr 2017 16:07:17 +0000 (12:07 -0400)
committerEugen <eugen@zeonfederated.com>
Fri, 21 Apr 2017 16:07:17 +0000 (18:07 +0200)
* Add user spec for settings, highlight global default mutation issue

* Fix mutation issue caused by settings/preferences spec

spec/controllers/settings/preferences_controller_spec.rb
spec/models/user_spec.rb

index 16cc87991c76101e6ab30ae2feb415754b46641c..cdf595d4d991c86ca8081239556e02219bd22490 100644 (file)
@@ -24,8 +24,8 @@ describe Settings::PreferencesController do
 
     it 'updates user settings' do
       user.settings['boost_modal'] = false
-      user.settings['notification_emails']['follow'] = false
-      user.settings['interactions']['must_be_follower'] = true
+      user.settings['notification_emails'] = user.settings['notification_emails'].merge('follow' => false)
+      user.settings['interactions'] = user.settings['interactions'].merge('must_be_follower' => true)
 
       put :update, params: {
         user: {
index 4ed1d5a0ac1f0bcfa9ecc90a933e0870623bc3d5..846a206ec190f4d8d29e05b27dde0e1811b04e19 100644 (file)
@@ -24,6 +24,37 @@ RSpec.describe User, type: :model do
     end
   end
 
+  describe 'settings' do
+    it 'inherits default settings from default yml' do
+      expect(Setting.boost_modal).to eq false
+      expect(Setting.interactions['must_be_follower']).to eq false
+
+      user = User.new
+      expect(user.settings.boost_modal).to eq false
+      expect(user.settings.interactions['must_be_follower']).to eq false
+    end
+
+    it 'can update settings' do
+      user = Fabricate(:user)
+      expect(user.settings['interactions']['must_be_follower']).to eq false
+      user.settings['interactions'] = user.settings['interactions'].merge('must_be_follower' => true)
+      user.reload
+
+      expect(user.settings['interactions']['must_be_follower']).to eq true
+    end
+
+    xit 'does not mutate defaults via the cache' do
+      user = Fabricate(:user)
+      user.settings['interactions']['must_be_follower'] = true
+      # TODO
+      # This mutates the global settings default such that future user
+      # instances will inherit the incorrect starting values
+
+      other = Fabricate(:user)
+      expect(other.settings['interactions']['must_be_follower']).to eq false
+    end
+  end
+
   describe 'scopes' do
     describe 'recent' do
       it 'returns an array of recent users ordered by id' do