summaryrefslogtreecommitdiffhomepage
path: root/test
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2015-02-07 00:13:14 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2015-02-07 00:13:14 +0900
commit1346456c6cb14af9b9a54bbd2da89c11588dbb81 (patch)
tree12b02cb6d092906583e040334042b7291d0c2c93 /test
parent4957c852696c9559bfbea988325fd9bf94fc34bc (diff)
parent8cb40fcda70989285cbedc34897d823b32e3d064 (diff)
downloadmruby-1346456c6cb14af9b9a54bbd2da89c11588dbb81.tar.gz
mruby-1346456c6cb14af9b9a54bbd2da89c11588dbb81.zip
Merge pull request #2716 from kou/fix-ensure-context-on-break-and-return
Fix ensure with yield context on break and return
Diffstat (limited to 'test')
-rw-r--r--test/t/ensure.rb54
1 files changed, 54 insertions, 0 deletions
diff --git a/test/t/ensure.rb b/test/t/ensure.rb
new file mode 100644
index 000000000..bef397059
--- /dev/null
+++ b/test/t/ensure.rb
@@ -0,0 +1,54 @@
+##
+# ensure Test
+
+assert('ensure - context - yield') do
+ class EnsureYieldBreak
+ attr_reader :ensure_context
+ def try
+ yield
+ ensure
+ @ensure_context = self
+ end
+ end
+
+ yielder = EnsureYieldBreak.new
+ yielder.try do
+ end
+ assert_equal yielder, yielder.ensure_context
+end
+
+assert('ensure - context - yield and break') do
+ class EnsureYieldBreak
+ attr_reader :ensure_context
+ def try
+ yield
+ ensure
+ @ensure_context = self
+ end
+ end
+
+ yielder = EnsureYieldBreak.new
+ yielder.try do
+ break
+ end
+ assert_equal yielder, yielder.ensure_context
+end
+
+assert('ensure - context - yield and return') do
+ class EnsureYieldBreak
+ attr_reader :ensure_context
+ def try
+ yield
+ ensure
+ @ensure_context = self
+ end
+ end
+
+ yielder = EnsureYieldBreak.new
+ lambda do
+ yielder.try do
+ return
+ end
+ end.call
+ assert_equal yielder, yielder.ensure_context
+end