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

Side by Side Diff: services/url_response_disk_cache/url_response_disk_cache_db_unittests.cc

Issue 1276073004: Offline By Default (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Follow review Created 5 years, 3 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
(Empty)
1 // Copyright 2015 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/files/scoped_temp_dir.h"
6 #include "base/threading/platform_thread.h"
7 #include "services/url_response_disk_cache/url_response_disk_cache_db.h"
8 #include "testing/gtest/include/gtest/gtest.h"
9
10 namespace mojo {
11
12 namespace {
13
14 class URLResponseDiskCacheDBTest : public ::testing::Test {
15 protected:
16 void SetUp() override {
17 ASSERT_TRUE(tmp_dir_.CreateUniqueTempDir());
18 Open();
19 }
20
21 void Open() {
22 db_ = nullptr;
23 base::FilePath db_path = tmp_dir_.path().Append("db");
24 db_ = new URLResponseDiskCacheDB(db_path);
25 }
26
27 CacheEntryPtr NewEntry() {
28 CacheEntryPtr entry = CacheEntry::New();
29 entry->response = URLResponse::New();
30 entry->cache_directory = "/cache";
31 entry->content_path = "/cache/content";
32 return entry.Pass();
33 }
34
35 base::ScopedTempDir tmp_dir_;
36 scoped_refptr<URLResponseDiskCacheDB> db_;
37 };
38
39 TEST_F(URLResponseDiskCacheDBTest, Create) {}
40
41 TEST_F(URLResponseDiskCacheDBTest, Version) {
42 EXPECT_EQ(0lu, db_->GetVersion());
43 db_->SetVersion(15);
44 EXPECT_EQ(15lu, db_->GetVersion());
45 }
46
47 TEST_F(URLResponseDiskCacheDBTest, Persist) {
48 db_->SetVersion(15);
49 EXPECT_EQ(15lu, db_->GetVersion());
50 Open();
51 EXPECT_EQ(15lu, db_->GetVersion());
52 }
53
54 TEST_F(URLResponseDiskCacheDBTest, Entry) {
55 std::string origin = "origin";
56 std::string url = "url";
57 db_->PutNewest(origin, url, NewEntry());
58 CacheEntryPtr entry = db_->GetNewest(origin, url);
59 EXPECT_TRUE(entry);
60 Open();
61 entry = db_->GetNewest(origin, url);
62 EXPECT_TRUE(entry);
63 }
64
65 TEST_F(URLResponseDiskCacheDBTest, Newest) {
66 std::string origin = "origin";
67 std::string url = "url";
68 std::string new_cache_directory = "/newcache/";
69 db_->PutNewest(origin, url, NewEntry());
70 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(5));
71 CacheEntryPtr entry = NewEntry();
72 entry->cache_directory = new_cache_directory;
73 db_->PutNewest(origin, url, entry.Pass());
74 entry = db_->GetNewest(origin, url);
75 EXPECT_TRUE(entry);
76 EXPECT_EQ(new_cache_directory, entry->cache_directory);
77 }
78
79 TEST_F(URLResponseDiskCacheDBTest, Iterator) {
ppi 2015/09/15 15:21:22 here we are putting the entries in the same order
qsr 2015/09/16 11:46:38 Done.
80 std::string origin = "origin";
81 std::string url = "url";
82 std::string url2 = "url2";
83 db_->PutNewest(origin, url, NewEntry());
84 CacheEntryPtr entry = db_->GetNewest(origin, url);
85 EXPECT_TRUE(entry);
86 db_->PutNewest(origin, url2, NewEntry());
87 entry = CacheEntry::New();
88 scoped_ptr<URLResponseDiskCacheDB::Iterator> iterator = db_->Iterate();
89 EXPECT_TRUE(iterator->HasNext());
90 CacheKeyPtr key;
91 iterator->GetNext(&key, &entry);
92 EXPECT_TRUE(iterator->HasNext());
93 EXPECT_TRUE(key);
94 EXPECT_EQ(url, key->url);
95 EXPECT_TRUE(entry);
96 iterator->GetNext(&key, &entry);
97 EXPECT_FALSE(iterator->HasNext());
98 EXPECT_TRUE(key);
99 EXPECT_EQ(url2, key->url);
100 EXPECT_TRUE(entry);
101 }
102
103 TEST_F(URLResponseDiskCacheDBTest, Delete) {
104 std::string origin = "origin";
105 std::string url = "url";
106 db_->PutNewest(origin, url, NewEntry());
107 CacheEntryPtr entry = db_->GetNewest(origin, url);
108 EXPECT_TRUE(entry);
109 entry = CacheEntry::New();
110 scoped_ptr<URLResponseDiskCacheDB::Iterator> iterator = db_->Iterate();
111 EXPECT_TRUE(iterator->HasNext());
112 CacheKeyPtr key;
113 iterator->GetNext(&key, &entry);
114 EXPECT_FALSE(iterator->HasNext());
115 EXPECT_TRUE(key);
116 EXPECT_TRUE(entry);
117 db_->Delete(key.Pass());
118 entry = db_->GetNewest(origin, url);
119 EXPECT_FALSE(entry);
120 }
121
122 TEST_F(URLResponseDiskCacheDBTest, IteratorFrozen) {
123 std::string origin = "origin";
124 std::string url = "url";
125 db_->PutNewest(origin, url, NewEntry());
126 scoped_ptr<URLResponseDiskCacheDB::Iterator> iterator = db_->Iterate();
127 std::string url2 = "url2";
128 db_->PutNewest(origin, url2, NewEntry());
129
130 EXPECT_TRUE(iterator->HasNext());
131 iterator->GetNext(nullptr, nullptr);
132 EXPECT_FALSE(iterator->HasNext());
133 }
134
135 } // namespace
136
137 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698