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

Side by Side Diff: net/disk_cache/simple/simple_index_unittest.cc

Issue 14746019: net/disk_cache/simple: Reduce size of EntrySet nodes. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: remove comment Created 7 years, 7 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/file_util.h" 5 #include "base/file_util.h"
6 #include "base/files/scoped_temp_dir.h" 6 #include "base/files/scoped_temp_dir.h"
7 #include "base/hash.h" 7 #include "base/hash.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "base/pickle.h" 10 #include "base/pickle.h"
11 #include "base/sha1.h" 11 #include "base/sha1.h"
12 #include "base/stringprintf.h" 12 #include "base/stringprintf.h"
13 #include "base/threading/platform_thread.h" 13 #include "base/threading/platform_thread.h"
14 #include "base/time.h" 14 #include "base/time.h"
15 #include "net/disk_cache/simple/simple_index.h" 15 #include "net/disk_cache/simple/simple_index.h"
16 #include "net/disk_cache/simple/simple_util.h" 16 #include "net/disk_cache/simple/simple_util.h"
17 #include "testing/gtest/include/gtest/gtest.h" 17 #include "testing/gtest/include/gtest/gtest.h"
18 18
19 namespace { 19 namespace {
20 20
21 const uint64 kTestHashKey = 4364515;
22 const int64 kTestLastUsedTimeInternal = 12345; 21 const int64 kTestLastUsedTimeInternal = 12345;
23 const base::Time kTestLastUsedTime = 22 const base::Time kTestLastUsedTime =
24 base::Time::FromInternalValue(kTestLastUsedTimeInternal); 23 base::Time::FromInternalValue(kTestLastUsedTimeInternal);
25 const uint64 kTestEntrySize = 789; 24 const uint64 kTestEntrySize = 789;
26 25
27 } // namespace 26 } // namespace
28 27
29 namespace disk_cache { 28 namespace disk_cache {
30 29
31 class EntryMetadataTest : public testing::Test { 30 class EntryMetadataTest : public testing::Test {
32 public: 31 public:
33 EntryMetadata NewEntryMetadataWithValues() { 32 EntryMetadata NewEntryMetadataWithValues() {
34 return EntryMetadata(kTestHashKey, 33 return EntryMetadata(kTestLastUsedTime, kTestEntrySize);
35 kTestLastUsedTime,
36 kTestEntrySize);
37 } 34 }
38 35
39 void CheckEntryMetadataValues(const EntryMetadata& entry_metadata) { 36 void CheckEntryMetadataValues(const EntryMetadata& entry_metadata) {
40 EXPECT_EQ(kTestLastUsedTime, entry_metadata.GetLastUsedTime()); 37 EXPECT_EQ(kTestLastUsedTime, entry_metadata.GetLastUsedTime());
41 EXPECT_EQ(kTestEntrySize, entry_metadata.GetEntrySize()); 38 EXPECT_EQ(kTestEntrySize, entry_metadata.GetEntrySize());
42 } 39 }
43 }; 40 };
44 41
45 TEST_F(EntryMetadataTest, Basics) { 42 TEST_F(EntryMetadataTest, Basics) {
46 EntryMetadata entry_metadata; 43 EntryMetadata entry_metadata;
47 EXPECT_EQ(base::Time::FromInternalValue(0), entry_metadata.GetLastUsedTime()); 44 EXPECT_EQ(base::Time::FromInternalValue(0), entry_metadata.GetLastUsedTime());
48 EXPECT_EQ(size_t(0), entry_metadata.GetEntrySize()); 45 EXPECT_EQ(size_t(0), entry_metadata.GetEntrySize());
49 46
50 entry_metadata = NewEntryMetadataWithValues(); 47 entry_metadata = NewEntryMetadataWithValues();
51 CheckEntryMetadataValues(entry_metadata); 48 CheckEntryMetadataValues(entry_metadata);
52 EXPECT_EQ(kTestHashKey, entry_metadata.GetHashKey());
53 49
54 const base::Time new_time = base::Time::FromInternalValue(5); 50 const base::Time new_time = base::Time::FromInternalValue(5);
55 entry_metadata.SetLastUsedTime(new_time); 51 entry_metadata.SetLastUsedTime(new_time);
56 EXPECT_EQ(new_time, entry_metadata.GetLastUsedTime()); 52 EXPECT_EQ(new_time, entry_metadata.GetLastUsedTime());
57 } 53 }
58 54
59 TEST_F(EntryMetadataTest, Serialize) { 55 TEST_F(EntryMetadataTest, Serialize) {
60 EntryMetadata entry_metadata = NewEntryMetadataWithValues(); 56 EntryMetadata entry_metadata = NewEntryMetadataWithValues();
61 57
62 Pickle pickle; 58 Pickle pickle;
63 entry_metadata.Serialize(&pickle); 59 entry_metadata.Serialize(&pickle);
64 60
65 PickleIterator it(pickle); 61 PickleIterator it(pickle);
66 EntryMetadata new_entry_metadata; 62 EntryMetadata new_entry_metadata;
67 new_entry_metadata.Deserialize(&it); 63 new_entry_metadata.Deserialize(&it);
68 CheckEntryMetadataValues(new_entry_metadata); 64 CheckEntryMetadataValues(new_entry_metadata);
69 EXPECT_EQ(kTestHashKey, new_entry_metadata.GetHashKey());
70 } 65 }
71 66
72 TEST_F(EntryMetadataTest, Merge) { 67 TEST_F(EntryMetadataTest, Merge) {
73 EntryMetadata entry_metadata_a = NewEntryMetadataWithValues(); 68 EntryMetadata entry_metadata_a = NewEntryMetadataWithValues();
74 // MergeWith assumes the hash_key of both entries is the same, so we 69 // MergeWith assumes the hash_key of both entries is the same, so we
75 // initialize it to be that way. 70 // initialize it to be that way.
76 base::Time dummy_time = base::Time::FromInternalValue(0); 71 base::Time dummy_time = base::Time::FromInternalValue(0);
77 EntryMetadata entry_metadata_b(entry_metadata_a.GetHashKey(), dummy_time, 0); 72 EntryMetadata entry_metadata_b(dummy_time, 0);
78 entry_metadata_b.MergeWith(entry_metadata_a); 73 entry_metadata_b.MergeWith(entry_metadata_a);
79 CheckEntryMetadataValues(entry_metadata_b); 74 CheckEntryMetadataValues(entry_metadata_b);
80 75
81 EntryMetadata entry_metadata_c(entry_metadata_a.GetHashKey(), dummy_time, 0); 76 EntryMetadata entry_metadata_c(dummy_time, 0);
82 entry_metadata_a.MergeWith(entry_metadata_c); 77 entry_metadata_a.MergeWith(entry_metadata_c);
83 CheckEntryMetadataValues(entry_metadata_a); 78 CheckEntryMetadataValues(entry_metadata_a);
84 79
85 EntryMetadata entry_metadata_d(entry_metadata_a.GetHashKey(), dummy_time, 0); 80 EntryMetadata entry_metadata_d(dummy_time, 0);
86 const base::Time new_time = base::Time::FromInternalValue(5); 81 const base::Time new_time = base::Time::FromInternalValue(5);
87 entry_metadata_d.SetLastUsedTime(new_time); 82 entry_metadata_d.SetLastUsedTime(new_time);
88 entry_metadata_d.MergeWith(entry_metadata_a); 83 entry_metadata_d.MergeWith(entry_metadata_a);
89 EXPECT_EQ(entry_metadata_a.GetEntrySize(), entry_metadata_d.GetEntrySize()); 84 EXPECT_EQ(entry_metadata_a.GetEntrySize(), entry_metadata_d.GetEntrySize());
90 EXPECT_EQ(new_time, entry_metadata_d.GetLastUsedTime()); 85 EXPECT_EQ(new_time, entry_metadata_d.GetLastUsedTime());
91 86
92 EntryMetadata entry_metadata_e(entry_metadata_a.GetHashKey(), dummy_time, 0); 87 EntryMetadata entry_metadata_e(dummy_time, 0);
93 const uint64 entry_size = 9999999; 88 const uint64 entry_size = 9999999;
94 entry_metadata_e.SetEntrySize(entry_size); 89 entry_metadata_e.SetEntrySize(entry_size);
95 entry_metadata_e.MergeWith(entry_metadata_a); 90 entry_metadata_e.MergeWith(entry_metadata_a);
96 EXPECT_EQ(entry_size, entry_metadata_e.GetEntrySize()); 91 EXPECT_EQ(entry_size, entry_metadata_e.GetEntrySize());
97 EXPECT_EQ(entry_metadata_a.GetLastUsedTime(), 92 EXPECT_EQ(entry_metadata_a.GetLastUsedTime(),
98 entry_metadata_e.GetLastUsedTime()); 93 entry_metadata_e.GetLastUsedTime());
99 } 94 }
100 95
101 class SimpleIndexTest : public testing::Test { 96 class SimpleIndexTest : public testing::Test {
102 }; 97 };
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
144 index.UpdateEntrySize("seven", 7); 139 index.UpdateEntrySize("seven", 7);
145 EXPECT_EQ(14U, index.cache_size_); 140 EXPECT_EQ(14U, index.cache_size_);
146 { 141 {
147 scoped_ptr<EntrySet> entries(new EntrySet()); 142 scoped_ptr<EntrySet> entries(new EntrySet());
148 index.MergeInitializingSet(entries.Pass(), false); 143 index.MergeInitializingSet(entries.Pass(), false);
149 } 144 }
150 EXPECT_EQ(14U, index.cache_size_); 145 EXPECT_EQ(14U, index.cache_size_);
151 { 146 {
152 scoped_ptr<EntrySet> entries(new EntrySet()); 147 scoped_ptr<EntrySet> entries(new EntrySet());
153 const uint64 hash_key = simple_util::GetEntryHashKey("eleven"); 148 const uint64 hash_key = simple_util::GetEntryHashKey("eleven");
154 entries->insert(std::make_pair(hash_key, EntryMetadata(hash_key, 149 entries->insert(
155 base::Time::Now(), 150 std::make_pair(hash_key, EntryMetadata(base::Time::Now(), 11)));
156 11)));
157 index.MergeInitializingSet(entries.Pass(), false); 151 index.MergeInitializingSet(entries.Pass(), false);
158 } 152 }
159 EXPECT_EQ(25U, index.cache_size_); 153 EXPECT_EQ(25U, index.cache_size_);
160 } 154 }
161 155
162 } // namespace disk_cache 156 } // namespace disk_cache
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698