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

Side by Side Diff: chrome/browser/chromeos/gdata/gdata_db_unittest.cc

Issue 10168025: GDataDB support with leveldb. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: minor Created 8 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
Property Changes:
Added: svn:eol-style
+ LF
OLDNEW
(Empty)
1 // Copyright (c) 2012 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 "chrome/browser/chromeos/gdata/gdata_db.h"
6
7 #include "base/string_number_conversions.h"
8 #include "chrome/browser/chromeos/gdata/gdata_db_factory.h"
9 #include "chrome/browser/chromeos/gdata/gdata_files.h"
10 #include "testing/gtest/include/gtest/gtest.h"
11 #include "chrome/test/base/testing_profile.h"
12
13 namespace gdata {
14 namespace {
15
16 class GDataDBTest : public testing::Test {
17 public:
18 GDataDBTest() : index_(0) {
19 }
20
21 virtual ~GDataDBTest() {
22 }
23
24 protected:
25 // testing::Test implementation.
26 virtual void SetUp() OVERRIDE;
27
28 // Tests GDataDB::GetPath and GDataDB::ResourceId, ensuring that an entry
29 // matching |source| does not exist.
30 void TestGetNotFound(const GDataEntry& source);
31
32 // Tests GDataDB::GetPath and GDataDB::ResourceId, ensuring that an entry
33 // matching |source| exists.
34 void TestGetFound(const GDataEntry& source);
35
36 // Initialize the database with the following entries:
37 // dir1
38 // dir2
39 // dir1/dir3
40 // dir1/file4
41 // dir1/file5
42 // dir2/file6
43 // dir2/file7
44 // dir2/file8
45 // dir1/dir3/file9
46 // dir1/dir3/file10
47 void InitDB();
48
49 // Helper functions to add a directory/file, incrementing index.
50 GDataDirectory* AddDir(GDataDirectory* parent);
satorux1 2012/04/24 20:25:15 nit: AddDirectory
achuithb 2012/04/24 21:36:25 Done.
51 GDataFile* AddFile(GDataDirectory* parent);
52
53 // Tests GDataDB::NewIterator and GDataDBIter::GetNext.
54 // Creates an iterator with start at |parent|, and iterates comparing with
55 // expected |filenames|.
56 void TestIter(const std::string& parent,
57 const char* file_paths[],
58 uint32 file_paths_size);
59
60 int index_;
satorux1 2012/04/24 20:25:15 maybe sequence_id_? index_ sounded like an index o
achuithb 2012/04/24 21:36:25 Done.
61 scoped_ptr<TestingProfile> profile_;
62 scoped_ptr<GDataDB> gdata_db_;
63 GDataRootDirectory root_;
64 };
65
66 void GDataDBTest::SetUp() {
67 profile_.reset(new TestingProfile());
68 gdata_db_ = db_factory::CreateGDataDB(
69 profile_->GetPath().Append("testdb"));
70 }
71
72 void GDataDBTest::TestGetNotFound(const GDataEntry& source) {
73 scoped_ptr<GDataEntry> entry;
74 GDataDB::Status status = gdata_db_->GetByPath(source.GetFilePath(), &entry);
75 EXPECT_EQ(GDataDB::DB_NOT_FOUND, status);
76 EXPECT_FALSE(entry.get());
77
78 status = gdata_db_->GetByResourceId(source.resource_id(), &entry);
79 EXPECT_EQ(GDataDB::DB_NOT_FOUND, status);
80 EXPECT_FALSE(entry.get());
81 }
82
83 void GDataDBTest::TestGetFound(const GDataEntry& source) {
84 scoped_ptr<GDataEntry> entry;
85 GDataDB::Status status = gdata_db_->GetByPath(source.GetFilePath(), &entry);
86 EXPECT_EQ(GDataDB::DB_OK, status);
87 ASSERT_TRUE(entry.get());
88 EXPECT_EQ(source.file_name(), entry->file_name());
89 EXPECT_EQ(source.resource_id(), entry->resource_id());
90 EXPECT_EQ(source.content_url(), entry->content_url());
91 entry.reset();
92
93 status = gdata_db_->GetByResourceId(source.resource_id(), &entry);
94 EXPECT_EQ(GDataDB::DB_OK, status);
95 ASSERT_TRUE(entry.get());
96 EXPECT_EQ(source.file_name(), entry->file_name());
97 EXPECT_EQ(source.resource_id(), entry->resource_id());
98 EXPECT_EQ(source.content_url(), entry->content_url());
99 }
100
101 void GDataDBTest::InitDB() {
102 index_ = 1;
103 GDataDirectory* dir1 = AddDir(NULL);
104 GDataDirectory* dir2 = AddDir(NULL);
105 GDataDirectory* dir3 = AddDir(dir1);
106
107 AddFile(dir1);
108 AddFile(dir1);
109
110 AddFile(dir2);
111 AddFile(dir2);
112 AddFile(dir2);
113
114 AddFile(dir3);
115 AddFile(dir3);
116 }
117
118 GDataDirectory* GDataDBTest::AddDir(GDataDirectory* parent) {
119 GDataDirectory* dir = new GDataDirectory(parent ? parent : &root_, &root_);
120 const std::string dir_name = "dir" + base::IntToString(index_++);
121 const std::string resource_id = std::string("dir_resource_id:") +
122 dir_name;
123 dir->set_file_name(dir_name);
124 dir->set_resource_id(resource_id);
125 GDataDB::Status status = gdata_db_->Put(*dir);
126 EXPECT_EQ(GDataDB::DB_OK, status);
127 DVLOG(1) << "AddDir " << dir->GetFilePath().value()
128 << ", " << resource_id;
129 return dir;
130 }
131
132 GDataFile* GDataDBTest::AddFile(GDataDirectory* parent) {
133 GDataFile* file = new GDataFile(parent, &root_);
134 const std::string file_name = "file" + base::IntToString(index_++);
135 const std::string resource_id = std::string("file_resource_id:") +
136 file_name;
137 file->set_file_name(file_name);
138 file->set_resource_id(resource_id);
139 GDataDB::Status status = gdata_db_->Put(*file);
140 EXPECT_EQ(GDataDB::DB_OK, status);
141 DVLOG(1) << "AddFile " << file->GetFilePath().value()
142 << ", " << resource_id;
143 return file;
144 }
145
146 void GDataDBTest::TestIter(const std::string& parent,
147 const char* file_paths[],
148 uint32 file_paths_size) {
satorux1 2012/04/24 20:25:15 uint32 -> size_t
achuithb 2012/04/24 21:36:25 Done.
149 scoped_ptr<GDataDBIter> iter = gdata_db_->NewIterator(
150 FilePath::FromUTF8Unsafe(parent));
151 for (uint32 i = 0; true; ++i) {
satorux1 2012/04/24 20:25:15 size_t. you can omit true.
achuithb 2012/04/24 21:36:25 Done.
152 scoped_ptr<GDataEntry> entry = iter->GetNext();
153 if (!entry.get()) {
154 EXPECT_EQ(i, file_paths_size);
155 break;
156 }
157 ASSERT_LT(i, file_paths_size);
158 // TODO(achuith): Fix this to check for entire path.
satorux1 2012/04/24 20:25:15 can we fix this now? Maybe we can modify the iter
achuithb 2012/04/24 21:36:25 Done.
159 EXPECT_EQ(FilePath(file_paths[i]).BaseName().value(), entry->file_name());
160 DVLOG(1) << "Iter " << entry->GetFilePath().value();
161 }
162 }
163
164 } // namespace
165
166 TEST_F(GDataDBTest, PutTest) {
167 GDataDirectory* dir = new GDataDirectory(&root_, &root_);
168 dir->set_file_name("dir");
169 dir->set_resource_id("dir_resource_id");
170 dir->set_content_url(GURL("http://content/dir"));
171 dir->set_upload_url(GURL("http://upload/dir"));
172
173 TestGetNotFound(*dir);
174
175 GDataDB::Status status = gdata_db_->Put(*dir);
176 EXPECT_EQ(GDataDB::DB_OK, status);
177
178 TestGetFound(*dir);
179
180 scoped_ptr<GDataEntry> entry;
181 gdata_db_->GetByPath(dir->GetFilePath(), &entry);
182 EXPECT_EQ(dir->upload_url(), entry->AsGDataDirectory()->upload_url());
183 EXPECT_TRUE(entry->AsGDataDirectory()->file_info().is_directory);
184
185 status = gdata_db_->DeleteByPath(dir->GetFilePath());
186 EXPECT_EQ(GDataDB::DB_OK, status);
187
188 TestGetNotFound(*dir);
189
190 GDataFile* file = new GDataFile(dir, &root_);
191 file->set_file_name("file1");
192 file->set_resource_id("file1_resource_id");
193 file->set_content_url(GURL("http://content/dir1/file1"));
194 file->set_file_md5("file1_md5");
195
196 TestGetNotFound(*file);
197
198 status = gdata_db_->Put(*file);
199 EXPECT_EQ(GDataDB::DB_OK, status);
200
201 TestGetFound(*file);
202
203 gdata_db_->GetByPath(file->GetFilePath(), &entry);
204 EXPECT_EQ(file->file_md5(), entry->AsGDataFile()->file_md5());
205 EXPECT_FALSE(entry->AsGDataFile()->file_info().is_directory);
206
207 status = gdata_db_->DeleteByPath(file->GetFilePath());
208 EXPECT_EQ(GDataDB::DB_OK, status);
209
210 TestGetNotFound(*file);
211 }
212
213 TEST_F(GDataDBTest, IterTest) {
214 InitDB();
215
216 const char* dir1_children[] = {
217 "dir1",
218 "dir1/dir3",
219 "dir1/dir3/file10",
220 "dir1/dir3/file9",
221 "dir1/file4",
222 "dir1/file5",
223 };
224 TestIter("dir1", dir1_children, arraysize(dir1_children));
225
226 const char* dir2_children[] = {
227 "dir2",
228 "dir2/file6",
229 "dir2/file7",
230 "dir2/file8",
231 };
232 TestIter("dir2", dir2_children, arraysize(dir2_children));
233
234 const char* dir3_children[] = {
235 "dir1/dir3",
236 "dir1/dir3/file10",
237 "dir1/dir3/file9",
238 };
239 TestIter("dir1/dir3", dir3_children, arraysize(dir3_children));
240
241 const char* file10[] = {
242 "dir1/dir3/file10",
243 };
244 TestIter(file10[0], file10, arraysize(file10));
245
246 const char* all_entries[] = {
247 "dir1",
248 "dir1/dir3",
249 "dir1/dir3/file10",
250 "dir1/dir3/file9",
251 "dir1/file4",
252 "dir1/file5",
253 "dir2",
254 "dir2/file6",
255 "dir2/file7",
256 "dir2/file8",
257 };
258 TestIter("", all_entries, arraysize(all_entries));
259
260 TestIter("dir4", NULL, 0);
261 }
262
263 } // namespace gdata
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698