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

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

Issue 10151013: Clean up leaks in gdata_db_unittest.cc (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: remove suppressions 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
« no previous file with comments | « no previous file | tools/heapcheck/suppressions.txt » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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 "chrome/browser/chromeos/gdata/gdata_db.h" 5 #include "chrome/browser/chromeos/gdata/gdata_db.h"
6 6
7 #include "base/string_number_conversions.h" 7 #include "base/string_number_conversions.h"
8 #include "chrome/browser/chromeos/gdata/gdata_db_factory.h" 8 #include "chrome/browser/chromeos/gdata/gdata_db_factory.h"
9 #include "chrome/browser/chromeos/gdata/gdata_files.h" 9 #include "chrome/browser/chromeos/gdata/gdata_files.h"
10 #include "testing/gtest/include/gtest/gtest.h" 10 #include "testing/gtest/include/gtest/gtest.h"
(...skipping 29 matching lines...) Expand all
40 // dir1/file4 40 // dir1/file4
41 // dir1/file5 41 // dir1/file5
42 // dir2/file6 42 // dir2/file6
43 // dir2/file7 43 // dir2/file7
44 // dir2/file8 44 // dir2/file8
45 // dir1/dir3/file9 45 // dir1/dir3/file9
46 // dir1/dir3/file10 46 // dir1/dir3/file10
47 void InitDB(); 47 void InitDB();
48 48
49 // Helper functions to add a directory/file, incrementing index. 49 // Helper functions to add a directory/file, incrementing index.
50 GDataDirectory* AddDirectory(GDataDirectory* parent, int sequence_id); 50 GDataDirectory* AddDirectory(GDataDirectory* parent,
51 GDataFile* AddFile(GDataDirectory* parent, int sequence_id); 51 GDataRootDirectory* root, int sequence_id);
52 GDataFile* AddFile(GDataDirectory* parent,
53 GDataRootDirectory* root, int sequence_id);
52 54
53 // Tests GDataDB::NewIterator and GDataDBIter::GetNext. 55 // Tests GDataDB::NewIterator and GDataDBIter::GetNext.
54 // Creates an iterator with start at |parent|, and iterates comparing with 56 // Creates an iterator with start at |parent|, and iterates comparing with
55 // expected |filenames|. 57 // expected |filenames|.
56 void TestIter(const std::string& parent, 58 void TestIter(const std::string& parent,
57 const char* file_paths[], 59 const char* file_paths[],
58 size_t file_paths_size); 60 size_t file_paths_size);
59 61
60 scoped_ptr<TestingProfile> profile_; 62 scoped_ptr<TestingProfile> profile_;
61 scoped_ptr<GDataDB> gdata_db_; 63 scoped_ptr<GDataDB> gdata_db_;
62 GDataRootDirectory root_; 64 std::set<GDataEntry*> entry_set_;
63 }; 65 };
64 66
65 void GDataDBTest::SetUp() { 67 void GDataDBTest::SetUp() {
66 profile_.reset(new TestingProfile()); 68 profile_.reset(new TestingProfile());
67 gdata_db_ = db_factory::CreateGDataDB( 69 gdata_db_ = db_factory::CreateGDataDB(
68 profile_->GetPath().Append("testdb")); 70 profile_->GetPath().Append("testdb"));
69 } 71 }
70 72
71 void GDataDBTest::TestGetNotFound(const GDataEntry& source) { 73 void GDataDBTest::TestGetNotFound(const GDataEntry& source) {
72 scoped_ptr<GDataEntry> entry; 74 scoped_ptr<GDataEntry> entry;
(...skipping 19 matching lines...) Expand all
92 status = gdata_db_->GetByResourceId(source.resource_id(), &entry); 94 status = gdata_db_->GetByResourceId(source.resource_id(), &entry);
93 EXPECT_EQ(GDataDB::DB_OK, status); 95 EXPECT_EQ(GDataDB::DB_OK, status);
94 ASSERT_TRUE(entry.get()); 96 ASSERT_TRUE(entry.get());
95 EXPECT_EQ(source.file_name(), entry->file_name()); 97 EXPECT_EQ(source.file_name(), entry->file_name());
96 EXPECT_EQ(source.resource_id(), entry->resource_id()); 98 EXPECT_EQ(source.resource_id(), entry->resource_id());
97 EXPECT_EQ(source.content_url(), entry->content_url()); 99 EXPECT_EQ(source.content_url(), entry->content_url());
98 } 100 }
99 101
100 void GDataDBTest::InitDB() { 102 void GDataDBTest::InitDB() {
101 int sequence_id = 1; 103 int sequence_id = 1;
102 GDataDirectory* dir1 = AddDirectory(NULL, sequence_id++); 104 GDataRootDirectory root;
103 GDataDirectory* dir2 = AddDirectory(NULL, sequence_id++); 105 GDataDirectory* dir1 = AddDirectory(NULL, &root, sequence_id++);
104 GDataDirectory* dir3 = AddDirectory(dir1, sequence_id++); 106 GDataDirectory* dir2 = AddDirectory(NULL, &root, sequence_id++);
107 GDataDirectory* dir3 = AddDirectory(dir1, &root, sequence_id++);
105 108
106 AddFile(dir1, sequence_id++); 109 AddFile(dir1, &root, sequence_id++);
107 AddFile(dir1, sequence_id++); 110 AddFile(dir1, &root, sequence_id++);
108 111
109 AddFile(dir2, sequence_id++); 112 AddFile(dir2, &root, sequence_id++);
110 AddFile(dir2, sequence_id++); 113 AddFile(dir2, &root, sequence_id++);
111 AddFile(dir2, sequence_id++); 114 AddFile(dir2, &root, sequence_id++);
112 115
113 AddFile(dir3, sequence_id++); 116 AddFile(dir3, &root, sequence_id++);
114 AddFile(dir3, sequence_id++); 117 AddFile(dir3, &root, sequence_id++);
118
119 STLDeleteElements(&entry_set_);
115 } 120 }
116 121
117 GDataDirectory* GDataDBTest::AddDirectory(GDataDirectory* parent, 122 GDataDirectory* GDataDBTest::AddDirectory(GDataDirectory* parent,
123 GDataRootDirectory* root,
118 int sequence_id) { 124 int sequence_id) {
119 GDataDirectory* dir = new GDataDirectory(parent ? parent : &root_, &root_); 125 GDataDirectory* dir = new GDataDirectory(parent ? parent : root, root);
120 const std::string dir_name = "dir" + base::IntToString(sequence_id); 126 const std::string dir_name = "dir" + base::IntToString(sequence_id);
121 const std::string resource_id = std::string("dir_resource_id:") + 127 const std::string resource_id = std::string("dir_resource_id:") +
122 dir_name; 128 dir_name;
123 dir->set_file_name(dir_name); 129 dir->set_file_name(dir_name);
124 dir->set_resource_id(resource_id); 130 dir->set_resource_id(resource_id);
125 GDataDB::Status status = gdata_db_->Put(*dir); 131 GDataDB::Status status = gdata_db_->Put(*dir);
126 EXPECT_EQ(GDataDB::DB_OK, status); 132 EXPECT_EQ(GDataDB::DB_OK, status);
127 DVLOG(1) << "AddDirectory " << dir->GetFilePath().value() 133 DVLOG(1) << "AddDirectory " << dir->GetFilePath().value()
128 << ", " << resource_id; 134 << ", " << resource_id;
135 entry_set_.insert(dir);
129 return dir; 136 return dir;
130 } 137 }
131 138
132 GDataFile* GDataDBTest::AddFile(GDataDirectory* parent, 139 GDataFile* GDataDBTest::AddFile(GDataDirectory* parent,
140 GDataRootDirectory* root,
133 int sequence_id) { 141 int sequence_id) {
134 GDataFile* file = new GDataFile(parent, &root_); 142 GDataFile* file = new GDataFile(parent, root);
135 const std::string file_name = "file" + base::IntToString(sequence_id); 143 const std::string file_name = "file" + base::IntToString(sequence_id);
136 const std::string resource_id = std::string("file_resource_id:") + 144 const std::string resource_id = std::string("file_resource_id:") +
137 file_name; 145 file_name;
138 file->set_file_name(file_name); 146 file->set_file_name(file_name);
139 file->set_resource_id(resource_id); 147 file->set_resource_id(resource_id);
140 GDataDB::Status status = gdata_db_->Put(*file); 148 GDataDB::Status status = gdata_db_->Put(*file);
141 EXPECT_EQ(GDataDB::DB_OK, status); 149 EXPECT_EQ(GDataDB::DB_OK, status);
142 DVLOG(1) << "AddFile " << file->GetFilePath().value() 150 DVLOG(1) << "AddFile " << file->GetFilePath().value()
143 << ", " << resource_id; 151 << ", " << resource_id;
152 entry_set_.insert(file);
144 return file; 153 return file;
145 } 154 }
146 155
147 void GDataDBTest::TestIter(const std::string& parent, 156 void GDataDBTest::TestIter(const std::string& parent,
148 const char* file_paths[], 157 const char* file_paths[],
149 size_t file_paths_size) { 158 size_t file_paths_size) {
150 scoped_ptr<GDataDBIter> iter = gdata_db_->CreateIterator( 159 scoped_ptr<GDataDBIter> iter = gdata_db_->CreateIterator(
151 FilePath::FromUTF8Unsafe(parent)); 160 FilePath::FromUTF8Unsafe(parent));
152 for (size_t i = 0; ; ++i) { 161 for (size_t i = 0; ; ++i) {
153 scoped_ptr<GDataEntry> entry; 162 scoped_ptr<GDataEntry> entry;
154 std::string path; 163 std::string path;
155 if (!iter->GetNext(&path, &entry)) { 164 if (!iter->GetNext(&path, &entry)) {
156 EXPECT_EQ(i, file_paths_size); 165 EXPECT_EQ(i, file_paths_size);
157 break; 166 break;
158 } 167 }
159 ASSERT_LT(i, file_paths_size); 168 ASSERT_LT(i, file_paths_size);
160 // TODO(achuith): Also test entry->GetFilePath(). 169 // TODO(achuith): Also test entry->GetFilePath().
161 EXPECT_EQ(FilePath(file_paths[i]).BaseName().value(), entry->file_name()); 170 EXPECT_EQ(FilePath(file_paths[i]).BaseName().value(), entry->file_name());
162 EXPECT_EQ(file_paths[i], path); 171 EXPECT_EQ(file_paths[i], path);
163 DVLOG(1) << "Iter " << path; 172 DVLOG(1) << "Iter " << path;
164 } 173 }
165 } 174 }
166 175
167 } // namespace 176 } // namespace
168 177
169 TEST_F(GDataDBTest, PutTest) { 178 TEST_F(GDataDBTest, PutTest) {
170 GDataDirectory* dir = new GDataDirectory(&root_, &root_); 179 GDataRootDirectory root;
171 dir->set_file_name("dir"); 180 GDataDirectory dir(&root, &root);
172 dir->set_resource_id("dir_resource_id"); 181 dir.set_file_name("dir");
173 dir->set_content_url(GURL("http://content/dir")); 182 dir.set_resource_id("dir_resource_id");
174 dir->set_upload_url(GURL("http://upload/dir")); 183 dir.set_content_url(GURL("http://content/dir"));
184 dir.set_upload_url(GURL("http://upload/dir"));
175 185
176 TestGetNotFound(*dir); 186 TestGetNotFound(dir);
177 187
178 GDataDB::Status status = gdata_db_->Put(*dir); 188 GDataDB::Status status = gdata_db_->Put(dir);
179 EXPECT_EQ(GDataDB::DB_OK, status); 189 EXPECT_EQ(GDataDB::DB_OK, status);
180 190
181 TestGetFound(*dir); 191 TestGetFound(dir);
182 192
183 scoped_ptr<GDataEntry> entry; 193 scoped_ptr<GDataEntry> entry;
184 gdata_db_->GetByPath(dir->GetFilePath(), &entry); 194 gdata_db_->GetByPath(dir.GetFilePath(), &entry);
185 EXPECT_EQ(dir->upload_url(), entry->AsGDataDirectory()->upload_url()); 195 EXPECT_EQ(dir.upload_url(), entry->AsGDataDirectory()->upload_url());
186 EXPECT_TRUE(entry->AsGDataDirectory()->file_info().is_directory); 196 EXPECT_TRUE(entry->AsGDataDirectory()->file_info().is_directory);
187 197
188 status = gdata_db_->DeleteByPath(dir->GetFilePath()); 198 status = gdata_db_->DeleteByPath(dir.GetFilePath());
189 EXPECT_EQ(GDataDB::DB_OK, status); 199 EXPECT_EQ(GDataDB::DB_OK, status);
190 200
191 TestGetNotFound(*dir); 201 TestGetNotFound(dir);
192 202
193 GDataFile* file = new GDataFile(dir, &root_); 203 GDataFile file(&dir, &root);
194 file->set_file_name("file1"); 204 file.set_file_name("file");
195 file->set_resource_id("file1_resource_id"); 205 file.set_resource_id("file_resource_id");
196 file->set_content_url(GURL("http://content/dir1/file1")); 206 file.set_content_url(GURL("http://content/dir/file"));
197 file->set_file_md5("file1_md5"); 207 file.set_file_md5("file_md5");
198 208
199 TestGetNotFound(*file); 209 TestGetNotFound(file);
200 210
201 status = gdata_db_->Put(*file); 211 status = gdata_db_->Put(file);
202 EXPECT_EQ(GDataDB::DB_OK, status); 212 EXPECT_EQ(GDataDB::DB_OK, status);
203 213
204 TestGetFound(*file); 214 TestGetFound(file);
205 215
206 gdata_db_->GetByPath(file->GetFilePath(), &entry); 216 gdata_db_->GetByPath(file.GetFilePath(), &entry);
207 EXPECT_EQ(file->file_md5(), entry->AsGDataFile()->file_md5()); 217 EXPECT_EQ(file.file_md5(), entry->AsGDataFile()->file_md5());
208 EXPECT_FALSE(entry->AsGDataFile()->file_info().is_directory); 218 EXPECT_FALSE(entry->AsGDataFile()->file_info().is_directory);
209 219
210 status = gdata_db_->DeleteByPath(file->GetFilePath()); 220 status = gdata_db_->DeleteByPath(file.GetFilePath());
211 EXPECT_EQ(GDataDB::DB_OK, status); 221 EXPECT_EQ(GDataDB::DB_OK, status);
212 222
213 TestGetNotFound(*file); 223 TestGetNotFound(file);
214 } 224 }
215 225
216 TEST_F(GDataDBTest, IterTest) { 226 TEST_F(GDataDBTest, IterTest) {
217 InitDB(); 227 InitDB();
218 228
219 const char* dir1_children[] = { 229 const char* dir1_children[] = {
220 "dir1", 230 "dir1",
221 "dir1/dir3", 231 "dir1/dir3",
222 "dir1/dir3/file10", 232 "dir1/dir3/file10",
223 "dir1/dir3/file9", 233 "dir1/dir3/file9",
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after
257 "dir2/file6", 267 "dir2/file6",
258 "dir2/file7", 268 "dir2/file7",
259 "dir2/file8", 269 "dir2/file8",
260 }; 270 };
261 TestIter("", all_entries, arraysize(all_entries)); 271 TestIter("", all_entries, arraysize(all_entries));
262 272
263 TestIter("dir4", NULL, 0); 273 TestIter("dir4", NULL, 0);
264 } 274 }
265 275
266 } // namespace gdata 276 } // namespace gdata
OLDNEW
« no previous file with comments | « no previous file | tools/heapcheck/suppressions.txt » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698