summaryrefslogtreecommitdiff
path: root/bootstraptest/test_syntax.rb
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-25 12:37:16 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-25 12:37:16 +0000
commit633df8de16203da72dff1a010740fdf92f9f7f5c (patch)
tree7f9889ab265a4dbf85c36ca259da1fb51a6db600 /bootstraptest/test_syntax.rb
parent904b278f94d9d18fef50adce79aec0756496a773 (diff)
* compile.c (iseq_compile_each): fix stack consistency error
(break is compiled to throw instead of jump insn). these problems are reported by Yusuke ENDOH <mame AT tsg.ne.jp> * bootstraptest/test_knownbug.rb, test_syntax.rb: move fixed test. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14699 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'bootstraptest/test_syntax.rb')
-rw-r--r--bootstraptest/test_syntax.rb40
1 files changed, 37 insertions, 3 deletions
diff --git a/bootstraptest/test_syntax.rb b/bootstraptest/test_syntax.rb
index 8d87ab9..ed47d59 100644
--- a/bootstraptest/test_syntax.rb
+++ b/bootstraptest/test_syntax.rb
@@ -689,7 +689,7 @@ assert_equal 'ok', %q{
"#{next}"
end
:ok
-}
+}, 'reported by Yusuke ENDOH'
assert_equal 'ok', %q{
counter = 2
@@ -700,7 +700,7 @@ assert_equal 'ok', %q{
redo
end
:ok
-}
+}, 'reported by Yusuke ENDOH'
assert_equal 'ok', %q{
counter = 2
@@ -711,4 +711,38 @@ assert_equal 'ok', %q{
"#{ redo }"
end
:ok
-}
+}, 'reported by Yusuke ENDOH'
+
+assert_normal_exit %q{
+ begin
+ raise
+ rescue
+ counter = 2
+ while true
+ counter -= 1
+ break if counter == 0
+ next
+ retry
+ end
+ end
+}, 'reported by Yusuke ENDOH'
+
+assert_normal_exit %q{
+ counter = 2
+ while true
+ counter -= 1
+ break if counter == 0
+ next
+ "#{ break }"
+ end
+}, 'reported by Yusuke ENDOH'
+
+assert_normal_exit %q{
+ counter = 2
+ while true
+ counter -= 1
+ next if counter != 0
+ "#{ break }"
+ end
+}, 'reported by Yusuke ENDOH'
+