diff options
author | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-10-07 07:35:21 +0000 |
---|---|---|
committer | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-10-07 07:35:21 +0000 |
commit | ef7df5a414852b172a330fb93a8901d203f8e4c9 (patch) | |
tree | fdc48a2ffda356791a36a8af2e0832b0df30b44d /test/-ext-/debug | |
parent | 774bff0adb44eaf5c806afb1bf9eff65d26b2f1f (diff) | |
download | ruby-ef7df5a414852b172a330fb93a8901d203f8e4c9.tar.gz |
* ext/-test-/debug/profile_frames.c:
test/-ext-/debug/test_profile_frames.rb: add a test for new C-APIs.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@43171 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/-ext-/debug')
-rw-r--r-- | test/-ext-/debug/test_profile_frames.rb | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/test/-ext-/debug/test_profile_frames.rb b/test/-ext-/debug/test_profile_frames.rb new file mode 100644 index 0000000000..05e4706eb6 --- /dev/null +++ b/test/-ext-/debug/test_profile_frames.rb @@ -0,0 +1,54 @@ +require 'test/unit' +require '-test-/debug' + +class C + def self.bar(block) + block.call + end + + def foo(block) + self.class.bar(block) + end +end + +class TestProfileFrames < Test::Unit::TestCase + def test_profile_frames + frames = Fiber.new{ + Fiber.yield C.new.foo(lambda{ Bug::Debug.profile_frames(0, 10) }) + }.resume + + assert_equal(4, frames.size) + + labels = [ + "block (2 levels) in test_profile_frames", + "bar", + "foo", + "block in test_profile_frames", + ] + base_labels = [ + "test_profile_frames", + "bar", + "foo", + "test_profile_frames", + ] + classes = [ + TestProfileFrames, + C, # singleton method + C, + TestProfileFrames, + ] + singleton_method_p = [ + false, true, false, false, false, + ] + + frames.each.with_index{|(path, absolute_path, label, base_label, first_lineno, classpath, singleton_p), i| + err_msg = "#{i}th frame" + assert_equal(__FILE__, path, err_msg) + assert_equal(__FILE__, absolute_path, err_msg) + assert_equal(labels[i], label, err_msg) + assert_equal(base_labels[i], base_label, err_msg) + assert_equal(classes[i].to_s, classpath, err_msg) + assert_equal(singleton_method_p[i], singleton_p, err_msg) + } + end +end |