blob: db6af64963a74a9707e34daa216b1685fc36e5db (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
// Copyright (c) 2006-2008 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 "net/disk_cache/backend_impl.h"
#include "net/disk_cache/disk_cache_test_util.h"
#include "net/disk_cache/mem_backend_impl.h"
void DiskCacheTest::TearDown() {
MessageLoop::current()->RunAllPending();
}
void DiskCacheTestWithCache::SetMaxSize(int size) {
size_ = size;
if (cache_impl_)
EXPECT_TRUE(cache_impl_->SetMaxSize(size));
if (mem_cache_)
EXPECT_TRUE(mem_cache_->SetMaxSize(size));
}
void DiskCacheTestWithCache::InitCache() {
if (mask_ || new_eviction_)
implementation_ = true;
if (memory_only_)
InitMemoryCache();
else
InitDiskCache();
ASSERT_TRUE(NULL != cache_);
if (first_cleanup_)
ASSERT_EQ(0, cache_->GetEntryCount());
}
void DiskCacheTestWithCache::InitMemoryCache() {
if (!implementation_) {
cache_ = disk_cache::CreateInMemoryCacheBackend(size_);
return;
}
mem_cache_ = new disk_cache::MemBackendImpl();
cache_ = mem_cache_;
ASSERT_TRUE(NULL != cache_);
if (size_)
EXPECT_TRUE(mem_cache_->SetMaxSize(size_));
ASSERT_TRUE(mem_cache_->Init());
}
void DiskCacheTestWithCache::InitDiskCache() {
std::wstring path = GetCachePath();
if (first_cleanup_)
ASSERT_TRUE(DeleteCache(path.c_str()));
if (!implementation_) {
cache_ = disk_cache::CreateCacheBackend(path, force_creation_, size_,
net::DISK_CACHE);
disk_cache::BackendImpl* impl =
static_cast<disk_cache::BackendImpl*>(cache_);
if (impl)
impl->SetFlags(disk_cache::kNoRandom);
return;
}
InitDiskCacheImpl(path);
}
void DiskCacheTestWithCache::InitDiskCacheImpl(const std::wstring& path) {
if (mask_)
cache_impl_ = new disk_cache::BackendImpl(path, mask_);
else
cache_impl_ = new disk_cache::BackendImpl(path);
cache_ = cache_impl_;
ASSERT_TRUE(NULL != cache_);
if (size_)
EXPECT_TRUE(cache_impl_->SetMaxSize(size_));
if (new_eviction_)
cache_impl_->SetNewEviction();
cache_impl_->SetFlags(disk_cache::kNoRandom);
ASSERT_TRUE(cache_impl_->Init());
}
void DiskCacheTestWithCache::TearDown() {
MessageLoop::current()->RunAllPending();
delete cache_;
if (!memory_only_ && integrity_) {
std::wstring path = GetCachePath();
EXPECT_TRUE(CheckCacheIntegrity(path, new_eviction_));
}
PlatformTest::TearDown();
}
// We are expected to leak memory when simulating crashes.
void DiskCacheTestWithCache::SimulateCrash() {
ASSERT_TRUE(implementation_ && !memory_only_);
cache_impl_->ClearRefCountForTest();
delete cache_impl_;
std::wstring path = GetCachePath();
EXPECT_TRUE(CheckCacheIntegrity(path, new_eviction_));
InitDiskCacheImpl(path);
}
void DiskCacheTestWithCache::SetTestMode() {
ASSERT_TRUE(implementation_ && !memory_only_);
cache_impl_->SetUnitTestMode();
}
|