summaryrefslogtreecommitdiff
path: root/test/ruby
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-05-31 16:16:06 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-05-31 16:16:06 +0000
commit604fe33b4493271c6116733548c3cddb12d2ace1 (patch)
tree20c77fbbdc1a48f25e7672847a8db805ac3eaa80 /test/ruby
parentfcc86b0f4c443b7ab28fb61831b81767a8798292 (diff)
* class.c (rb_mix_module): implement Module#mix.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@31873 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby')
-rw-r--r--test/ruby/test_module.rb29
1 files changed, 29 insertions, 0 deletions
diff --git a/test/ruby/test_module.rb b/test/ruby/test_module.rb
index 0dcfeccef9..ec29530f8e 100644
--- a/test/ruby/test_module.rb
+++ b/test/ruby/test_module.rb
@@ -1068,4 +1068,33 @@ class TestModule < Test::Unit::TestCase
INPUT
assert_in_out_err([], src, ["NameError"], [])
end
+
+ def test_mix
+ american = Module.new do
+ attr_accessor :address
+ end
+ japanese = Module.new do
+ attr_accessor :address
+ end
+
+ japanese_american = Class.new
+ assert_nothing_raised(ArgumentError) {
+ japanese_american.class_eval {mix american}
+ }
+ assert_raise(ArgumentError) {
+ japanese_american.class_eval {mix japanese}
+ }
+
+ japanese_american = Class.new
+ assert_nothing_raised(ArgumentError) {
+ japanese_american.class_eval {
+ mix american, :address => :us_address, :address= => :us_address=
+ }
+ }
+ assert_nothing_raised(ArgumentError) {
+ japanese_american.class_eval {
+ mix japanese, :address => :jp_address, :address= => :jp_address=
+ }
+ }
+ end
end