1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
require_relative '../fixtures/classes'
describe :thread_to_s, shared: true do
it "returns a description including file and line number" do
thread, line = Thread.new { "hello" }, __LINE__
thread.join
thread.send(@method).should =~ /^#<Thread:([^ ]*?) #{Regexp.escape __FILE__}:#{line} \w+>$/
end
it "has a binary encoding" do
ThreadSpecs.status_of_current_thread.send(@method).encoding.should == Encoding::BINARY
end
it "can check it's own status" do
ThreadSpecs.status_of_current_thread.send(@method).should include('run')
end
it "describes a running thread" do
ThreadSpecs.status_of_running_thread.send(@method).should include('run')
end
it "describes a sleeping thread" do
ThreadSpecs.status_of_sleeping_thread.send(@method).should include('sleep')
end
it "describes a blocked thread" do
ThreadSpecs.status_of_blocked_thread.send(@method).should include('sleep')
end
it "describes a completed thread" do
ThreadSpecs.status_of_completed_thread.send(@method).should include('dead')
end
it "describes a killed thread" do
ThreadSpecs.status_of_killed_thread.send(@method).should include('dead')
end
it "describes a thread with an uncaught exception" do
ThreadSpecs.status_of_thread_with_uncaught_exception.send(@method).should include('dead')
end
it "describes a dying sleeping thread" do
ThreadSpecs.status_of_dying_sleeping_thread.send(@method).should include('sleep')
end
it "reports aborting on a killed thread" do
ThreadSpecs.status_of_dying_running_thread.send(@method).should include('aborting')
end
it "reports aborting on a killed thread after sleep" do
ThreadSpecs.status_of_dying_thread_after_sleep.send(@method).should include('aborting')
end
end
|