git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@60975 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
eregon 2017-12-01 17:51:16 +00:00
parent 60775cc48a
commit d209b4c0a2
2 changed files with 53 additions and 34 deletions

View File

@ -3,18 +3,18 @@ require File.expand_path('../../../spec_helper', __FILE__)
describe 'TracePoint#disable' do describe 'TracePoint#disable' do
def test; end def test; end
it 'returns true if trace was enabled' do it 'returns true if trace was enabled' do
event_name, method_name = nil called = false
trace = TracePoint.new(:call) do |tp| trace = TracePoint.new(:call) do |tp|
event_name = tp.event called = true
method_name = tp.method_id
end end
trace.enable trace.enable
trace.disable.should be_true trace.disable.should be_true
event_name, method_name = nil
# Check the TracePoint is disabled
called = false
test test
method_name.equal?(:test).should be_false called.should == false
event_name.should equal(nil)
end end
it 'returns false if trace was disabled' do it 'returns false if trace was disabled' do
@ -35,18 +35,24 @@ describe 'TracePoint#disable' do
enabled = nil enabled = nil
trace = TracePoint.new(:line) {} trace = TracePoint.new(:line) {}
trace.enable trace.enable
trace.disable { enabled = trace.enabled? } begin
enabled.should be_false trace.disable { enabled = trace.enabled? }
trace.enabled?.should be_true enabled.should be_false
trace.disable trace.enabled?.should be_true
ensure
trace.disable
end
end end
it 'is disabled within a block & also returns false when its called with a block' do it 'is disabled within a block & also returns false when its called with a block' do
trace = TracePoint.new(:line) {} trace = TracePoint.new(:line) {}
trace.enable trace.enable
trace.disable { trace.enabled? }.should == false begin
trace.enabled?.should equal(true) trace.disable { trace.enabled? }.should == false
trace.disable trace.enabled?.should equal(true)
ensure
trace.disable
end
end end
ruby_bug "#14057", "2.0"..."2.5" do ruby_bug "#14057", "2.0"..."2.5" do
@ -54,11 +60,14 @@ describe 'TracePoint#disable' do
event_name = nil event_name = nil
trace = TracePoint.new(:line) {} trace = TracePoint.new(:line) {}
trace.enable trace.enable
trace.disable do |*args| begin
args.should == [] trace.disable do |*args|
args.should == []
end
trace.enabled?.should be_true
ensure
trace.disable
end end
trace.enabled?.should be_true
trace.disable
end end
end end
end end

View File

@ -5,20 +5,21 @@ describe 'TracePoint#enable' do
describe 'without a block' do describe 'without a block' do
it 'returns true if trace was enabled' do it 'returns true if trace was enabled' do
event_name, method_name = nil, nil event_name = nil
method_name = []
trace = TracePoint.new(:call) do |tp| trace = TracePoint.new(:call) do |tp|
event_name = tp.event event_name = tp.event
method_name << tp.method_id
end end
test test
event_name.should == nil event_name.should == nil
trace.enable trace.enable
test begin
event_name.should equal(:call) test
trace.disable event_name.should equal(:call)
ensure
trace.disable
end
end end
it 'returns false if trace was disabled' do it 'returns false if trace was disabled' do
@ -29,21 +30,27 @@ describe 'TracePoint#enable' do
end end
trace.enable.should be_false trace.enable.should be_false
event_name.should equal(:call) begin
test event_name.should equal(:call)
method_name.equal?(:test).should be_true test
method_name.equal?(:test).should be_true
ensure
trace.disable
end
trace.disable
event_name, method_name = nil event_name, method_name = nil
test test
method_name.equal?(:test).should be_false method_name.equal?(:test).should be_false
event_name.should equal(nil) event_name.should equal(nil)
trace.enable.should be_false trace.enable.should be_false
event_name.should equal(:call) begin
test event_name.should equal(:call)
method_name.equal?(:test).should be_true test
trace.disable method_name.equal?(:test).should be_true
ensure
trace.disable
end
end end
end end
@ -71,9 +78,12 @@ describe 'TracePoint#enable' do
enabled = nil enabled = nil
trace = TracePoint.new(:line) {} trace = TracePoint.new(:line) {}
trace.enable trace.enable
trace.enable { enabled = trace.enabled? } begin
enabled.should == true trace.enable { enabled = trace.enabled? }
trace.disable enabled.should == true
ensure
trace.disable
end
end end
it 'returns value returned by the block' do it 'returns value returned by the block' do