aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/test/core_ext/module_test.rb
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2006-06-03 22:43:13 +0000
committerDavid Heinemeier Hansson <david@loudthinking.com>2006-06-03 22:43:13 +0000
commite72ff355c35879ffaf262f4bd91ce7612f028a8e (patch)
tree6ad1f9f497c79297c3ac107cef56b5f11ef728fd /activesupport/test/core_ext/module_test.rb
parentb85c5356c905add4ba2f3d68e9a67ab5e3b247d2 (diff)
downloadrails-e72ff355c35879ffaf262f4bd91ce7612f028a8e.tar.gz
rails-e72ff355c35879ffaf262f4bd91ce7612f028a8e.tar.bz2
rails-e72ff355c35879ffaf262f4bd91ce7612f028a8e.zip
Fixed that Module#alias_method_chain should work with both foo? foo! and foo at the same time (closes #4954) [anna@wota.jp]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4429 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activesupport/test/core_ext/module_test.rb')
-rw-r--r--activesupport/test/core_ext/module_test.rb34
1 files changed, 28 insertions, 6 deletions
diff --git a/activesupport/test/core_ext/module_test.rb b/activesupport/test/core_ext/module_test.rb
index bd51aa11c3..66e4afc918 100644
--- a/activesupport/test/core_ext/module_test.rb
+++ b/activesupport/test/core_ext/module_test.rb
@@ -109,8 +109,12 @@ module BarMethodAliaser
bar_without_baz << '_with_baz'
end
- def quux_with_baz
- quux_without_baz << '_with_baz'
+ def quux_with_baz!
+ quux_without_baz! << '_with_baz!'
+ end
+
+ def quux_with_baz?
+ false
end
end
@@ -148,12 +152,30 @@ class MethodAliasingTest < Test::Unit::TestCase
def test_alias_method_chain_with_punctuation_method
FooClassWithBarMethod.send(:define_method, 'quux!', Proc.new { 'quux' })
- assert !@instance.respond_to?(:quux_with_baz)
+ assert !@instance.respond_to?(:quux_with_baz!)
FooClassWithBarMethod.send(:include, BarMethodAliaser)
FooClassWithBarMethod.alias_method_chain :quux!, :baz
- assert @instance.respond_to?(:quux_with_baz)
+ assert @instance.respond_to?(:quux_with_baz!)
+
+ assert_equal 'quux_with_baz!', @instance.quux!
+ assert_equal 'quux', @instance.quux_without_baz!
+ end
- assert_equal 'quux_with_baz', @instance.quux!
- assert_equal 'quux', @instance.quux_without_baz
+ def test_alias_method_chain_with_same_names_between_predicates_and_bang_methods
+ FooClassWithBarMethod.send(:define_method, 'quux!', Proc.new { 'quux' })
+ FooClassWithBarMethod.send(:define_method, 'quux?', Proc.new { true })
+ assert !@instance.respond_to?(:quux_with_baz!)
+ assert !@instance.respond_to?(:quux_with_baz?)
+
+ FooClassWithBarMethod.send(:include, BarMethodAliaser)
+ FooClassWithBarMethod.alias_method_chain :quux!, :baz
+ FooClassWithBarMethod.alias_method_chain :quux?, :baz
+
+ assert @instance.respond_to?(:quux_with_baz!)
+ assert @instance.respond_to?(:quux_with_baz?)
+ assert_equal 'quux_with_baz!', @instance.quux!
+ assert_equal 'quux', @instance.quux_without_baz!
+ assert_equal false, @instance.quux?
+ assert_equal true, @instance.quux_without_baz?
end
end