1 module ThreadInstrumentation
6 Bug::ThreadInstrumentation.register_callback(!ENV["GVL_DEBUG"])
9 timeline = Bug::ThreadInstrumentation.unregister_callback
17 def timeline_for(thread, timeline)
18 timeline.select { |t, _| t == thread }.map(&:last)
21 def assert_consistent_timeline(events)
22 refute_predicate events, :empty?
25 events.each do |event|
26 refute_equal :exited, previous_event, "`exited` must be the final event: #{events.inspect}"
29 assert_nil previous_event, "`started` must be the first event: #{events.inspect}"
31 unless previous_event.nil?
32 assert %i(started suspended).include?(previous_event), "`ready` must be preceded by `started` or `suspended`: #{events.inspect}"
35 unless previous_event.nil?
36 assert_equal :ready, previous_event, "`resumed` must be preceded by `ready`: #{events.inspect}"
39 unless previous_event.nil?
40 assert_equal :resumed, previous_event, "`suspended` must be preceded by `resumed`: #{events.inspect}"
43 unless previous_event.nil?
44 assert %i(resumed suspended).include?(previous_event), "`exited` must be preceded by `resumed` or `suspended`: #{events.inspect}"
47 previous_event = event