diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-05-09 12:00:53 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-05-09 12:00:53 +0900 |
| commit | b8e524bb9e0852b10c011d7953daf7284443fe95 (patch) | |
| tree | 2dee3be1b4ac3b2b691845ce30cb3a9882a49a29 /test | |
| parent | 78f2d283a76ab4ea94405aa55f98cf1a3cc059b1 (diff) | |
| parent | 06a67df950a4a56190e1047d42054e0307f8c301 (diff) | |
| download | mruby-b8e524bb9e0852b10c011d7953daf7284443fe95.tar.gz mruby-b8e524bb9e0852b10c011d7953daf7284443fe95.zip | |
Merge pull request #2214 from ksss/proc-clear
OP_ENTER clean block object in register
Diffstat (limited to 'test')
| -rw-r--r-- | test/t/proc.rb | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/test/t/proc.rb b/test/t/proc.rb index 151e1df86..1be73c99a 100644 --- a/test/t/proc.rb +++ b/test/t/proc.rb @@ -55,6 +55,23 @@ assert('Proc#call', '15.2.17.4.3') do assert_equal 5, a2 end +assert('Proc#call proc args pos block') do + pr = proc {|a,b,&c| + [a, b, c.class, c&&c.call(:x)] + } + assert_equal [nil, nil, Proc, :proc], (pr.call(){ :proc }) + assert_equal [1, nil, Proc, :proc], (pr.call(1){ :proc }) + assert_equal [1, 2, Proc, :proc], (pr.call(1, 2){ :proc }) + assert_equal [1, 2, Proc, :proc], (pr.call(1, 2, 3){ :proc }) + assert_equal [1, 2, Proc, :proc], (pr.call(1, 2, 3, 4){ :proc }) + + assert_equal [nil, nil, Proc, :x], (pr.call(){|x| x}) + assert_equal [1, nil, Proc, :x], (pr.call(1){|x| x}) + assert_equal [1, 2, Proc, :x], (pr.call(1, 2){|x| x}) + assert_equal [1, 2, Proc, :x], (pr.call(1, 2, 3){|x| x}) + assert_equal [1, 2, Proc, :x], (pr.call(1, 2, 3, 4){|x| x}) +end + assert('Proc#return_does_not_break_self') do class TestClass attr_accessor :block |
