#include // NOLINT #include "caffe2/utils/simple_queue.h" #include namespace caffe2 { static std::unique_ptr > gQueue; static void ConsumerFunction(int thread_idx) { int value; while (true) { if (!gQueue->Pop(&value)) return; VLOG(1) << "Emitting " << value << " from thread " << thread_idx; } } static void ProducerFunction(int thread_idx, int start, int count) { for (int i = 0; i < count; ++i) { VLOG(1) << "Pushing " << i + start << " from thread " << thread_idx; gQueue->Push(i + start); } } TEST(SimpleQueueTest, SingleProducerSingleConsumer) { gQueue.reset(new SimpleQueue()); std::thread consumer(ConsumerFunction, 0); for (int i = 0; i < 10; ++i) { gQueue->Push(i); } gQueue->NoMoreJobs(); consumer.join(); } TEST(SimpleQueueTest, SingleProducerDoubleConsumer) { gQueue.reset(new SimpleQueue()); std::thread consumer0(ConsumerFunction, 0); std::thread consumer1(ConsumerFunction, 1); for (int i = 0; i < 10; ++i) { gQueue->Push(i); } gQueue->NoMoreJobs(); consumer0.join(); consumer1.join(); } TEST(SimpleQueueTest, DoubleProducerDoubleConsumer) { gQueue.reset(new SimpleQueue()); std::thread producer0(ProducerFunction, 0, 0, 10); std::thread producer1(ProducerFunction, 0, 10, 10); std::thread consumer0(ConsumerFunction, 2); std::thread consumer1(ConsumerFunction, 3); producer0.join(); producer1.join(); gQueue->NoMoreJobs(); consumer0.join(); consumer1.join(); } TEST(SimpleQueueDeathTest, CannotAddAfterQueueFinished) { gQueue.reset(new SimpleQueue()); gQueue->Push(0); gQueue->NoMoreJobs(); ASSERT_THROW(gQueue->Push(0), EnforceNotMet); } } // namespace caffe2