/* * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #include "rtc_base/swap_queue.h" #include #include #include "test/gtest.h" namespace webrtc { namespace { // Test parameter for the basic sample based SwapQueue Tests. const size_t kChunkSize = 3; // Queue item verification function for the vector test. bool LengthVerifierFunction(const std::vector& v) { return v.size() == kChunkSize; } // Queue item verifier for the vector test. class LengthVerifierFunctor { public: explicit LengthVerifierFunctor(size_t length) : length_(length) {} bool operator()(const std::vector& v) const { return v.size() == length_; } private: size_t length_; }; } // anonymous namespace TEST(SwapQueueTest, BasicOperation) { std::vector i(kChunkSize, 0); SwapQueue> queue(2, i); EXPECT_TRUE(queue.Insert(&i)); EXPECT_EQ(i.size(), kChunkSize); EXPECT_TRUE(queue.Insert(&i)); EXPECT_EQ(i.size(), kChunkSize); EXPECT_TRUE(queue.Remove(&i)); EXPECT_EQ(i.size(), kChunkSize); EXPECT_TRUE(queue.Remove(&i)); EXPECT_EQ(i.size(), kChunkSize); } TEST(SwapQueueTest, FullQueue) { SwapQueue queue(2); // Fill the queue. int i = 0; EXPECT_TRUE(queue.Insert(&i)); i = 1; EXPECT_TRUE(queue.Insert(&i)); // Ensure that the value is not swapped when doing an Insert // on a full queue. i = 2; EXPECT_FALSE(queue.Insert(&i)); EXPECT_EQ(i, 2); // Ensure that the Insert didn't overwrite anything in the queue. EXPECT_TRUE(queue.Remove(&i)); EXPECT_EQ(i, 0); EXPECT_TRUE(queue.Remove(&i)); EXPECT_EQ(i, 1); } TEST(SwapQueueTest, EmptyQueue) { SwapQueue queue(2); int i = 0; EXPECT_FALSE(queue.Remove(&i)); EXPECT_TRUE(queue.Insert(&i)); EXPECT_TRUE(queue.Remove(&i)); EXPECT_FALSE(queue.Remove(&i)); } TEST(SwapQueueTest, Clear) { SwapQueue queue(2); int i = 0; // Fill the queue. EXPECT_TRUE(queue.Insert(&i)); EXPECT_TRUE(queue.Insert(&i)); // Ensure full queue. EXPECT_FALSE(queue.Insert(&i)); // Empty the queue. queue.Clear(); // Ensure that the queue is empty EXPECT_FALSE(queue.Remove(&i)); // Ensure that the queue is no longer full. EXPECT_TRUE(queue.Insert(&i)); } TEST(SwapQueueTest, SuccessfulItemVerifyFunction) { std::vector template_element(kChunkSize); SwapQueue, SwapQueueItemVerifier, LengthVerifierFunction>> queue(2, template_element); std::vector valid_chunk(kChunkSize, 0); EXPECT_TRUE(queue.Insert(&valid_chunk)); EXPECT_EQ(valid_chunk.size(), kChunkSize); EXPECT_TRUE(queue.Remove(&valid_chunk)); EXPECT_EQ(valid_chunk.size(), kChunkSize); } TEST(SwapQueueTest, SuccessfulItemVerifyFunctor) { std::vector template_element(kChunkSize); LengthVerifierFunctor verifier(kChunkSize); SwapQueue, LengthVerifierFunctor> queue(2, template_element, verifier); std::vector valid_chunk(kChunkSize, 0); EXPECT_TRUE(queue.Insert(&valid_chunk)); EXPECT_EQ(valid_chunk.size(), kChunkSize); EXPECT_TRUE(queue.Remove(&valid_chunk)); EXPECT_EQ(valid_chunk.size(), kChunkSize); } #if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID) TEST(SwapQueueDeathTest, UnsuccessfulItemVerifyFunctor) { // Queue item verifier for the test. auto minus_2_verifier = [](const int& i) { return i > -2; }; SwapQueue queue(2, minus_2_verifier); int valid_value = 1; int invalid_value = -4; EXPECT_TRUE(queue.Insert(&valid_value)); EXPECT_TRUE(queue.Remove(&valid_value)); EXPECT_DEATH((void)queue.Insert(&invalid_value), ""); } TEST(SwapQueueDeathTest, UnSuccessfulItemVerifyInsert) { std::vector template_element(kChunkSize); SwapQueue, SwapQueueItemVerifier, &LengthVerifierFunction>> queue(2, template_element); std::vector invalid_chunk(kChunkSize - 1, 0); EXPECT_DEATH((void)queue.Insert(&invalid_chunk), ""); } TEST(SwapQueueDeathTest, UnSuccessfulItemVerifyRemove) { std::vector template_element(kChunkSize); SwapQueue, SwapQueueItemVerifier, &LengthVerifierFunction>> queue(2, template_element); std::vector invalid_chunk(kChunkSize - 1, 0); std::vector valid_chunk(kChunkSize, 0); EXPECT_TRUE(queue.Insert(&valid_chunk)); EXPECT_EQ(valid_chunk.size(), kChunkSize); EXPECT_DEATH((void)queue.Remove(&invalid_chunk), ""); } #endif TEST(SwapQueueTest, VectorContentTest) { const size_t kQueueSize = 10; const size_t kFrameLength = 160; const size_t kDataLength = kQueueSize * kFrameLength; std::vector buffer_reader(kFrameLength, 0); std::vector buffer_writer(kFrameLength, 0); SwapQueue> queue(kQueueSize, std::vector(kFrameLength)); std::vector samples(kDataLength); for (size_t k = 0; k < kDataLength; k++) { samples[k] = k % 9; } for (size_t k = 0; k < kQueueSize; k++) { buffer_writer.clear(); buffer_writer.insert(buffer_writer.end(), &samples[0] + k * kFrameLength, &samples[0] + (k + 1) * kFrameLength); EXPECT_TRUE(queue.Insert(&buffer_writer)); } for (size_t k = 0; k < kQueueSize; k++) { EXPECT_TRUE(queue.Remove(&buffer_reader)); for (size_t j = 0; j < buffer_reader.size(); j++) { EXPECT_EQ(buffer_reader[j], samples[k * kFrameLength + j]); } } } TEST(SwapQueueTest, ZeroSlotQueue) { SwapQueue queue(0); int i = 42; EXPECT_FALSE(queue.Insert(&i)); EXPECT_FALSE(queue.Remove(&i)); EXPECT_EQ(i, 42); } TEST(SwapQueueTest, OneSlotQueue) { SwapQueue queue(1); int i = 42; EXPECT_TRUE(queue.Insert(&i)); i = 43; EXPECT_FALSE(queue.Insert(&i)); EXPECT_EQ(i, 43); EXPECT_TRUE(queue.Remove(&i)); EXPECT_EQ(i, 42); EXPECT_FALSE(queue.Remove(&i)); } } // namespace webrtc