aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
diff options
context:
space:
mode:
authorMislav Marohnić <mislav.marohnic@gmail.com>2010-04-16 16:20:31 +0200
committerJeremy Kemper <jeremy@bitsweat.net>2010-04-16 13:09:07 -0700
commitcf616e48765d1aa378d04618c044b493fd9583e1 (patch)
tree61102541b455c5827f77bb4412d7c8170514731d /activerecord
parent779723a0b4d9cd42bf6a494c0906723a5e3c5fec (diff)
downloadrails-cf616e48765d1aa378d04618c044b493fd9583e1.tar.gz
rails-cf616e48765d1aa378d04618c044b493fd9583e1.tar.bz2
rails-cf616e48765d1aa378d04618c044b493fd9583e1.zip
merge callbacks_observers_test.rb into lifecycle_test.rb where other observers test reside
Benefits: test able to run independently, subclassing instead of changing the original Comment model Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
Diffstat (limited to 'activerecord')
-rw-r--r--activerecord/test/cases/callbacks_observers_test.rb37
-rw-r--r--activerecord/test/cases/lifecycle_test.rb34
2 files changed, 34 insertions, 37 deletions
diff --git a/activerecord/test/cases/callbacks_observers_test.rb b/activerecord/test/cases/callbacks_observers_test.rb
deleted file mode 100644
index 52ce384844..0000000000
--- a/activerecord/test/cases/callbacks_observers_test.rb
+++ /dev/null
@@ -1,37 +0,0 @@
-require "cases/helper"
-
-class Comment < ActiveRecord::Base
- attr_accessor :callers
-
- before_validation :record_callers
-
- after_validation do
- record_callers
- end
-
- def record_callers
- callers << self.class if callers
- end
-end
-
-class CommentObserver < ActiveRecord::Observer
- attr_accessor :callers
-
- def after_validation(model)
- callers << self.class if callers
- end
-end
-
-class CallbacksObserversTest < ActiveRecord::TestCase
- def test_model_callbacks_fire_before_observers_are_notified
- callers = []
-
- comment = Comment.new
- comment.callers = callers
-
- CommentObserver.instance.callers = callers
-
- comment.valid?
- assert_equal [Comment, Comment, CommentObserver], callers, "model callbacks did not fire before observers were notified"
- end
-end
diff --git a/activerecord/test/cases/lifecycle_test.rb b/activerecord/test/cases/lifecycle_test.rb
index fcad3e90d3..5e71ed0221 100644
--- a/activerecord/test/cases/lifecycle_test.rb
+++ b/activerecord/test/cases/lifecycle_test.rb
@@ -3,6 +3,7 @@ require 'models/topic'
require 'models/developer'
require 'models/reply'
require 'models/minimalistic'
+require 'models/comment'
class SpecialDeveloper < Developer; end
@@ -57,6 +58,28 @@ class MultiObserver < ActiveRecord::Observer
end
end
+class ValidatedComment < Comment
+ attr_accessor :callers
+
+ before_validation :record_callers
+
+ after_validation do
+ record_callers
+ end
+
+ def record_callers
+ callers << self.class if callers
+ end
+end
+
+class ValidatedCommentObserver < ActiveRecord::Observer
+ attr_accessor :callers
+
+ def after_validation(model)
+ callers << self.class if callers
+ end
+end
+
class LifecycleTest < ActiveRecord::TestCase
fixtures :topics, :developers, :minimalistics
@@ -125,4 +148,15 @@ class LifecycleTest < ActiveRecord::TestCase
def test_invalid_observer
assert_raise(ArgumentError) { Topic.observers = Object.new; Topic.instantiate_observers }
end
+
+ test "model callbacks fire before observers are notified" do
+ callers = []
+
+ comment = ValidatedComment.new
+ comment.callers = ValidatedCommentObserver.instance.callers = callers
+
+ comment.valid?
+ assert_equal [ValidatedComment, ValidatedComment, ValidatedCommentObserver], callers,
+ "model callbacks did not fire before observers were notified"
+ end
end