diff options
| author | Peter Zhu <peter@peterzhu.ca> | 2023-01-04 13:15:59 -0500 |
|---|---|---|
| committer | Peter Zhu <peter@peterzhu.ca> | 2023-01-04 14:59:40 -0500 |
| commit | 837ef8911c638c3e2bdb6af710de7c1fac7b5f90 (patch) | |
| tree | e2f08ba8b9dbc089210762a0363ed0eb81332ba0 /test/ruby | |
| parent | f7243d1afb726848fc5fa77dbb7c95eb78f6f610 (diff) | |
Fix crash in TracePoint c_call for removed method
trace_arg->id is the ID of the original method of an aliased method. If
the original method is removed, then the lookup will fail. We should use
trace_arg->called_id instead, which is the ID of the aliased method.
Fixes [Bug #19305]
Notes
Notes:
Merged: https://github.com/ruby/ruby/pull/7064
Diffstat (limited to 'test/ruby')
| -rw-r--r-- | test/ruby/test_settracefunc.rb | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/test/ruby/test_settracefunc.rb b/test/ruby/test_settracefunc.rb index 05d774016b..f869f574a7 100644 --- a/test/ruby/test_settracefunc.rb +++ b/test/ruby/test_settracefunc.rb @@ -70,6 +70,29 @@ class TestSetTraceFunc < Test::Unit::TestCase assert_nil(binding) end + def test_c_call_removed_method + # [Bug #19305] + klass = Class.new do + attr_writer :bar + alias_method :set_bar, :bar= + remove_method :bar= + end + + obj = klass.new + method_id = nil + parameters = nil + + TracePoint.new(:c_call) { |tp| + method_id = tp.method_id + parameters = tp.parameters + }.enable { + obj.set_bar(1) + } + + assert_equal(:bar=, method_id) + assert_equal([[:req]], parameters) + end + def test_call events = [] name = "#{self.class}\##{__method__}" |
