diff options
author | Takashi Kokubun <takashikkbn@gmail.com> | 2022-11-10 14:12:38 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-11-10 17:12:38 -0500 |
commit | 2b8191bdad7545b71f270d2b25a34cd2b3afa02f (patch) | |
tree | 76117dbcae3361e74b3ae6ce01a3a488e6fb127c /test | |
parent | d9056328514041c22f73809921118fa7a1478092 (diff) |
YJIT: Invalidate JIT code only for ISEQ_TRACE_EVENTS (#6695)
Notes
Notes:
Merged-By: maximecb <maximecb@ruby-lang.org>
Diffstat (limited to 'test')
-rw-r--r-- | test/ruby/test_yjit.rb | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/test/ruby/test_yjit.rb b/test/ruby/test_yjit.rb index 1a564889af..fab8768a7e 100644 --- a/test/ruby/test_yjit.rb +++ b/test/ruby/test_yjit.rb @@ -918,6 +918,54 @@ class TestYJIT < Test::Unit::TestCase RUBY end + def test_trace_script_compiled # not ISEQ_TRACE_EVENTS + assert_compiles(<<~'RUBY', exits: :any, result: :ok) + @eval_counter = 0 + def eval_script + eval('@eval_counter += 1') + end + + @trace_counter = 0 + trace = TracePoint.new(:script_compiled) do |t| + @trace_counter += 1 + end + + eval_script # JIT without TracePoint + trace.enable + eval_script # call with TracePoint + trace.disable + + return :"eval_#{@eval_counter}" if @eval_counter != 2 + return :"trace_#{@trace_counter}" if @trace_counter != 1 + + :ok + RUBY + end + + def test_trace_b_call # ISEQ_TRACE_EVENTS + assert_compiles(<<~'RUBY', exits: :any, result: :ok) + @call_counter = 0 + def block_call + 1.times { @call_counter += 1 } + end + + @trace_counter = 0 + trace = TracePoint.new(:b_call) do |t| + @trace_counter += 1 + end + + block_call # JIT without TracePoint + trace.enable + block_call # call with TracePoint + trace.disable + + return :"call_#{@call_counter}" if @call_counter != 2 + return :"trace_#{@trace_counter}" if @trace_counter != 1 + + :ok + RUBY + end + private def code_gc_helpers |