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

Unified Diff: net/disk_cache/disk_cache_test_base.cc

Issue 127083002: **STILLBAKING** Decouple disk cache tests from backends. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: upstream rebase Created 6 years, 10 months 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/disk_cache_test_base.h ('k') | net/disk_cache/disk_cache_test_util.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/disk_cache/disk_cache_test_base.cc
diff --git a/net/disk_cache/disk_cache_test_base.cc b/net/disk_cache/disk_cache_test_base.cc
deleted file mode 100644
index 045765dd448778dd09bbd27e73ac1a7f74bfae27..0000000000000000000000000000000000000000
--- a/net/disk_cache/disk_cache_test_base.cc
+++ /dev/null
@@ -1,322 +0,0 @@
-// 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 "net/disk_cache/disk_cache_test_base.h"
-
-#include "base/file_util.h"
-#include "base/path_service.h"
-#include "base/run_loop.h"
-#include "base/threading/platform_thread.h"
-#include "net/base/io_buffer.h"
-#include "net/base/net_errors.h"
-#include "net/base/test_completion_callback.h"
-#include "net/disk_cache/blockfile/backend_impl.h"
-#include "net/disk_cache/cache_util.h"
-#include "net/disk_cache/disk_cache.h"
-#include "net/disk_cache/disk_cache_test_util.h"
-#include "net/disk_cache/memory/mem_backend_impl.h"
-#include "net/disk_cache/simple/simple_backend_impl.h"
-#include "net/disk_cache/simple/simple_index.h"
-
-DiskCacheTest::DiskCacheTest() {
- CHECK(temp_dir_.CreateUniqueTempDir());
- cache_path_ = temp_dir_.path();
- if (!base::MessageLoop::current())
- message_loop_.reset(new base::MessageLoopForIO());
-}
-
-DiskCacheTest::~DiskCacheTest() {
-}
-
-bool DiskCacheTest::CopyTestCache(const std::string& name) {
- base::FilePath path;
- PathService::Get(base::DIR_SOURCE_ROOT, &path);
- path = path.AppendASCII("net");
- path = path.AppendASCII("data");
- path = path.AppendASCII("cache_tests");
- path = path.AppendASCII(name);
-
- if (!CleanupCacheDir())
- return false;
- return base::CopyDirectory(path, cache_path_, false);
-}
-
-bool DiskCacheTest::CleanupCacheDir() {
- return DeleteCache(cache_path_);
-}
-
-void DiskCacheTest::TearDown() {
- base::RunLoop().RunUntilIdle();
-}
-
-DiskCacheTestWithCache::DiskCacheTestWithCache()
- : cache_impl_(NULL),
- simple_cache_impl_(NULL),
- mem_cache_(NULL),
- mask_(0),
- size_(0),
- type_(net::DISK_CACHE),
- memory_only_(false),
- simple_cache_mode_(false),
- simple_cache_wait_for_index_(true),
- force_creation_(false),
- new_eviction_(false),
- first_cleanup_(true),
- integrity_(true),
- use_current_thread_(false),
- cache_thread_("CacheThread") {
-}
-
-DiskCacheTestWithCache::~DiskCacheTestWithCache() {}
-
-void DiskCacheTestWithCache::InitCache() {
- if (memory_only_)
- InitMemoryCache();
- else
- InitDiskCache();
-
- ASSERT_TRUE(NULL != cache_);
- if (first_cleanup_)
- ASSERT_EQ(0, cache_->GetEntryCount());
-}
-
-// We are expected to leak memory when simulating crashes.
-void DiskCacheTestWithCache::SimulateCrash() {
- ASSERT_TRUE(!memory_only_);
- net::TestCompletionCallback cb;
- int rv = cache_impl_->FlushQueueForTest(cb.callback());
- ASSERT_EQ(net::OK, cb.GetResult(rv));
- cache_impl_->ClearRefCountForTest();
-
- cache_.reset();
- EXPECT_TRUE(CheckCacheIntegrity(cache_path_, new_eviction_, mask_));
-
- CreateBackend(disk_cache::kNoRandom, &cache_thread_);
-}
-
-void DiskCacheTestWithCache::SetTestMode() {
- ASSERT_TRUE(!memory_only_);
- cache_impl_->SetUnitTestMode();
-}
-
-void DiskCacheTestWithCache::SetMaxSize(int size) {
- size_ = size;
- if (simple_cache_impl_)
- EXPECT_TRUE(simple_cache_impl_->SetMaxSize(size));
-
- if (cache_impl_)
- EXPECT_TRUE(cache_impl_->SetMaxSize(size));
-
- if (mem_cache_)
- EXPECT_TRUE(mem_cache_->SetMaxSize(size));
-}
-
-int DiskCacheTestWithCache::OpenEntry(const std::string& key,
- disk_cache::Entry** entry) {
- net::TestCompletionCallback cb;
- int rv = cache_->OpenEntry(key, entry, cb.callback());
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::CreateEntry(const std::string& key,
- disk_cache::Entry** entry) {
- net::TestCompletionCallback cb;
- int rv = cache_->CreateEntry(key, entry, cb.callback());
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::DoomEntry(const std::string& key) {
- net::TestCompletionCallback cb;
- int rv = cache_->DoomEntry(key, cb.callback());
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::DoomAllEntries() {
- net::TestCompletionCallback cb;
- int rv = cache_->DoomAllEntries(cb.callback());
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::DoomEntriesBetween(const base::Time initial_time,
- const base::Time end_time) {
- net::TestCompletionCallback cb;
- int rv = cache_->DoomEntriesBetween(initial_time, end_time, cb.callback());
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::DoomEntriesSince(const base::Time initial_time) {
- net::TestCompletionCallback cb;
- int rv = cache_->DoomEntriesSince(initial_time, cb.callback());
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::OpenNextEntry(void** iter,
- disk_cache::Entry** next_entry) {
- net::TestCompletionCallback cb;
- int rv = cache_->OpenNextEntry(iter, next_entry, cb.callback());
- return cb.GetResult(rv);
-}
-
-void DiskCacheTestWithCache::FlushQueueForTest() {
- if (memory_only_ || !cache_impl_)
- return;
-
- net::TestCompletionCallback cb;
- int rv = cache_impl_->FlushQueueForTest(cb.callback());
- EXPECT_EQ(net::OK, cb.GetResult(rv));
-}
-
-void DiskCacheTestWithCache::RunTaskForTest(const base::Closure& closure) {
- if (memory_only_ || !cache_impl_) {
- closure.Run();
- return;
- }
-
- net::TestCompletionCallback cb;
- int rv = cache_impl_->RunTaskForTest(closure, cb.callback());
- EXPECT_EQ(net::OK, cb.GetResult(rv));
-}
-
-int DiskCacheTestWithCache::ReadData(disk_cache::Entry* entry, int index,
- int offset, net::IOBuffer* buf, int len) {
- net::TestCompletionCallback cb;
- int rv = entry->ReadData(index, offset, buf, len, cb.callback());
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::WriteData(disk_cache::Entry* entry, int index,
- int offset, net::IOBuffer* buf, int len,
- bool truncate) {
- net::TestCompletionCallback cb;
- int rv = entry->WriteData(index, offset, buf, len, cb.callback(), truncate);
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::ReadSparseData(disk_cache::Entry* entry,
- int64 offset, net::IOBuffer* buf,
- int len) {
- net::TestCompletionCallback cb;
- int rv = entry->ReadSparseData(offset, buf, len, cb.callback());
- return cb.GetResult(rv);
-}
-
-int DiskCacheTestWithCache::WriteSparseData(disk_cache::Entry* entry,
- int64 offset,
- net::IOBuffer* buf, int len) {
- net::TestCompletionCallback cb;
- int rv = entry->WriteSparseData(offset, buf, len, cb.callback());
- return cb.GetResult(rv);
-}
-
-void DiskCacheTestWithCache::TrimForTest(bool empty) {
- RunTaskForTest(base::Bind(&disk_cache::BackendImpl::TrimForTest,
- base::Unretained(cache_impl_),
- empty));
-}
-
-void DiskCacheTestWithCache::TrimDeletedListForTest(bool empty) {
- RunTaskForTest(base::Bind(&disk_cache::BackendImpl::TrimDeletedListForTest,
- base::Unretained(cache_impl_),
- empty));
-}
-
-void DiskCacheTestWithCache::AddDelay() {
- if (simple_cache_mode_) {
- // The simple cache uses second resolution for many timeouts, so it's safest
- // to advance by at least whole seconds before falling back into the normal
- // disk cache epsilon advance.
- const base::Time initial_time = base::Time::Now();
- do {
- base::PlatformThread::YieldCurrentThread();
- } while (base::Time::Now() -
- initial_time < base::TimeDelta::FromSeconds(1));
- }
-
- base::Time initial = base::Time::Now();
- while (base::Time::Now() <= initial) {
- base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(1));
- };
-}
-
-void DiskCacheTestWithCache::TearDown() {
- base::RunLoop().RunUntilIdle();
- disk_cache::SimpleBackendImpl::FlushWorkerPoolForTesting();
- base::RunLoop().RunUntilIdle();
- cache_.reset();
- if (cache_thread_.IsRunning())
- cache_thread_.Stop();
-
- if (!memory_only_ && !simple_cache_mode_ && integrity_) {
- EXPECT_TRUE(CheckCacheIntegrity(cache_path_, new_eviction_, mask_));
- }
- base::RunLoop().RunUntilIdle();
- disk_cache::SimpleBackendImpl::FlushWorkerPoolForTesting();
- DiskCacheTest::TearDown();
-}
-
-void DiskCacheTestWithCache::InitMemoryCache() {
- mem_cache_ = new disk_cache::MemBackendImpl(NULL);
- cache_.reset(mem_cache_);
- ASSERT_TRUE(cache_);
-
- if (size_)
- EXPECT_TRUE(mem_cache_->SetMaxSize(size_));
-
- ASSERT_TRUE(mem_cache_->Init());
-}
-
-void DiskCacheTestWithCache::InitDiskCache() {
- if (first_cleanup_)
- ASSERT_TRUE(CleanupCacheDir());
-
- if (!cache_thread_.IsRunning()) {
- ASSERT_TRUE(cache_thread_.StartWithOptions(
- base::Thread::Options(base::MessageLoop::TYPE_IO, 0)));
- }
- ASSERT_TRUE(cache_thread_.message_loop() != NULL);
-
- CreateBackend(disk_cache::kNoRandom, &cache_thread_);
-}
-
-void DiskCacheTestWithCache::CreateBackend(uint32 flags, base::Thread* thread) {
- base::MessageLoopProxy* runner;
- if (use_current_thread_)
- runner = base::MessageLoopProxy::current().get();
- else
- runner = thread->message_loop_proxy().get();
-
- if (simple_cache_mode_) {
- net::TestCompletionCallback cb;
- scoped_ptr<disk_cache::SimpleBackendImpl> simple_backend(
- new disk_cache::SimpleBackendImpl(
- cache_path_, size_, type_, make_scoped_refptr(runner).get(), NULL));
- int rv = simple_backend->Init(cb.callback());
- ASSERT_EQ(net::OK, cb.GetResult(rv));
- simple_cache_impl_ = simple_backend.get();
- cache_ = simple_backend.PassAs<disk_cache::Backend>();
- if (simple_cache_wait_for_index_) {
- net::TestCompletionCallback wait_for_index_cb;
- rv = simple_cache_impl_->index()->ExecuteWhenReady(
- wait_for_index_cb.callback());
- ASSERT_EQ(net::OK, wait_for_index_cb.GetResult(rv));
- }
- return;
- }
-
- if (mask_)
- cache_impl_ = new disk_cache::BackendImpl(cache_path_, mask_, runner, NULL);
- else
- cache_impl_ = new disk_cache::BackendImpl(cache_path_, runner, NULL);
- cache_.reset(cache_impl_);
- ASSERT_TRUE(cache_);
- if (size_)
- EXPECT_TRUE(cache_impl_->SetMaxSize(size_));
- if (new_eviction_)
- cache_impl_->SetNewEviction();
- cache_impl_->SetType(type_);
- cache_impl_->SetFlags(flags);
- net::TestCompletionCallback cb;
- int rv = cache_impl_->Init(cb.callback());
- ASSERT_EQ(net::OK, cb.GetResult(rv));
-}
« no previous file with comments | « net/disk_cache/disk_cache_test_base.h ('k') | net/disk_cache/disk_cache_test_util.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698