diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/assert.rb | 6 | ||||
| -rw-r--r-- | test/t/exception.rb | 47 |
2 files changed, 42 insertions, 11 deletions
diff --git a/test/assert.rb b/test/assert.rb index 6fad58fa8..e8368c64c 100644 --- a/test/assert.rb +++ b/test/assert.rb @@ -10,11 +10,7 @@ def t_print(*args) len = args.size while i < len str = args[i].to_s - begin - __printstr__ str - rescue NoMethodError - __t_printstr__ str rescue print str - end + __t_printstr__ str rescue print str i += 1 end end diff --git a/test/t/exception.rb b/test/t/exception.rb index d27813028..742f4a044 100644 --- a/test/t/exception.rb +++ b/test/t/exception.rb @@ -373,12 +373,47 @@ assert('Raise in ensure') do end end -assert('Raise in rescue') do - assert_raise(ArgumentError) do - begin - raise "" # RuntimeError - rescue - raise ArgumentError +def backtrace_avaialble? + begin + raise "XXX" + rescue => exception + not exception.backtrace.empty? + end +end + +assert('GC in rescue') do + skip "backtrace isn't avaialble" unless backtrace_avaialble? + + line = nil + begin + [1].each do + [2].each do + [3].each do + line = __LINE__; raise "XXX" + end + end + end + rescue => exception + GC.start + assert_equal("#{__FILE__}:#{line}:in Object.call", + exception.backtrace.first) + end +end + +assert('Method call in rescue') do + skip "backtrace isn't avaialble" unless backtrace_avaialble? + + line = nil + begin + [1].each do + [2].each do + line = __LINE__; raise "XXX" + end + end + rescue => exception + [3].each do end + assert_equal("#{__FILE__}:#{line}:in Object.call", + exception.backtrace.first) end end |
