summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-eval/test/eval.rb
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2020-06-02 14:49:49 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2020-06-02 14:49:49 +0900
commit14e325e45d336b06cd96e68843d0bb886aea1b22 (patch)
tree1f6852e91266cd14899974d725dffbeedfb9cd37 /mrbgems/mruby-eval/test/eval.rb
parent1fc9345b4567bf65ed27d1ed7a84002b898f08d2 (diff)
parentf85906b67920c0e69599c6e59d843274aef152be (diff)
downloadmruby-14e325e45d336b06cd96e68843d0bb886aea1b22.tar.gz
mruby-14e325e45d336b06cd96e68843d0bb886aea1b22.zip
Merge branch 'dearblue-eval-patchfree'; close #5016
Diffstat (limited to 'mrbgems/mruby-eval/test/eval.rb')
-rw-r--r--mrbgems/mruby-eval/test/eval.rb21
1 files changed, 21 insertions, 0 deletions
diff --git a/mrbgems/mruby-eval/test/eval.rb b/mrbgems/mruby-eval/test/eval.rb
index 4930259c1..639ed68f9 100644
--- a/mrbgems/mruby-eval/test/eval.rb
+++ b/mrbgems/mruby-eval/test/eval.rb
@@ -130,3 +130,24 @@ Proc.new { foo }
EOS
}
end
+
+assert('Calling the same method as the variable name') do
+ hoge = Object.new
+ def hoge.fuga
+ "Hit!"
+ end
+ assert_equal("Hit!") { fuga = "Miss!"; eval "hoge.fuga" }
+ assert_equal("Hit!") { fuga = "Miss!"; -> { eval "hoge.fuga" }.call }
+ assert_equal("Hit!") { -> { fuga = "Miss!"; eval "hoge.fuga" }.call }
+ assert_equal("Hit!") { fuga = "Miss!"; eval("-> { hoge.fuga }").call }
+end
+
+assert('Access numbered parameter from eval') do
+ hoge = Object.new
+ def hoge.fuga(a, &b)
+ b.call(a)
+ end
+ assert_equal(6) {
+ hoge.fuga(3) { _1 + eval("_1") }
+ }
+end