summaryrefslogtreecommitdiff
path: root/test/rinda
diff options
context:
space:
mode:
Diffstat (limited to 'test/rinda')
-rw-r--r--test/rinda/test_rinda.rb86
1 files changed, 24 insertions, 62 deletions
diff --git a/test/rinda/test_rinda.rb b/test/rinda/test_rinda.rb
index e91ecf395f..8154b46da3 100644
--- a/test/rinda/test_rinda.rb
+++ b/test/rinda/test_rinda.rb
@@ -269,37 +269,29 @@ module TupleSpaceTestModule
assert_equal([[:req, 2], [:req, 2], [:req, 2], [:req, 2], [:req, 2]],
@ts.read_all([nil, nil]))
- taker = Thread.new do
+ taker = Thread.new(5) do |count|
s = 0
- while true
- begin
- tuple = @ts.take([:req, Integer], 1)
- assert_equal(2, tuple[1])
- s += tuple[1]
- rescue Rinda::RequestExpiredError
- break
- end
+ count.times do
+ tuple = @ts.take([:req, Integer])
+ assert_equal(2, tuple[1])
+ s += tuple[1]
end
@ts.write([:ans, s])
s
end
assert_equal(10, thread_join(taker))
- tuple = @ts.take([:ans, nil])
- assert_equal(10, tuple[1])
+ assert_equal([:ans, 10], @ts.take([:ans, 10]))
+ assert_equal([], @ts.read_all([nil, nil]))
end
def test_core_02
- taker = Thread.new do
+ taker = Thread.new(5) do |count|
s = 0
- while true
- begin
- tuple = @ts.take([:req, Integer], 1)
- assert_equal(2, tuple[1])
- s += tuple[1]
- rescue Rinda::RequestExpiredError
- break
- end
+ count.times do
+ tuple = @ts.take([:req, Integer])
+ assert_equal(2, tuple[1])
+ s += tuple[1]
end
@ts.write([:ans, s])
s
@@ -310,22 +302,20 @@ module TupleSpaceTestModule
end
assert_equal(10, thread_join(taker))
- tuple = @ts.take([:ans, nil])
- assert_equal(10, tuple[1])
+ assert_equal([:ans, 10], @ts.take([:ans, 10]))
assert_equal([], @ts.read_all([nil, nil]))
end
def test_core_03_notify
notify1 = @ts.notify(nil, [:req, Integer])
- notify2 = @ts.notify(nil, [:ans, Integer], 8)
- notify3 = @ts.notify(nil, {"message"=>String, "name"=>String}, 8)
+ notify2 = @ts.notify(nil, {"message"=>String, "name"=>String}, 8)
@ts.write({"message"=>"first", "name"=>"3"}, 3)
@ts.write({"message"=>"second", "name"=>"1"}, 1)
@ts.write({"message"=>"third", "name"=>"0"})
@ts.take({"message"=>"third", "name"=>"0"})
- listener1 = Thread.new do
+ listener = Thread.new do
lv = 0
n = 0
notify1.each do |ev, tuple|
@@ -343,35 +333,12 @@ module TupleSpaceTestModule
[lv, n]
end
- listener2 = Thread.new do
- result = nil
- lv = 0
- n = 0
- notify2.each do |ev, tuple|
- n += 1
- if ev == 'write'
- lv = lv + 1
- elsif ev == 'take'
- lv = lv - 1
- elsif ev == 'close'
- result = [lv, n]
- break
- end
- assert(lv >= 0)
- assert_equal([:ans, 10], tuple)
- end
- result
- end
-
- taker = Thread.new do
+ taker = Thread.new(5) do |count|
s = 0
- while true
- begin
- tuple = @ts.take([:req, Integer], 1)
- s += tuple[1]
- rescue Rinda::RequestExpiredError
- break
- end
+ count.times do
+ tuple = @ts.take([:req, Integer])
+ assert_equal(2, tuple[1])
+ s += tuple[1]
end
@ts.write([:ans, s])
s
@@ -383,19 +350,14 @@ module TupleSpaceTestModule
@ts.take({"message"=>"first", "name"=>"3"})
- sleep(4)
assert_equal(10, thread_join(taker))
- # notify2 must not expire until this @ts.take.
- # sleep(4) might be short enough for the timeout of notify2 (8 secs)
- tuple = @ts.take([:ans, nil])
- assert_equal(10, tuple[1])
+ assert_equal([:ans, 10], @ts.take([:ans, 10]))
assert_equal([], @ts.read_all([nil, nil]))
notify1.cancel
- sleep(7) # notify2 expired (sleep(4)+sleep(7) > 8)
+ sleep(8)
- assert_equal([0, 11], thread_join(listener1))
- assert_equal([0, 3], thread_join(listener2))
+ assert_equal([0, 11], thread_join(listener))
ary = []
ary.push(["write", {"message"=>"first", "name"=>"3"}])
@@ -406,7 +368,7 @@ module TupleSpaceTestModule
ary.push(["delete", {"message"=>"second", "name"=>"1"}])
ary.push(["close"])
- notify3.each do |ev|
+ notify2.each do |ev|
assert_equal(ary.shift, ev)
end
assert_equal([], ary)