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

Side by Side Diff: webkit/dom_storage/dom_storage_area_unittest.cc

Issue 10389061: DomStorageArea: Allow multiple simultaneous in flight commit batches. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Comment Created 8 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 | Annotate | Revision Log
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 "base/bind.h" 5 #include "base/bind.h"
6 #include "base/file_util.h" 6 #include "base/file_util.h"
7 #include "base/message_loop.h" 7 #include "base/message_loop.h"
8 #include "base/message_loop_proxy.h" 8 #include "base/message_loop_proxy.h"
9 #include "base/scoped_temp_dir.h" 9 #include "base/scoped_temp_dir.h"
10 #include "base/threading/sequenced_worker_pool.h" 10 #include "base/threading/sequenced_worker_pool.h"
(...skipping 20 matching lines...) Expand all
31 const GURL kOrigin; 31 const GURL kOrigin;
32 const string16 kKey; 32 const string16 kKey;
33 const string16 kValue; 33 const string16 kValue;
34 const string16 kKey2; 34 const string16 kKey2;
35 const string16 kValue2; 35 const string16 kValue2;
36 36
37 // Method used in the CommitTasks test case. 37 // Method used in the CommitTasks test case.
38 void InjectedCommitSequencingTask(DomStorageArea* area) { 38 void InjectedCommitSequencingTask(DomStorageArea* area) {
39 // At this point the OnCommitTimer has run. 39 // At this point the OnCommitTimer has run.
40 // Verify that it put a commit in flight. 40 // Verify that it put a commit in flight.
41 EXPECT_TRUE(area->in_flight_commit_batch_.get()); 41 EXPECT_EQ(1, area->commit_batches_in_flight_);
42 EXPECT_FALSE(area->commit_batch_.get()); 42 EXPECT_FALSE(area->commit_batch_.get());
43 EXPECT_TRUE(area->HasUncommittedChanges()); 43 EXPECT_TRUE(area->HasUncommittedChanges());
44 // Make additional change and verify that a new commit batch 44 // Make additional change and verify that a new commit batch
45 // is created for that change. 45 // is created for that change.
46 NullableString16 old_value; 46 NullableString16 old_value;
47 EXPECT_TRUE(area->SetItem(kKey2, kValue2, &old_value)); 47 EXPECT_TRUE(area->SetItem(kKey2, kValue2, &old_value));
48 EXPECT_TRUE(area->commit_batch_.get()); 48 EXPECT_TRUE(area->commit_batch_.get());
49 EXPECT_TRUE(area->in_flight_commit_batch_.get()); 49 EXPECT_EQ(1, area->commit_batches_in_flight_);
50 EXPECT_TRUE(area->HasUncommittedChanges()); 50 EXPECT_TRUE(area->HasUncommittedChanges());
51 } 51 }
52 52
53 // Class used in the CommitChangesAtShutdown test case. 53 // Class used in the CommitChangesAtShutdown test case.
54 class VerifyChangesCommittedDatabase : public DomStorageDatabase { 54 class VerifyChangesCommittedDatabase : public DomStorageDatabase {
55 public: 55 public:
56 VerifyChangesCommittedDatabase() {} 56 VerifyChangesCommittedDatabase() {}
57 virtual ~VerifyChangesCommittedDatabase() { 57 virtual ~VerifyChangesCommittedDatabase() {
58 const string16 kKey(ASCIIToUTF16("key")); 58 const string16 kKey(ASCIIToUTF16("key"));
59 const string16 kValue(ASCIIToUTF16("value")); 59 const string16 kValue(ASCIIToUTF16("value"));
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after
167 // that a file is written to disk - DOMStorageDatabase unit tests cover 167 // that a file is written to disk - DOMStorageDatabase unit tests cover
168 // that. 168 // that.
169 area->backing_.reset(new DomStorageDatabase()); 169 area->backing_.reset(new DomStorageDatabase());
170 170
171 // Need to write something to ensure that the database is created. 171 // Need to write something to ensure that the database is created.
172 NullableString16 old_value; 172 NullableString16 old_value;
173 EXPECT_TRUE(area->SetItem(kKey, kValue, &old_value)); 173 EXPECT_TRUE(area->SetItem(kKey, kValue, &old_value));
174 ASSERT_TRUE(old_value.is_null()); 174 ASSERT_TRUE(old_value.is_null());
175 EXPECT_TRUE(area->is_initial_import_done_); 175 EXPECT_TRUE(area->is_initial_import_done_);
176 EXPECT_TRUE(area->commit_batch_.get()); 176 EXPECT_TRUE(area->commit_batch_.get());
177 EXPECT_FALSE(area->in_flight_commit_batch_.get()); 177 EXPECT_EQ(0, area->commit_batches_in_flight_);
178 178
179 MessageLoop::current()->RunAllPending(); 179 MessageLoop::current()->RunAllPending();
180 180
181 EXPECT_FALSE(area->commit_batch_.get()); 181 EXPECT_FALSE(area->commit_batch_.get());
182 EXPECT_FALSE(area->in_flight_commit_batch_.get()); 182 EXPECT_EQ(0, area->commit_batches_in_flight_);
183 EXPECT_TRUE(area->backing_->IsOpen()); 183 EXPECT_TRUE(area->backing_->IsOpen());
184 EXPECT_EQ(1u, area->Length()); 184 EXPECT_EQ(1u, area->Length());
185 EXPECT_EQ(kValue, area->GetItem(kKey).string()); 185 EXPECT_EQ(kValue, area->GetItem(kKey).string());
186 186
187 // Verify the content made it to the in memory database. 187 // Verify the content made it to the in memory database.
188 ValuesMap values; 188 ValuesMap values;
189 area->backing_->ReadAllValues(&values); 189 area->backing_->ReadAllValues(&values);
190 EXPECT_EQ(1u, values.size()); 190 EXPECT_EQ(1u, values.size());
191 EXPECT_EQ(kValue, values[kKey].string()); 191 EXPECT_EQ(kValue, values[kKey].string());
192 } 192 }
(...skipping 26 matching lines...) Expand all
219 EXPECT_TRUE(area->commit_batch_.get()); 219 EXPECT_TRUE(area->commit_batch_.get());
220 EXPECT_FALSE(area->commit_batch_->clear_all_first); 220 EXPECT_FALSE(area->commit_batch_->clear_all_first);
221 EXPECT_EQ(1u, area->commit_batch_->changed_values.size()); 221 EXPECT_EQ(1u, area->commit_batch_->changed_values.size());
222 EXPECT_TRUE(area->SetItem(kKey2, kValue2, &old_value)); 222 EXPECT_TRUE(area->SetItem(kKey2, kValue2, &old_value));
223 EXPECT_TRUE(area->commit_batch_.get()); 223 EXPECT_TRUE(area->commit_batch_.get());
224 EXPECT_FALSE(area->commit_batch_->clear_all_first); 224 EXPECT_FALSE(area->commit_batch_->clear_all_first);
225 EXPECT_EQ(2u, area->commit_batch_->changed_values.size()); 225 EXPECT_EQ(2u, area->commit_batch_->changed_values.size());
226 MessageLoop::current()->RunAllPending(); 226 MessageLoop::current()->RunAllPending();
227 EXPECT_FALSE(area->HasUncommittedChanges()); 227 EXPECT_FALSE(area->HasUncommittedChanges());
228 EXPECT_FALSE(area->commit_batch_.get()); 228 EXPECT_FALSE(area->commit_batch_.get());
229 EXPECT_FALSE(area->in_flight_commit_batch_.get()); 229 EXPECT_EQ(0, area->commit_batches_in_flight_);
230 // Verify the changes made it to the database. 230 // Verify the changes made it to the database.
231 values.clear(); 231 values.clear();
232 area->backing_->ReadAllValues(&values); 232 area->backing_->ReadAllValues(&values);
233 EXPECT_EQ(2u, values.size()); 233 EXPECT_EQ(2u, values.size());
234 EXPECT_EQ(kValue, values[kKey].string()); 234 EXPECT_EQ(kValue, values[kKey].string());
235 EXPECT_EQ(kValue2, values[kKey2].string()); 235 EXPECT_EQ(kValue2, values[kKey2].string());
236 236
237 // See that clear is handled properly. 237 // See that clear is handled properly.
238 EXPECT_TRUE(area->Clear()); 238 EXPECT_TRUE(area->Clear());
239 EXPECT_TRUE(area->commit_batch_.get()); 239 EXPECT_TRUE(area->commit_batch_.get());
240 EXPECT_TRUE(area->commit_batch_->clear_all_first); 240 EXPECT_TRUE(area->commit_batch_->clear_all_first);
241 EXPECT_TRUE(area->commit_batch_->changed_values.empty()); 241 EXPECT_TRUE(area->commit_batch_->changed_values.empty());
242 MessageLoop::current()->RunAllPending(); 242 MessageLoop::current()->RunAllPending();
243 EXPECT_FALSE(area->commit_batch_.get()); 243 EXPECT_FALSE(area->commit_batch_.get());
244 EXPECT_FALSE(area->in_flight_commit_batch_.get()); 244 EXPECT_EQ(0, area->commit_batches_in_flight_);
245 // Verify the changes made it to the database. 245 // Verify the changes made it to the database.
246 values.clear(); 246 values.clear();
247 area->backing_->ReadAllValues(&values); 247 area->backing_->ReadAllValues(&values);
248 EXPECT_TRUE(values.empty()); 248 EXPECT_TRUE(values.empty());
249 249
250 // See that if changes accrue while a commit is "in flight" 250 // See that if changes accrue while a commit is "in flight"
251 // those will also get committed. 251 // those will also get committed.
252 EXPECT_TRUE(area->SetItem(kKey, kValue, &old_value)); 252 EXPECT_TRUE(area->SetItem(kKey, kValue, &old_value));
253 EXPECT_TRUE(area->HasUncommittedChanges()); 253 EXPECT_TRUE(area->HasUncommittedChanges());
254 // At this point the OnCommitTimer task has been posted. We inject 254 // At this point the OnCommitTimer task has been posted. We inject
(...skipping 187 matching lines...) Expand 10 before | Expand all | Expand 10 after
442 EXPECT_EQ( 442 EXPECT_EQ(
443 FilePath().AppendASCII("-journal"), 443 FilePath().AppendASCII("-journal"),
444 DomStorageDatabase::GetJournalFilePath(FilePath())); 444 DomStorageDatabase::GetJournalFilePath(FilePath()));
445 EXPECT_EQ( 445 EXPECT_EQ(
446 FilePath().AppendASCII(".extensiononly-journal"), 446 FilePath().AppendASCII(".extensiononly-journal"),
447 DomStorageDatabase::GetJournalFilePath( 447 DomStorageDatabase::GetJournalFilePath(
448 FilePath().AppendASCII(".extensiononly"))); 448 FilePath().AppendASCII(".extensiononly")));
449 } 449 }
450 450
451 } // namespace dom_storage 451 } // namespace dom_storage
OLDNEW
« webkit/dom_storage/dom_storage_area.cc ('K') | « webkit/dom_storage/dom_storage_area.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698