mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/rinda/tuplespace.rb: fix Rinda::TupleSpace keeper thread bug.
the thread is started too early. [ruby-talk:264062] * test/rinda/test_rinda.rb: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_6@13222 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
679e43eccb
commit
e66f118a9b
4 changed files with 30 additions and 6 deletions
|
|
@ -1,3 +1,10 @@
|
|||
Sun Arg 12 03:56:30 2007 Masatoshi SEKI <m_seki@mva.biglobe.ne.jp>
|
||||
|
||||
* lib/rinda/tuplespace.rb: fix Rinda::TupleSpace keeper thread bug.
|
||||
the thread is started too early. [ruby-talk:264062]
|
||||
|
||||
* test/rinda/test_rinda.rb: ditto.
|
||||
|
||||
Wed Aug 22 12:31:15 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* configure.in (ac_cv_func_isinf): set yes also on OpenSolaris.
|
||||
|
|
|
|||
|
|
@ -404,7 +404,6 @@ module Rinda
|
|||
|
||||
def write(tuple, sec=nil)
|
||||
entry = TupleEntry.new(tuple, sec)
|
||||
start_keeper
|
||||
synchronize do
|
||||
if entry.expired?
|
||||
@read_waiter.find_all_template(entry).each do |template|
|
||||
|
|
@ -414,6 +413,7 @@ module Rinda
|
|||
notify_event('delete', entry.value)
|
||||
else
|
||||
@bag.push(entry)
|
||||
start_keeper if entry.expires
|
||||
@read_waiter.find_all_template(entry).each do |template|
|
||||
template.read(tuple)
|
||||
end
|
||||
|
|
@ -439,7 +439,6 @@ module Rinda
|
|||
def move(port, tuple, sec=nil)
|
||||
template = WaitTemplateEntry.new(self, tuple, sec)
|
||||
yield(template) if block_given?
|
||||
start_keeper
|
||||
synchronize do
|
||||
entry = @bag.find(template)
|
||||
if entry
|
||||
|
|
@ -452,6 +451,7 @@ module Rinda
|
|||
|
||||
begin
|
||||
@take_waiter.push(template)
|
||||
start_keeper if template.expires
|
||||
while true
|
||||
raise RequestCanceledError if template.canceled?
|
||||
raise RequestExpiredError if template.expired?
|
||||
|
|
@ -476,7 +476,6 @@ module Rinda
|
|||
def read(tuple, sec=nil)
|
||||
template = WaitTemplateEntry.new(self, tuple, sec)
|
||||
yield(template) if block_given?
|
||||
start_keeper
|
||||
synchronize do
|
||||
entry = @bag.find(template)
|
||||
return entry.value if entry
|
||||
|
|
@ -484,6 +483,7 @@ module Rinda
|
|||
|
||||
begin
|
||||
@read_waiter.push(template)
|
||||
start_keeper if template.expires
|
||||
template.wait
|
||||
raise RequestCanceledError if template.canceled?
|
||||
raise RequestExpiredError if template.expired?
|
||||
|
|
@ -566,8 +566,11 @@ module Rinda
|
|||
def start_keeper
|
||||
return if @keeper && @keeper.alive?
|
||||
@keeper = Thread.new do
|
||||
while need_keeper?
|
||||
keep_clean
|
||||
while true
|
||||
synchronize do
|
||||
break unless need_keeper?
|
||||
keep_clean
|
||||
end
|
||||
sleep(@period)
|
||||
end
|
||||
end
|
||||
|
|
|
|||
|
|
@ -240,6 +240,20 @@ module TupleSpaceTestModule
|
|||
end
|
||||
end
|
||||
|
||||
def test_ruby_talk_264062
|
||||
th = Thread.new { @ts.take([:empty], 1) }
|
||||
sleep 2
|
||||
assert_raises(Rinda::RequestExpiredError) do
|
||||
th.value
|
||||
end
|
||||
|
||||
th = Thread.new { @ts.read([:empty], 1) }
|
||||
sleep 2
|
||||
assert_raises(Rinda::RequestExpiredError) do
|
||||
th.value
|
||||
end
|
||||
end
|
||||
|
||||
def test_core_01
|
||||
5.times do |n|
|
||||
@ts.write([:req, 2])
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@
|
|||
#define RUBY_RELEASE_DATE "2007-08-22"
|
||||
#define RUBY_VERSION_CODE 186
|
||||
#define RUBY_RELEASE_CODE 20070822
|
||||
#define RUBY_PATCHLEVEL 87
|
||||
#define RUBY_PATCHLEVEL 88
|
||||
|
||||
#define RUBY_VERSION_MAJOR 1
|
||||
#define RUBY_VERSION_MINOR 8
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue