blob: c2c2aee9bf0ce7c917682ec05ab5a393a977acb9 (
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
describe :process_fork, shared: true do
platform_is :windows do
it "returns false from #respond_to?" do
# Workaround for Kernel::Method being public and losing the "non-respond_to? magic"
mod = @object.class.name == "KernelSpecs::Method" ? Object.new : @object
mod.respond_to?(:fork).should be_false
mod.respond_to?(:fork, true).should be_false
end
it "raises a NotImplementedError when called" do
lambda { @object.fork }.should raise_error(NotImplementedError)
end
end
platform_is_not :windows do
before :each do
@file = tmp('i_exist')
rm_r @file
end
after :each do
rm_r @file
end
it "returns status zero" do
pid = Process.fork { exit! 0 }
_, result = Process.wait2(pid)
result.exitstatus.should == 0
end
it "returns status zero" do
pid = Process.fork { exit 0 }
_, result = Process.wait2(pid)
result.exitstatus.should == 0
end
it "returns status zero" do
pid = Process.fork {}
_, result = Process.wait2(pid)
result.exitstatus.should == 0
end
it "returns status non-zero" do
pid = Process.fork { exit! 42 }
_, result = Process.wait2(pid)
result.exitstatus.should == 42
end
it "returns status non-zero" do
pid = Process.fork { exit 42 }
_, result = Process.wait2(pid)
result.exitstatus.should == 42
end
it "returns nil for the child process" do
child_id = @object.fork
if child_id == nil
touch(@file) { |f| f.write 'rubinius' }
Process.exit!
else
Process.waitpid(child_id)
end
File.exist?(@file).should == true
end
it "runs a block in a child process" do
pid = @object.fork {
touch(@file) { |f| f.write 'rubinius' }
Process.exit!
}
Process.waitpid(pid)
File.exist?(@file).should == true
end
it "marks threads from the parent as killed" do
t = Thread.new { sleep }
pid = @object.fork {
touch(@file) do |f|
f.write Thread.current.alive?
f.write t.alive?
end
Process.exit!
}
Process.waitpid(pid)
t.kill
t.join
File.read(@file).should == "truefalse"
end
end
end
|