##// END OF EJS Templates
Potential can't dup NilClass error in UserPreference (#11905)....
Jean-Philippe Lang -
r10255:838025372dc3
parent child
Show More
@@ -1,59 +1,59
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 class UserPreference < ActiveRecord::Base
18 class UserPreference < ActiveRecord::Base
19 belongs_to :user
19 belongs_to :user
20 serialize :others
20 serialize :others
21
21
22 attr_protected :others, :user_id
22 attr_protected :others, :user_id
23
23
24 before_save :set_others_hash
24 before_save :set_others_hash
25
25
26 def initialize(attributes=nil, *args)
26 def initialize(attributes=nil, *args)
27 super
27 super
28 self.others ||= {}
28 self.others ||= {}
29 end
29 end
30
30
31 def set_others_hash
31 def set_others_hash
32 self.others ||= {}
32 self.others ||= {}
33 end
33 end
34
34
35 def [](attr_name)
35 def [](attr_name)
36 if attribute_present? attr_name
36 if attribute_present? attr_name
37 super
37 super
38 else
38 else
39 others ? others[attr_name] : nil
39 others ? others[attr_name] : nil
40 end
40 end
41 end
41 end
42
42
43 def []=(attr_name, value)
43 def []=(attr_name, value)
44 if attribute_present? attr_name
44 if attribute_present? attr_name
45 super
45 super
46 else
46 else
47 h = read_attribute(:others).dup || {}
47 h = (read_attribute(:others) || {}).dup
48 h.update(attr_name => value)
48 h.update(attr_name => value)
49 write_attribute(:others, h)
49 write_attribute(:others, h)
50 value
50 value
51 end
51 end
52 end
52 end
53
53
54 def comments_sorting; self[:comments_sorting] end
54 def comments_sorting; self[:comments_sorting] end
55 def comments_sorting=(order); self[:comments_sorting]=order end
55 def comments_sorting=(order); self[:comments_sorting]=order end
56
56
57 def warn_on_leaving_unsaved; self[:warn_on_leaving_unsaved] || '1'; end
57 def warn_on_leaving_unsaved; self[:warn_on_leaving_unsaved] || '1'; end
58 def warn_on_leaving_unsaved=(value); self[:warn_on_leaving_unsaved]=value; end
58 def warn_on_leaving_unsaved=(value); self[:warn_on_leaving_unsaved]=value; end
59 end
59 end
@@ -1,57 +1,72
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 require File.expand_path('../../test_helper', __FILE__)
18 require File.expand_path('../../test_helper', __FILE__)
19
19
20 class UserPreferenceTest < ActiveSupport::TestCase
20 class UserPreferenceTest < ActiveSupport::TestCase
21 fixtures :users, :user_preferences
21 fixtures :users, :user_preferences
22
22
23 def test_create
23 def test_create
24 user = User.new(:firstname => "new", :lastname => "user", :mail => "newuser@somenet.foo")
24 user = User.new(:firstname => "new", :lastname => "user", :mail => "newuser@somenet.foo")
25 user.login = "newuser"
25 user.login = "newuser"
26 user.password, user.password_confirmation = "password", "password"
26 user.password, user.password_confirmation = "password", "password"
27 assert user.save
27 assert user.save
28
28
29 assert_kind_of UserPreference, user.pref
29 assert_kind_of UserPreference, user.pref
30 assert_kind_of Hash, user.pref.others
30 assert_kind_of Hash, user.pref.others
31 assert user.pref.save
31 assert user.pref.save
32 end
32 end
33
33
34 def test_update
34 def test_update
35 user = User.find(1)
35 user = User.find(1)
36 assert_equal true, user.pref.hide_mail
36 assert_equal true, user.pref.hide_mail
37 user.pref['preftest'] = 'value'
37 user.pref['preftest'] = 'value'
38 assert user.pref.save
38 assert user.pref.save
39
39
40 user.reload
40 user.reload
41 assert_equal 'value', user.pref['preftest']
41 assert_equal 'value', user.pref['preftest']
42 end
42 end
43
43
44 def test_others_hash
44 def test_others_hash
45 user = User.new(:firstname => "new", :lastname => "user", :mail => "newuser@somenet.foo")
45 user = User.new(:firstname => "new", :lastname => "user", :mail => "newuser@somenet.foo")
46 user.login = "newuser"
46 user.login = "newuser"
47 user.password, user.password_confirmation = "password", "password"
47 user.password, user.password_confirmation = "password", "password"
48 assert user.save
48 assert user.save
49 assert_nil user.preference
49 assert_nil user.preference
50 up = UserPreference.new(:user => user)
50 up = UserPreference.new(:user => user)
51 assert_kind_of Hash, up.others
51 assert_kind_of Hash, up.others
52 up.others = nil
52 up.others = nil
53 assert_nil up.others
53 assert_nil up.others
54 assert up.save
54 assert up.save
55 assert_kind_of Hash, up.others
55 assert_kind_of Hash, up.others
56 end
56 end
57
58 def test_reading_value_from_nil_others_hash
59 up = UserPreference.new(:user => User.new)
60 up.others = nil
61 assert_nil up.others
62 assert_nil up[:foo]
63 end
64
65 def test_writing_value_to_nil_others_hash
66 up = UserPreference.new(:user => User.new)
67 up.others = nil
68 assert_nil up.others
69 up[:foo] = 'bar'
70 assert_equal 'bar', up[:foo]
71 end
57 end
72 end
General Comments 0
You need to be logged in to leave comments. Login now