Index: net/spdy/spdy_read_queue_unittest.cc |
diff --git a/net/spdy/spdy_read_queue_unittest.cc b/net/spdy/spdy_read_queue_unittest.cc |
deleted file mode 100644 |
index a0a431c9f80ebf426d1773245c7d42fc0141e5a0..0000000000000000000000000000000000000000 |
--- a/net/spdy/spdy_read_queue_unittest.cc |
+++ /dev/null |
@@ -1,140 +0,0 @@ |
-// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
- |
-#include "net/spdy/spdy_read_queue.h" |
- |
-#include <algorithm> |
-#include <cstddef> |
-#include <memory> |
-#include <utility> |
- |
-#include "base/bind.h" |
-#include "base/memory/ptr_util.h" |
-#include "base/stl_util.h" |
-#include "net/spdy/platform/api/spdy_string.h" |
-#include "net/spdy/spdy_buffer.h" |
-#include "testing/gtest/include/gtest/gtest.h" |
- |
-namespace net { |
-namespace test { |
-namespace { |
- |
-const char kData[] = "SPDY read queue test data.\0Some more data."; |
-const size_t kDataSize = arraysize(kData); |
- |
-// Enqueues |data| onto |queue| in chunks of at most |max_buffer_size| |
-// bytes. |
-void EnqueueString(const SpdyString& data, |
- size_t max_buffer_size, |
- SpdyReadQueue* queue) { |
- ASSERT_GT(data.size(), 0u); |
- ASSERT_GT(max_buffer_size, 0u); |
- size_t old_total_size = queue->GetTotalSize(); |
- for (size_t i = 0; i < data.size();) { |
- size_t buffer_size = std::min(data.size() - i, max_buffer_size); |
- queue->Enqueue(std::unique_ptr<SpdyBuffer>( |
- new SpdyBuffer(data.data() + i, buffer_size))); |
- i += buffer_size; |
- EXPECT_FALSE(queue->IsEmpty()); |
- EXPECT_EQ(old_total_size + i, queue->GetTotalSize()); |
- } |
-} |
- |
-// Dequeues all bytes in |queue| in chunks of at most |
-// |max_buffer_size| bytes and returns the data as a string. |
-SpdyString DrainToString(size_t max_buffer_size, SpdyReadQueue* queue) { |
- SpdyString data; |
- |
- // Pad the buffer so we can detect out-of-bound writes. |
- size_t padding = std::max(static_cast<size_t>(4096), queue->GetTotalSize()); |
- size_t buffer_size_with_padding = padding + max_buffer_size + padding; |
- std::unique_ptr<char[]> buffer(new char[buffer_size_with_padding]); |
- std::memset(buffer.get(), 0, buffer_size_with_padding); |
- char* buffer_data = buffer.get() + padding; |
- |
- while (!queue->IsEmpty()) { |
- size_t old_total_size = queue->GetTotalSize(); |
- EXPECT_GT(old_total_size, 0u); |
- size_t dequeued_bytes = queue->Dequeue(buffer_data, max_buffer_size); |
- |
- // Make sure |queue| doesn't write past either end of its given |
- // boundaries. |
- for (int i = 1; i <= static_cast<int>(padding); ++i) { |
- EXPECT_EQ('\0', buffer_data[-i]) << -i; |
- } |
- for (size_t i = 0; i < padding; ++i) { |
- EXPECT_EQ('\0', buffer_data[max_buffer_size + i]) << i; |
- } |
- |
- data.append(buffer_data, dequeued_bytes); |
- EXPECT_EQ(dequeued_bytes, std::min(max_buffer_size, dequeued_bytes)); |
- EXPECT_EQ(queue->GetTotalSize(), old_total_size - dequeued_bytes); |
- } |
- EXPECT_TRUE(queue->IsEmpty()); |
- return data; |
-} |
- |
-// Enqueue a test string with the given enqueue/dequeue max buffer |
-// sizes. |
-void RunEnqueueDequeueTest(size_t enqueue_max_buffer_size, |
- size_t dequeue_max_buffer_size) { |
- SpdyString data(kData, kDataSize); |
- SpdyReadQueue read_queue; |
- EnqueueString(data, enqueue_max_buffer_size, &read_queue); |
- const SpdyString& drained_data = |
- DrainToString(dequeue_max_buffer_size, &read_queue); |
- EXPECT_EQ(data, drained_data); |
-} |
- |
-void OnBufferDiscarded(bool* discarded, |
- size_t* discarded_bytes, |
- size_t delta, |
- SpdyBuffer::ConsumeSource consume_source) { |
- EXPECT_EQ(SpdyBuffer::DISCARD, consume_source); |
- *discarded = true; |
- *discarded_bytes = delta; |
-} |
- |
-} // namespace |
- |
-class SpdyReadQueueTest : public ::testing::Test {}; |
- |
-// Call RunEnqueueDequeueTest() with various buffer size combinatinos. |
- |
-TEST_F(SpdyReadQueueTest, LargeEnqueueAndDequeueBuffers) { |
- RunEnqueueDequeueTest(2 * kDataSize, 2 * kDataSize); |
-} |
- |
-TEST_F(SpdyReadQueueTest, OneByteEnqueueAndDequeueBuffers) { |
- RunEnqueueDequeueTest(1, 1); |
-} |
- |
-TEST_F(SpdyReadQueueTest, CoprimeBufferSizes) { |
- RunEnqueueDequeueTest(2, 3); |
- RunEnqueueDequeueTest(3, 2); |
-} |
- |
-TEST_F(SpdyReadQueueTest, Clear) { |
- auto buffer = base::MakeUnique<SpdyBuffer>(kData, kDataSize); |
- bool discarded = false; |
- size_t discarded_bytes = 0; |
- buffer->AddConsumeCallback( |
- base::Bind(&OnBufferDiscarded, &discarded, &discarded_bytes)); |
- |
- SpdyReadQueue read_queue; |
- read_queue.Enqueue(std::move(buffer)); |
- |
- EXPECT_FALSE(discarded); |
- EXPECT_EQ(0u, discarded_bytes); |
- EXPECT_FALSE(read_queue.IsEmpty()); |
- |
- read_queue.Clear(); |
- |
- EXPECT_TRUE(discarded); |
- EXPECT_EQ(kDataSize, discarded_bytes); |
- EXPECT_TRUE(read_queue.IsEmpty()); |
-} |
- |
-} // namespace test |
-} // namespace net |