diff options
| author | ksss <[email protected]> | 2017-01-14 10:15:40 +0900 |
|---|---|---|
| committer | ksss <[email protected]> | 2017-01-14 22:01:20 +0900 |
| commit | 6f9cb7406aed5f06dffdb64356d2891aba4a15b1 (patch) | |
| tree | 540a77996f115716d42d366fddb94ddc6c83a95a /mrbgems/mruby-kernel-ext/test/kernel.rb | |
| parent | c4491e477b40adc842ef76e524647607780c8f25 (diff) | |
| download | mruby-6f9cb7406aed5f06dffdb64356d2891aba4a15b1.tar.gz mruby-6f9cb7406aed5f06dffdb64356d2891aba4a15b1.zip | |
Implement Kernel.#caller
Diffstat (limited to 'mrbgems/mruby-kernel-ext/test/kernel.rb')
| -rw-r--r-- | mrbgems/mruby-kernel-ext/test/kernel.rb | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/mrbgems/mruby-kernel-ext/test/kernel.rb b/mrbgems/mruby-kernel-ext/test/kernel.rb index cc6af13a3..ee11dacbf 100644 --- a/mrbgems/mruby-kernel-ext/test/kernel.rb +++ b/mrbgems/mruby-kernel-ext/test/kernel.rb @@ -3,6 +3,33 @@ assert('Kernel.fail, Kernel#fail') do assert_raise(RuntimeError) { Kernel.fail } end +assert('Kernel.caller, Kernel#caller') do + c = Class.new do + def foo(*args) + caller(*args) + end + + def bar(*args) + foo(*args) + end + + def baz(*args) + bar(*args) + end + end + assert_equal "#bar", c.new.baz[0][-4..-1] + assert_equal "#foo", c.new.baz(0)[0][-4..-1] + assert_equal "#bar", c.new.baz(1)[0][-4..-1] + assert_equal "#baz", c.new.baz(2)[0][-4..-1] + assert_equal ["#foo", "#bar"], c.new.baz(0, 2).map { |i| i[-4..-1] } + assert_equal ["#bar", "#baz"], c.new.baz(1..2).map { |i| i[-4..-1] } + assert_nil c.new.baz(10..20) + assert_raise(ArgumentError) { c.new.baz(-1) } + assert_raise(ArgumentError) { c.new.baz(-1, 1) } + assert_raise(ArgumentError) { c.new.baz(1, -1) } + assert_raise(TypeError) { c.new.baz(nil) } +end + assert('Kernel#__method__') do assert_equal(:m, Class.new {def m; __method__; end}.new.m) assert_equal(:m, Class.new {define_method(:m) {__method__}}.new.m) |
