mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
69 lines
2 KiB
Ruby
69 lines
2 KiB
Ruby
require_relative '../../spec_helper'
|
|
|
|
describe "Thread#backtrace" do
|
|
it "returns the current backtrace of a thread" do
|
|
t = Thread.new do
|
|
begin
|
|
sleep
|
|
rescue
|
|
end
|
|
end
|
|
|
|
Thread.pass while t.status && t.status != 'sleep'
|
|
|
|
backtrace = t.backtrace
|
|
backtrace.should be_kind_of(Array)
|
|
backtrace.first.should =~ /`sleep'/
|
|
|
|
t.raise 'finish the thread'
|
|
t.join
|
|
end
|
|
|
|
it "returns nil for dead thread" do
|
|
t = Thread.new {}
|
|
t.join
|
|
t.backtrace.should == nil
|
|
end
|
|
|
|
it "returns an array (which may be empty) immediately after the thread is created" do
|
|
t = Thread.new { sleep }
|
|
backtrace = t.backtrace
|
|
t.kill
|
|
t.join
|
|
backtrace.should be_kind_of(Array)
|
|
end
|
|
|
|
it "can be called with a number of locations to omit" do
|
|
locations1 = Thread.current.backtrace
|
|
locations2 = Thread.current.backtrace(2)
|
|
locations1[2..-1].length.should == locations2.length
|
|
locations1[2..-1].map(&:to_s).should == locations2.map(&:to_s)
|
|
end
|
|
|
|
it "can be called with a maximum number of locations to return as second parameter" do
|
|
locations1 = Thread.current.backtrace
|
|
locations2 = Thread.current.backtrace(2, 3)
|
|
locations1[2..4].map(&:to_s).should == locations2.map(&:to_s)
|
|
end
|
|
|
|
it "can be called with a range" do
|
|
locations1 = Thread.current.backtrace
|
|
locations2 = Thread.current.backtrace(2..4)
|
|
locations1[2..4].map(&:to_s).should == locations2.map(&:to_s)
|
|
end
|
|
|
|
it "can be called with a range whose end is negative" do
|
|
Thread.current.backtrace(2..-1).should == Thread.current.backtrace[2..-1]
|
|
Thread.current.backtrace(2..-2).should == Thread.current.backtrace[2..-2]
|
|
end
|
|
|
|
it "returns nil if omitting more locations than available" do
|
|
Thread.current.backtrace(100).should == nil
|
|
Thread.current.backtrace(100..-1).should == nil
|
|
end
|
|
|
|
it "returns [] if omitting exactly the number of locations available" do
|
|
omit = Thread.current.backtrace.length
|
|
Thread.current.backtrace(omit).should == []
|
|
end
|
|
end
|