From 11dbedfaad4a9a9521ece2198a8dc491678b1902 Mon Sep 17 00:00:00 2001 From: shyouhei Date: Wed, 29 Aug 2007 04:06:12 +0000 Subject: add tag v1_8_6_5001 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/tags/v1_8_6_5001@13304 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ruby_1_8_6/test/drb/ut_timerholder.rb | 49 +++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 ruby_1_8_6/test/drb/ut_timerholder.rb (limited to 'ruby_1_8_6/test/drb/ut_timerholder.rb') diff --git a/ruby_1_8_6/test/drb/ut_timerholder.rb b/ruby_1_8_6/test/drb/ut_timerholder.rb new file mode 100644 index 0000000000..141cb73302 --- /dev/null +++ b/ruby_1_8_6/test/drb/ut_timerholder.rb @@ -0,0 +1,49 @@ +require 'runit/testcase' +require 'runit/cui/testrunner' +require 'timerholder' + +class TimerHolderTest < RUNIT::TestCase + def do_test(timeout, keeper_sleep = nil) + holder = TimerHolder.new(timeout) + holder.keeper_sleep = keeper_sleep if keeper_sleep + key = holder.add(self) + sleep(timeout * 0.5) + assert_equal(holder.peek(key), self) + holder.delete(key) + assert(!holder.include?(key)) + key = holder.add(self) + sleep(timeout+0.5) + assert_equal(holder.fetch(key), nil) + key = holder.add(self) + assert_equal(holder.fetch(key), self) + holder.store(key, true) + assert_equal(holder.fetch(key), true) + assert_equal(holder.include?(key), true) + sleep(timeout+0.5) + assert_exception(TimerHolder::InvalidIndexError) do + holder.store(key, 1) + end + assert_equal(holder.include?(key), false) + key = holder.add(self) + sleep(timeout * 0.5) + assert(holder.include?(key)) + holder.extend(key, timeout) + sleep(timeout * 0.5) + assert(holder.include?(key)) + sleep(timeout * 0.6) + assert(!holder.include?(key)) + holder.delete(key) + end + + def test_00 + do_test(0.5) + end + + def test_01 + do_test(1, 0.5) + end +end + +if __FILE__ == $0 + RUNIT::CUI::TestRunner.run(TimerHolderTest.suite) +end -- cgit v1.2.3