summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-02-09 16:07:41 +0000
committernagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-02-09 16:07:41 +0000
commit08e1428b7bf2baaa9fefeacfaef518dc75cc9c64 (patch)
tree90f61fe0e3eba2898ed2f2e03843baf5a890fc7c
parentf0e5252835e5492333e9d223be043781d91667ce (diff)
merge revision(s) 44595: [Backport #9342]
* ext/thread/thread.c (rb_szqueue_clear): notify SZQUEUE_WAITERS on SizedQueue#clear. [ruby-core:59462] [Bug #9342] * test/thread/test_queue.rb: add test. the patch is from Justin Collins. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@44899 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog8
-rw-r--r--lib/thread.rb12
-rw-r--r--test/thread/test_queue.rb67
-rw-r--r--version.h2
4 files changed, 88 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 700f7f805c..6bba4c2d1a 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+Mon Feb 10 00:42:12 2014 Masaki Matsushita <glass.saga@gmail.com>
+
+ * ext/thread/thread.c (rb_szqueue_clear): notify SZQUEUE_WAITERS
+ on SizedQueue#clear. [ruby-core:59462] [Bug #9342]
+
+ * test/thread/test_queue.rb: add test. the patch is from
+ Justin Collins.
+
Mon Feb 10 00:27:33 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
* parse.y (local_push_gen, local_pop_gen): save cmdarg_stack to
diff --git a/lib/thread.rb b/lib/thread.rb
index 1c8107085b..b140a9e445 100644
--- a/lib/thread.rb
+++ b/lib/thread.rb
@@ -319,6 +319,18 @@ class SizedQueue < Queue
end
#
+ # Removes all objects from the queue.
+ #
+ def clear
+ super
+ @mutex.synchronize do
+ @max.times do
+ @enque_cond.signal
+ end
+ end
+ end
+
+ #
# Alias of push
#
alias << push
diff --git a/test/thread/test_queue.rb b/test/thread/test_queue.rb
index 993514f86d..6b4f10c4d2 100644
--- a/test/thread/test_queue.rb
+++ b/test/thread/test_queue.rb
@@ -108,4 +108,71 @@ class TestQueue < Test::Unit::TestCase
end
}
end
+
+ def test_sized_queue_clear
+ # Fill queue, then test that SizedQueue#clear wakes up all waiting threads
+ sq = SizedQueue.new(2)
+ 2.times { sq << 1 }
+
+ t1 = Thread.new do
+ sq << 1
+ end
+
+ t2 = Thread.new do
+ sq << 1
+ end
+
+ t3 = Thread.new do
+ Thread.pass
+ sq.clear
+ end
+
+ [t3, t2, t1].each(&:join)
+ assert_equal sq.length, 2
+ end
+
+ def test_sized_queue_throttle
+ q = SizedQueue.new(1)
+ i = 0
+ consumer = Thread.new do
+ while q.pop
+ i += 1
+ Thread.pass
+ end
+ end
+ nprod = 4
+ npush = 100
+
+ producer = nprod.times.map do
+ Thread.new do
+ npush.times { q.push(true) }
+ end
+ end
+ producer.each(&:join)
+ q.push(nil)
+ consumer.join
+ assert_equal(nprod * npush, i)
+ end
+
+ def test_queue_thread_raise
+ q = Queue.new
+ th1 = Thread.new do
+ begin
+ q.pop
+ rescue RuntimeError
+ sleep
+ end
+ end
+ th2 = Thread.new do
+ sleep 0.1
+ q.pop
+ end
+ sleep 0.1
+ th1.raise
+ sleep 0.1
+ q << :s
+ assert_nothing_raised(TimeoutError) do
+ timeout(1) { th2.join }
+ end
+ end
end
diff --git a/version.h b/version.h
index d4fab20cc6..5a83708e7b 100644
--- a/version.h
+++ b/version.h
@@ -1,6 +1,6 @@
#define RUBY_VERSION "2.0.0"
#define RUBY_RELEASE_DATE "2014-02-10"
-#define RUBY_PATCHLEVEL 398
+#define RUBY_PATCHLEVEL 399
#define RUBY_RELEASE_YEAR 2014
#define RUBY_RELEASE_MONTH 2