Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(620)

Unified Diff: net/disk_cache/flash/cache_entry_unittest.cc

Issue 11316178: Added CacheEntry implementation. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Added destructor for Stream struct. Created 8 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/disk_cache/flash/cache_entry.cc ('k') | net/disk_cache/flash/format.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/disk_cache/flash/cache_entry_unittest.cc
diff --git a/net/disk_cache/flash/cache_entry_unittest.cc b/net/disk_cache/flash/cache_entry_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..206f283c16ff5f8acfc9ab1edfb2451209f348a8
--- /dev/null
+++ b/net/disk_cache/flash/cache_entry_unittest.cc
@@ -0,0 +1,59 @@
+// Copyright (c) 2012 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 "base/memory/scoped_ptr.h"
+#include "net/base/io_buffer.h"
+#include "net/disk_cache/disk_cache_test_util.h"
+#include "net/disk_cache/flash/cache_entry.h"
+#include "net/disk_cache/flash/flash_cache_test_base.h"
+#include "net/disk_cache/flash/format.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+using disk_cache::CacheEntry;
+
+// Tests the behavior of a CacheEntry with empty streams.
+TEST_F(FlashCacheTest, CacheEntryEmpty) {
+ scoped_ptr<CacheEntry> entry(new CacheEntry(log_structured_store_.get()));
+ EXPECT_TRUE(entry->Init());
+ EXPECT_TRUE(entry->Close());
+
+ entry.reset(new CacheEntry(log_structured_store_.get(), entry->id()));
+ EXPECT_TRUE(entry->Init());
+
+ for (int i = 0; i < disk_cache::kFlashCacheEntryNumStreams; ++i) {
+ const int kSize = 1024;
+ scoped_refptr<net::IOBuffer> buf(new net::IOBuffer(kSize));
+ EXPECT_EQ(0, entry->GetDataSize(i));
+ EXPECT_EQ(0, entry->ReadData(i, 0, buf, kSize));
+ }
+ EXPECT_TRUE(entry->Close());
+}
+
+TEST_F(FlashCacheTest, CacheEntryWriteRead) {
+ scoped_ptr<CacheEntry> entry(new CacheEntry(log_structured_store_.get()));
+ EXPECT_TRUE(entry->Init());
+
+ int sizes[disk_cache::kFlashCacheEntryNumStreams] = {333, 444, 555, 666};
+ scoped_refptr<net::IOBuffer> buffers[disk_cache::kFlashCacheEntryNumStreams];
+
+ for (int i = 0; i < disk_cache::kFlashCacheEntryNumStreams; ++i) {
+ buffers[i] = new net::IOBuffer(sizes[i]);
+ CacheTestFillBuffer(buffers[i]->data(), sizes[i], false);
+ EXPECT_EQ(sizes[i], entry->WriteData(i, 0, buffers[i], sizes[i]));
+ }
+ EXPECT_TRUE(entry->Close());
+
+ int32 id = entry->id();
+ entry.reset(new CacheEntry(log_structured_store_.get(), id));
+ EXPECT_TRUE(entry->Init());
+
+ for (int i = 0; i < disk_cache::kFlashCacheEntryNumStreams; ++i) {
+ EXPECT_EQ(sizes[i], entry->GetDataSize(i));
+ scoped_refptr<net::IOBuffer> buffer(new net::IOBuffer(sizes[i]));
+ EXPECT_EQ(sizes[i], entry->ReadData(i, 0, buffer, sizes[i]));
+ EXPECT_EQ(0, memcmp(buffers[i]->data(), buffer->data(), sizes[i]));
+ }
+ EXPECT_TRUE(entry->Close());
+ EXPECT_EQ(id, entry->id());
+}
« no previous file with comments | « net/disk_cache/flash/cache_entry.cc ('k') | net/disk_cache/flash/format.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698