aboutsummaryrefslogtreecommitdiffstats
path: root/activemodel/test
diff options
context:
space:
mode:
authorlulalala <mark@goodlife.tw>2018-04-03 13:06:04 +0800
committerlulalala <mark@goodlife.tw>2019-03-31 22:59:12 +0800
commit86620cc3aa8e2630bc8d934b1a86453276b9eee9 (patch)
treef9853d8b8b55469c8e0a9facca31c647337c23ea /activemodel/test
parent2a06f13099b3344e93198728795209bc69501d4a (diff)
downloadrails-86620cc3aa8e2630bc8d934b1a86453276b9eee9.tar.gz
rails-86620cc3aa8e2630bc8d934b1a86453276b9eee9.tar.bz2
rails-86620cc3aa8e2630bc8d934b1a86453276b9eee9.zip
Allow errors to remove duplicates, and ensure cyclic associations w/ autosave duplicate errors can be removed
See SHA 7550f0a016ee6647aaa76c0c0ae30bebc3867288
Diffstat (limited to 'activemodel/test')
-rw-r--r--activemodel/test/cases/error_test.rb20
1 files changed, 20 insertions, 0 deletions
diff --git a/activemodel/test/cases/error_test.rb b/activemodel/test/cases/error_test.rb
index f557d50c32..d1193d123f 100644
--- a/activemodel/test/cases/error_test.rb
+++ b/activemodel/test/cases/error_test.rb
@@ -170,4 +170,24 @@ class ErrorTest < ActiveModel::TestCase
assert_equal "name can't be blank", error.full_message
}
end
+
+ test "equality by base attribute, type and options" do
+ person = Person.new
+
+ e1 = ActiveModel::Error.new(person, :name, foo: :bar)
+ e2 = ActiveModel::Error.new(person, :name, foo: :bar)
+ e2.instance_variable_set(:@_humanized_attribute, "Name")
+
+ assert_equal(e1, e2)
+ end
+
+ test "inequality" do
+ person = Person.new
+ error = ActiveModel::Error.new(person, :name, foo: :bar)
+
+ assert error != ActiveModel::Error.new(person, :name, foo: :baz)
+ assert error != ActiveModel::Error.new(person, :name)
+ assert error != ActiveModel::Error.new(person, :title, foo: :bar)
+ assert error != ActiveModel::Error.new(Person.new, :name, foo: :bar)
+ end
end