blob: f3477804ad15547d80704116c35a53d2c4b91804 (
plain)
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
54
55
56
57
58
|
describe :fiber_resume, shared: true do
it "can be invoked from the root Fiber" do
fiber = Fiber.new { :fiber }
fiber.send(@method).should == :fiber
end
it "raises a FiberError if invoked from a different Thread" do
fiber = Fiber.new { 42 }
Thread.new do
-> {
fiber.send(@method)
}.should raise_error(FiberError)
end.join
# Check the Fiber can still be used
fiber.send(@method).should == 42
end
it "passes control to the beginning of the block on first invocation" do
invoked = false
fiber = Fiber.new { invoked = true }
fiber.send(@method)
invoked.should be_true
end
it "returns the last value encountered on first invocation" do
fiber = Fiber.new { 1+1; true }
fiber.send(@method).should be_true
end
it "runs until the end of the block" do
obj = mock('obj')
obj.should_receive(:do).once
fiber = Fiber.new { 1 + 2; a = "glark"; obj.do }
fiber.send(@method)
end
it "accepts any number of arguments" do
fiber = Fiber.new { |a| }
-> { fiber.send(@method, *(1..10).to_a) }.should_not raise_error
end
it "raises a FiberError if the Fiber is dead" do
fiber = Fiber.new { true }
fiber.send(@method)
-> { fiber.send(@method) }.should raise_error(FiberError)
end
it "raises a LocalJumpError if the block includes a return statement" do
fiber = Fiber.new { return; }
-> { fiber.send(@method) }.should raise_error(LocalJumpError)
end
it "raises a LocalJumpError if the block includes a break statement" do
fiber = Fiber.new { break; }
-> { fiber.send(@method) }.should raise_error(LocalJumpError)
end
end
|