diff options
author | Carlos Antonio da Silva <carlosantoniodasilva@gmail.com> | 2013-02-11 08:03:09 -0800 |
---|---|---|
committer | Carlos Antonio da Silva <carlosantoniodasilva@gmail.com> | 2013-02-11 08:03:09 -0800 |
commit | 65dde28730fabadf95d99512cf8a11894a575234 (patch) | |
tree | d127458e91064880ebaffc7d42444c2f1d94122b /activerecord/test | |
parent | b1c72a3675d57a3a575563acbc120d125d2c667b (diff) | |
parent | 9dfef5a46bb6a0c74a48aa70fa350c0f09f92c0d (diff) | |
download | rails-65dde28730fabadf95d99512cf8a11894a575234.tar.gz rails-65dde28730fabadf95d99512cf8a11894a575234.tar.bz2 rails-65dde28730fabadf95d99512cf8a11894a575234.zip |
Merge pull request #9247 from lest/store-module
define Active Record Store accessors in a module
Diffstat (limited to 'activerecord/test')
-rw-r--r-- | activerecord/test/cases/store_test.rb | 12 | ||||
-rw-r--r-- | activerecord/test/models/admin/user.rb | 9 |
2 files changed, 21 insertions, 0 deletions
diff --git a/activerecord/test/cases/store_test.rb b/activerecord/test/cases/store_test.rb index 43bf285ba9..3e32d866ee 100644 --- a/activerecord/test/cases/store_test.rb +++ b/activerecord/test/cases/store_test.rb @@ -35,6 +35,12 @@ class StoreTest < ActiveRecord::TestCase assert_equal '(123) 456-7890', @john.phone_number end + test "overriding a read accessor using super" do + @john.settings[:color] = nil + + assert_equal 'red', @john.color + end + test "updating the store will mark it as changed" do @john.color = 'red' assert @john.settings_changed? @@ -66,6 +72,12 @@ class StoreTest < ActiveRecord::TestCase assert_equal '1234567890', @john.settings[:phone_number] end + test "overriding a write accessor using super" do + @john.color = 'yellow' + + assert_equal 'blue', @john.color + end + test "preserve store attributes data in HashWithIndifferentAccess format without any conversion" do @john.json_data = ActiveSupport::HashWithIndifferentAccess.new(:height => 'tall', 'weight' => 'heavy') @john.height = 'low' diff --git a/activerecord/test/models/admin/user.rb b/activerecord/test/models/admin/user.rb index 024fede266..4c3b71e8f9 100644 --- a/activerecord/test/models/admin/user.rb +++ b/activerecord/test/models/admin/user.rb @@ -27,4 +27,13 @@ class Admin::User < ActiveRecord::Base def phone_number=(value) write_store_attribute(:settings, :phone_number, value && value.gsub(/[^\d]/,'')) end + + def color + super || 'red' + end + + def color=(value) + value = 'blue' unless %w(black red green blue).include?(value) + super + end end |