aboutsummaryrefslogtreecommitdiffstats
path: root/test/ruby/test_settracefunc.rb
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-06-19 12:43:48 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-06-19 12:43:48 +0000
commitbef2e29aab53d2d15006fad7de9e56f2f44c7778 (patch)
treeae966a2db6bf86622ac22a033dc3a6d25a0bf23a /test/ruby/test_settracefunc.rb
parent370212a8ae39939979cf0651bd98108316a8e535 (diff)
downloadruby-bef2e29aab53d2d15006fad7de9e56f2f44c7778.tar.gz
* vm.c (rb_vm_rewind_cfp): add new function to rewind specified cfp
with invoking RUBY_EVENT_C_RETURN. [Bug #9961] * vm_core.h: ditto. * eval.c (rb_protect): use it. * eval.c (rb_rescue2): ditto. * vm_eval.c (rb_iterate): ditto. * test/ruby/test_settracefunc.rb: add a test. * vm_core.h (rb_name_err_mesg_new): git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@46465 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby/test_settracefunc.rb')
-rw-r--r--test/ruby/test_settracefunc.rb51
1 files changed, 51 insertions, 0 deletions
diff --git a/test/ruby/test_settracefunc.rb b/test/ruby/test_settracefunc.rb
index 0c8d7399cc..5d46fc3b08 100644
--- a/test/ruby/test_settracefunc.rb
+++ b/test/ruby/test_settracefunc.rb
@@ -1257,4 +1257,55 @@ class TestSetTraceFunc < Test::Unit::TestCase
assert_equal [], events # should be empty.
end
+
+ def test_rb_rescue
+ events = []
+ curr_thread = Thread.current
+ TracePoint.new(:a_call, :a_return){|tp|
+ next if curr_thread != Thread.current
+ events << [tp.event, tp.method_id]
+ }.enable do
+ begin
+ -Numeric.new
+ rescue => e
+ # ignore
+ end
+ end
+
+ assert_equal [
+ [:b_call, :test_rb_rescue],
+ [:c_call, :new],
+ [:c_call, :initialize],
+ [:c_return, :initialize],
+ [:c_return, :new],
+ [:c_call, :-@],
+ [:c_call, :coerce],
+ [:c_call, :to_s],
+ [:c_return, :to_s],
+ [:c_call, :new],
+ [:c_call, :initialize],
+ [:c_return, :initialize],
+ [:c_return, :new],
+ [:c_call, :exception],
+ [:c_return, :exception],
+ [:c_call, :backtrace],
+ [:c_return, :backtrace],
+ [:c_return, :coerce], # don't miss it!
+ [:c_call, :to_s],
+ [:c_return, :to_s],
+ [:c_call, :to_s],
+ [:c_return, :to_s],
+ [:c_call, :new],
+ [:c_call, :initialize],
+ [:c_return, :initialize],
+ [:c_return, :new],
+ [:c_call, :exception],
+ [:c_return, :exception],
+ [:c_call, :backtrace],
+ [:c_return, :backtrace],
+ [:c_return, :-@],
+ [:c_call, :===],
+ [:c_return, :===],
+ [:b_return, :test_rb_rescue]], events
+ end
end