File: timeout_spec.rb

package info (click to toggle)
dlr-languages 20090805%2Bgit.e6b28d27%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 51,484 kB
  • ctags: 59,257
  • sloc: cs: 298,829; ruby: 159,643; xml: 19,872; python: 2,820; yacc: 1,960; makefile: 96; sh: 65
file content (44 lines) | stat: -rw-r--r-- 1,002 bytes parent folder | download
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
require File.dirname(__FILE__) + '/../../spec_helper'
require 'timeout'

describe "Timeout.timeout" do
  it "raises Timeout::Error when it times out" do
    lambda {
      Timeout::timeout(1) do
        sleep 3
      end
    }.should raise_error(Timeout::Error)
  end
  
  it "shouldn't wait too long" do
    before_time = Time.now
    begin
      Timeout::timeout(1) do
        sleep 3
      end
    rescue Timeout::Error
      (Time.now - before_time).should < 1.2
    else
      1.should == 0  # I can't think of a better way to say "shouldn't get here"
    end
  end

  it "shouldn't return too quickly" do
    before_time = Time.now
    begin
      Timeout::timeout(2) do
        sleep 3
      end
    rescue Timeout::Error
      (Time.now - before_time).should > 1.9
    else
      1.should == 0  # I can't think of a better way to say "shouldn't get here"
    end
  end

  it "should return back the last value in the block" do
    Timeout::timeout(1) do
      42
    end.should == 42
  end
end