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

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

Issue 14263005: Refactor our SimpleIndex file format and serialization to use Pickle instead of the previously bugg… (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 8 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 | Annotate | Revision Log
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "base/hash.h"
6 #include "base/logging.h"
7 #include "base/memory/scoped_ptr.h"
8 #include "base/pickle.h"
9 #include "base/sha1.h"
10 #include "base/stringprintf.h"
11 #include "base/time.h"
12 #include "net/disk_cache/simple/simple_index.h"
13 #include "testing/gtest/include/gtest/gtest.h"
14
15 namespace {
gavinp 2013/04/16 11:22:13 blank line at beginning and end, and // namespace
felipeg 2013/04/16 11:25:35 Done.
Philippe 2013/04/16 11:58:47 I would make this anonymous namespace (and the res
16 const uint64 kTestHashKey = 4364515;
17 const int64 kTestLastUsedTimeInternal = 12345;
18 const base::Time kTestLastUsedTime =
19 base::Time::FromInternalValue(kTestLastUsedTimeInternal);
Philippe 2013/04/16 11:58:47 Note that this will generate a static initializer.
20 const uint64 kTestEntrySize = 789;
21 }
22
23 using disk_cache::EntryMetadata;
24
gavinp 2013/04/16 11:22:13 lose blank line
felipeg 2013/04/16 11:25:35 Done.
25
26 class EntryMetadataTest : public testing::Test {
Philippe 2013/04/16 11:58:47 Nit: extra space before ':'.
27 public:
28 EntryMetadata NewEntryMetadataWithValues() {
29 return EntryMetadata(kTestHashKey,
30 kTestLastUsedTime,
31 kTestEntrySize);
32 }
33
34 void CheckEntryMetadataValues(const EntryMetadata& entry_metadata) {
Philippe 2013/04/16 11:58:47 Nit: this should be static or const.
35 EXPECT_EQ(kTestLastUsedTime, entry_metadata.GetLastUsedTime());
36 EXPECT_EQ(kTestEntrySize, entry_metadata.GetEntrySize());
37 }
38 };
39
40 TEST_F(EntryMetadataTest, Basics) {
41 EntryMetadata entry_metadata;
42 EXPECT_EQ(base::Time::FromInternalValue(0), entry_metadata.GetLastUsedTime());
43 EXPECT_EQ(size_t(0), entry_metadata.GetEntrySize());
44
45 entry_metadata = NewEntryMetadataWithValues();
46 CheckEntryMetadataValues(entry_metadata);
47 EXPECT_EQ(kTestHashKey, entry_metadata.GetHashKey());
48
49 const base::Time new_time = base::Time::FromInternalValue(5);
50 entry_metadata.SetLastUsedTime(new_time);
51 EXPECT_EQ(new_time, entry_metadata.GetLastUsedTime());
52 }
53
54 TEST_F(EntryMetadataTest, Serialize) {
55 EntryMetadata entry_metadata = NewEntryMetadataWithValues();
56
57 Pickle pickle;
58 entry_metadata.Serialize(&pickle);
59
60 PickleIterator it(pickle);
61 EntryMetadata new_entry_metadata;
62 new_entry_metadata.Deserialize(&it);
63 CheckEntryMetadataValues(new_entry_metadata);
64 EXPECT_EQ(kTestHashKey, new_entry_metadata.GetHashKey());
65 }
66
67 TEST_F(EntryMetadataTest, Merge) {
68 EntryMetadata entry_metadata_a = NewEntryMetadataWithValues();
69 // MergeWith assumes the hash_key of both entries is the same, so we
70 // initialize it to be that way.
71 base::Time dummy_time = base::Time::FromInternalValue(0);
72 EntryMetadata entry_metadata_b(entry_metadata_a.GetHashKey(), dummy_time, 0);
73 entry_metadata_b.MergeWith(entry_metadata_a);
74 CheckEntryMetadataValues(entry_metadata_b);
75
76 EntryMetadata entry_metadata_c(entry_metadata_a.GetHashKey(), dummy_time, 0);
77 entry_metadata_a.MergeWith(entry_metadata_c);
78 CheckEntryMetadataValues(entry_metadata_a);
79
80 EntryMetadata entry_metadata_d(entry_metadata_a.GetHashKey(), dummy_time, 0);
81 const base::Time new_time = base::Time::FromInternalValue(5);
82 entry_metadata_d.SetLastUsedTime(new_time);
83 entry_metadata_d.MergeWith(entry_metadata_a);
84 EXPECT_EQ(entry_metadata_a.GetEntrySize(), entry_metadata_d.GetEntrySize());
85 EXPECT_EQ(new_time, entry_metadata_d.GetLastUsedTime());
86
87 EntryMetadata entry_metadata_e(entry_metadata_a.GetHashKey(), dummy_time, 0);
88 const uint64 entry_size = 9999999;
89 entry_metadata_e.SetEntrySize(entry_size);
90 entry_metadata_e.MergeWith(entry_metadata_a);
91 EXPECT_EQ(entry_size, entry_metadata_e.GetEntrySize());
92 EXPECT_EQ(entry_metadata_a.GetLastUsedTime(),
93 entry_metadata_e.GetLastUsedTime());
94 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698