2018-03-04 10:09:32 -05:00
|
|
|
require_relative '../../spec_helper'
|
2017-05-07 08:04:49 -04:00
|
|
|
require 'timeout'
|
|
|
|
|
|
|
|
describe "Timeout.timeout" do
|
|
|
|
it "raises Timeout::Error when it times out with no specified error type" do
|
|
|
|
lambda {
|
|
|
|
Timeout.timeout(1) do
|
|
|
|
sleep 3
|
|
|
|
end
|
|
|
|
}.should raise_error(Timeout::Error)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises specified error type when it times out" do
|
|
|
|
lambda do
|
|
|
|
Timeout.timeout(1, StandardError) do
|
|
|
|
sleep 3
|
|
|
|
end
|
|
|
|
end.should raise_error(StandardError)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not wait too long" do
|
|
|
|
before_time = Time.now
|
|
|
|
lambda do
|
|
|
|
Timeout.timeout(1, StandardError) do
|
|
|
|
sleep 3
|
|
|
|
end
|
|
|
|
end.should raise_error(StandardError)
|
|
|
|
|
2019-03-29 08:00:44 -04:00
|
|
|
(Time.now - before_time).should be_close(1.0, 0.8)
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "returns back the last value in the block" do
|
|
|
|
Timeout.timeout(1) do
|
|
|
|
42
|
|
|
|
end.should == 42
|
|
|
|
end
|
|
|
|
end
|