2018-03-04 15:09:32 +00:00
|
|
|
require_relative '../../spec_helper'
|
2017-12-01 15:41:50 +00:00
|
|
|
|
|
|
|
describe 'TracePoint#enable' do
|
|
|
|
def test; end
|
|
|
|
|
|
|
|
describe 'without a block' do
|
|
|
|
it 'returns true if trace was enabled' do
|
2017-12-01 17:51:16 +00:00
|
|
|
event_name = nil
|
2017-12-01 15:41:50 +00:00
|
|
|
trace = TracePoint.new(:call) do |tp|
|
|
|
|
event_name = tp.event
|
|
|
|
end
|
|
|
|
|
|
|
|
test
|
|
|
|
event_name.should == nil
|
|
|
|
|
|
|
|
trace.enable
|
2017-12-01 17:51:16 +00:00
|
|
|
begin
|
|
|
|
test
|
|
|
|
event_name.should equal(:call)
|
|
|
|
ensure
|
|
|
|
trace.disable
|
|
|
|
end
|
2017-12-01 15:41:50 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns false if trace was disabled' do
|
|
|
|
event_name, method_name = nil, nil
|
|
|
|
trace = TracePoint.new(:call) do |tp|
|
|
|
|
event_name = tp.event
|
|
|
|
method_name = tp.method_id
|
|
|
|
end
|
|
|
|
|
|
|
|
trace.enable.should be_false
|
2017-12-01 17:51:16 +00:00
|
|
|
begin
|
|
|
|
event_name.should equal(:call)
|
|
|
|
test
|
|
|
|
method_name.equal?(:test).should be_true
|
|
|
|
ensure
|
|
|
|
trace.disable
|
|
|
|
end
|
2017-12-01 15:41:50 +00:00
|
|
|
|
|
|
|
event_name, method_name = nil
|
|
|
|
test
|
|
|
|
method_name.equal?(:test).should be_false
|
|
|
|
event_name.should equal(nil)
|
|
|
|
|
|
|
|
trace.enable.should be_false
|
2017-12-01 17:51:16 +00:00
|
|
|
begin
|
|
|
|
event_name.should equal(:call)
|
|
|
|
test
|
|
|
|
method_name.equal?(:test).should be_true
|
|
|
|
ensure
|
|
|
|
trace.disable
|
|
|
|
end
|
2017-12-01 15:41:50 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'with a block' do
|
|
|
|
it 'enables the trace object within a block' do
|
|
|
|
event_name = nil
|
|
|
|
TracePoint.new(:line) do |tp|
|
|
|
|
event_name = tp.event
|
|
|
|
end.enable { event_name.should equal(:line) }
|
|
|
|
end
|
|
|
|
|
2018-04-28 19:50:06 +00:00
|
|
|
ruby_bug "#14057", ""..."2.5" do
|
2017-12-01 15:41:50 +00:00
|
|
|
it 'can accept arguments within a block but it should not yield arguments' do
|
|
|
|
event_name = nil
|
|
|
|
trace = TracePoint.new(:line) { |tp| event_name = tp.event }
|
|
|
|
trace.enable do |*args|
|
|
|
|
event_name.should equal(:line)
|
|
|
|
args.should == []
|
|
|
|
end
|
|
|
|
trace.enabled?.should be_false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'enables trace object on calling with a block if it was already enabled' do
|
|
|
|
enabled = nil
|
|
|
|
trace = TracePoint.new(:line) {}
|
|
|
|
trace.enable
|
2017-12-01 17:51:16 +00:00
|
|
|
begin
|
|
|
|
trace.enable { enabled = trace.enabled? }
|
|
|
|
enabled.should == true
|
|
|
|
ensure
|
|
|
|
trace.disable
|
|
|
|
end
|
2017-12-01 15:41:50 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns value returned by the block' do
|
|
|
|
trace = TracePoint.new(:line) {}
|
|
|
|
trace.enable { true; 'test' }.should == 'test'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'disables the trace object outside the block' do
|
|
|
|
event_name = nil
|
|
|
|
trace = TracePoint.new(:line) { |tp|event_name = tp.event }
|
|
|
|
trace.enable { '2 + 2' }
|
|
|
|
event_name.should equal(:line)
|
|
|
|
trace.enabled?.should be_false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|