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

Side by Side Diff: content/browser/service_worker/service_worker_database_unittest.cc

Issue 285453002: ServiceWorker: Clean up ServiceWorkerDatabaseTest (2) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "content/browser/service_worker/service_worker_database.h" 5 #include "content/browser/service_worker/service_worker_database.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/files/scoped_temp_dir.h" 9 #include "base/files/scoped_temp_dir.h"
10 #include "base/stl_util.h" 10 #include "base/stl_util.h"
(...skipping 11 matching lines...) Expand all
22 int64 reg_id; 22 int64 reg_id;
23 int64 res_id; 23 int64 res_id;
24 int64 ver_id; 24 int64 ver_id;
25 25
26 AvailableIds() : reg_id(-1), res_id(-1), ver_id(-1) {} 26 AvailableIds() : reg_id(-1), res_id(-1), ver_id(-1) {}
27 ~AvailableIds() {} 27 ~AvailableIds() {}
28 }; 28 };
29 29
30 GURL URL(const GURL& origin, const std::string& path) { 30 GURL URL(const GURL& origin, const std::string& path) {
31 EXPECT_TRUE(origin.is_valid()); 31 EXPECT_TRUE(origin.is_valid());
32 GURL out(origin.GetOrigin().spec() + path); 32 EXPECT_EQ(origin, origin.GetOrigin());
33 GURL out(origin.spec() + path);
33 EXPECT_TRUE(out.is_valid()); 34 EXPECT_TRUE(out.is_valid());
34 return out; 35 return out;
35 } 36 }
36 37
37 Resource CreateResource(int64 resource_id, const GURL& url) { 38 Resource CreateResource(int64 resource_id, const GURL& url) {
39 EXPECT_TRUE(url.is_valid());
38 Resource resource; 40 Resource resource;
39 resource.resource_id = resource_id; 41 resource.resource_id = resource_id;
40 resource.url = url; 42 resource.url = url;
41 EXPECT_TRUE(resource.url.is_valid());
42 return resource; 43 return resource;
43 } 44 }
44 45
45 ServiceWorkerDatabase* CreateDatabase(const base::FilePath& path) { 46 ServiceWorkerDatabase* CreateDatabase(const base::FilePath& path) {
46 return new ServiceWorkerDatabase(path); 47 return new ServiceWorkerDatabase(path);
47 } 48 }
48 49
49 ServiceWorkerDatabase* CreateDatabaseInMemory() { 50 ServiceWorkerDatabase* CreateDatabaseInMemory() {
50 return new ServiceWorkerDatabase(base::FilePath()); 51 return new ServiceWorkerDatabase(base::FilePath());
51 } 52 }
52 53
53 void VerifyRegistrationData(const RegistrationData& expected, 54 void VerifyRegistrationData(const RegistrationData& expected,
54 const RegistrationData& actual) { 55 const RegistrationData& actual) {
55 EXPECT_EQ(expected.registration_id, actual.registration_id); 56 EXPECT_EQ(expected.registration_id, actual.registration_id);
56 EXPECT_EQ(expected.scope, actual.scope); 57 EXPECT_EQ(expected.scope, actual.scope);
57 EXPECT_EQ(expected.script, actual.script); 58 EXPECT_EQ(expected.script, actual.script);
58 EXPECT_EQ(expected.version_id, actual.version_id); 59 EXPECT_EQ(expected.version_id, actual.version_id);
59 EXPECT_EQ(expected.is_active, actual.is_active); 60 EXPECT_EQ(expected.is_active, actual.is_active);
60 EXPECT_EQ(expected.has_fetch_handler, actual.has_fetch_handler); 61 EXPECT_EQ(expected.has_fetch_handler, actual.has_fetch_handler);
61 EXPECT_EQ(expected.last_update_check, actual.last_update_check); 62 EXPECT_EQ(expected.last_update_check, actual.last_update_check);
62 } 63 }
63 64
64 void VerifyResourceRecords(const std::vector<Resource>& expected, 65 void VerifyResourceRecords(const std::vector<Resource>& expected,
65 const std::vector<Resource>& actual) { 66 const std::vector<Resource>& actual) {
66 EXPECT_EQ(expected.size(), actual.size()); 67 ASSERT_EQ(expected.size(), actual.size());
67 if (expected.size() != actual.size())
68 return;
69 for (size_t i = 0; i < expected.size(); ++i) { 68 for (size_t i = 0; i < expected.size(); ++i) {
70 EXPECT_EQ(expected[i].resource_id, actual[i].resource_id); 69 EXPECT_EQ(expected[i].resource_id, actual[i].resource_id);
71 EXPECT_EQ(expected[i].url, actual[i].url); 70 EXPECT_EQ(expected[i].url, actual[i].url);
72 } 71 }
73 } 72 }
74 73
75 } // namespace 74 } // namespace
76 75
77 TEST(ServiceWorkerDatabaseTest, OpenDatabase) { 76 TEST(ServiceWorkerDatabaseTest, OpenDatabase) {
78 base::ScopedTempDir database_dir; 77 base::ScopedTempDir database_dir;
(...skipping 132 matching lines...) Expand 10 before | Expand all | Expand 10 after
211 data3.script = URL(origin3, "/script3.js"); 210 data3.script = URL(origin3, "/script3.js");
212 data3.version_id = 678; 211 data3.version_id = 678;
213 ASSERT_TRUE(database->WriteRegistration(data3, resources)); 212 ASSERT_TRUE(database->WriteRegistration(data3, resources));
214 213
215 // |origin3| has two registrations. 214 // |origin3| has two registrations.
216 RegistrationData data4; 215 RegistrationData data4;
217 data4.registration_id = 456; 216 data4.registration_id = 456;
218 data4.scope = URL(origin3, "/fuga"); 217 data4.scope = URL(origin3, "/fuga");
219 data4.script = URL(origin3, "/script4.js"); 218 data4.script = URL(origin3, "/script4.js");
220 data4.version_id = 789; 219 data4.version_id = 789;
221 ASSERT_EQ(origin3, data4.scope.GetOrigin());
222 ASSERT_TRUE(database->WriteRegistration(data4, resources)); 220 ASSERT_TRUE(database->WriteRegistration(data4, resources));
223 221
224 origins.clear(); 222 origins.clear();
225 EXPECT_TRUE(database->GetOriginsWithRegistrations(&origins)); 223 EXPECT_TRUE(database->GetOriginsWithRegistrations(&origins));
226 EXPECT_EQ(3U, origins.size()); 224 EXPECT_EQ(3U, origins.size());
227 EXPECT_TRUE(ContainsKey(origins, origin1)); 225 EXPECT_TRUE(ContainsKey(origins, origin1));
228 EXPECT_TRUE(ContainsKey(origins, origin2)); 226 EXPECT_TRUE(ContainsKey(origins, origin2));
229 EXPECT_TRUE(ContainsKey(origins, origin3)); 227 EXPECT_TRUE(ContainsKey(origins, origin3));
230 228
231 // |origin3| has another registration, so should not remove it from the 229 // |origin3| has another registration, so should not remove it from the
(...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after
341 339
342 registrations.clear(); 340 registrations.clear();
343 EXPECT_TRUE(database->GetAllRegistrations(&registrations)); 341 EXPECT_TRUE(database->GetAllRegistrations(&registrations));
344 EXPECT_EQ(4U, registrations.size()); 342 EXPECT_EQ(4U, registrations.size());
345 VerifyRegistrationData(data1, registrations[0]); 343 VerifyRegistrationData(data1, registrations[0]);
346 VerifyRegistrationData(data2, registrations[1]); 344 VerifyRegistrationData(data2, registrations[1]);
347 VerifyRegistrationData(data3, registrations[2]); 345 VerifyRegistrationData(data3, registrations[2]);
348 VerifyRegistrationData(data4, registrations[3]); 346 VerifyRegistrationData(data4, registrations[3]);
349 } 347 }
350 348
351 // TODO(nhiroki): Record read/write operations using gtest fixture to avoid
352 // building expectations by hand. For example, expected purgeable resource ids
353 // should be calculated automatically.
nhiroki 2014/05/12 15:14:24 I found this makes test purposes/expectations uncl
354 TEST(ServiceWorkerDatabaseTest, Registration_Basic) { 349 TEST(ServiceWorkerDatabaseTest, Registration_Basic) {
355 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory()); 350 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory());
356 351
357 GURL origin("http://example.com"); 352 GURL origin("http://example.com");
358 RegistrationData data; 353 RegistrationData data;
359 data.registration_id = 100; 354 data.registration_id = 100;
360 data.scope = URL(origin, "/foo"); 355 data.scope = URL(origin, "/foo");
361 data.script = URL(origin, "/script.js"); 356 data.script = URL(origin, "/script.js");
362 data.version_id = 200; 357 data.version_id = 200;
363 358
364 Resource resource1 = CreateResource(1, URL(origin, "/resource1")); 359 std::vector<Resource> resources;
365 Resource resource2 = CreateResource(2, URL(origin, "/resource2")); 360 resources.push_back(CreateResource(1, URL(origin, "/resource1")));
361 resources.push_back(CreateResource(2, URL(origin, "/resource2")));
366 362
367 std::vector<Resource> resources; 363 // Write a resource to the uncommitted list to make sure that writing
368 resources.push_back(resource1);
369 resources.push_back(resource2);
370
371 // Write |resource1| to the uncommitted list to make sure that writing
372 // registration removes resource ids associated with the registration from 364 // registration removes resource ids associated with the registration from
373 // the uncommitted list. 365 // the uncommitted list.
374 std::set<int64> uncommitted_ids; 366 std::set<int64> uncommitted_ids;
375 uncommitted_ids.insert(resource1.resource_id); 367 uncommitted_ids.insert(resources[0].resource_id);
376 EXPECT_TRUE(database->WriteUncommittedResourceIds(uncommitted_ids)); 368 EXPECT_TRUE(database->WriteUncommittedResourceIds(uncommitted_ids));
377 std::set<int64> uncommitted_ids_out; 369 std::set<int64> uncommitted_ids_out;
378 EXPECT_TRUE(database->GetUncommittedResourceIds(&uncommitted_ids_out)); 370 EXPECT_TRUE(database->GetUncommittedResourceIds(&uncommitted_ids_out));
379 EXPECT_EQ(1u, uncommitted_ids_out.size()); 371 EXPECT_EQ(uncommitted_ids.size(), uncommitted_ids_out.size());
380 EXPECT_TRUE(ContainsKey(uncommitted_ids_out, resource1.resource_id)); 372 EXPECT_TRUE(ContainsKey(uncommitted_ids_out, resources[0].resource_id));
381 373
382 EXPECT_TRUE(database->WriteRegistration(data, resources)); 374 EXPECT_TRUE(database->WriteRegistration(data, resources));
383 375
384 // Make sure that the registration and resource records are stored. 376 // Make sure that the registration and resource records are stored.
385 RegistrationData data_out; 377 RegistrationData data_out;
386 std::vector<Resource> resources_out; 378 std::vector<Resource> resources_out;
387 EXPECT_TRUE(database->ReadRegistration( 379 EXPECT_TRUE(database->ReadRegistration(
388 data.registration_id, origin, &data_out, &resources_out)); 380 data.registration_id, origin, &data_out, &resources_out));
389 VerifyRegistrationData(data, data_out); 381 VerifyRegistrationData(data, data_out);
390 VerifyResourceRecords(resources, resources_out); 382 VerifyResourceRecords(resources, resources_out);
391 383
392 // Make sure that |resource1| is removed from the uncommitted list. 384 // Make sure that the resource is removed from the uncommitted list.
393 uncommitted_ids_out.clear(); 385 uncommitted_ids_out.clear();
394 EXPECT_TRUE(database->GetUncommittedResourceIds(&uncommitted_ids_out)); 386 EXPECT_TRUE(database->GetUncommittedResourceIds(&uncommitted_ids_out));
395 EXPECT_TRUE(uncommitted_ids_out.empty()); 387 EXPECT_TRUE(uncommitted_ids_out.empty());
396 388
397 EXPECT_TRUE(database->DeleteRegistration( 389 EXPECT_TRUE(database->DeleteRegistration(data.registration_id, origin));
398 data.registration_id, data.scope.GetOrigin()));
399 390
400 // Make sure that the registration and resource records are gone. 391 // Make sure that the registration and resource records are gone.
401 resources_out.clear(); 392 resources_out.clear();
402 EXPECT_FALSE(database->ReadRegistration( 393 EXPECT_FALSE(database->ReadRegistration(
403 data.registration_id, origin, &data_out, &resources_out)); 394 data.registration_id, origin, &data_out, &resources_out));
404 EXPECT_TRUE(resources_out.empty()); 395 EXPECT_TRUE(resources_out.empty());
405 396
406 // Resources should be purgeable because these are no longer referred. 397 // Resources should be purgeable because these are no longer referred.
407 std::set<int64> purgeable_resource_ids; 398 std::set<int64> purgeable_ids_out;
408 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_resource_ids)); 399 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_ids_out));
409 EXPECT_EQ(2u, purgeable_resource_ids.size()); 400 EXPECT_EQ(2u, purgeable_ids_out.size());
410 EXPECT_TRUE(ContainsKey(purgeable_resource_ids, resource1.resource_id)); 401 EXPECT_TRUE(ContainsKey(purgeable_ids_out, resources[0].resource_id));
411 EXPECT_TRUE(ContainsKey(purgeable_resource_ids, resource2.resource_id)); 402 EXPECT_TRUE(ContainsKey(purgeable_ids_out, resources[1].resource_id));
412 } 403 }
413 404
414 TEST(ServiceWorkerDatabaseTest, Registration_Overwrite) { 405 TEST(ServiceWorkerDatabaseTest, Registration_Overwrite) {
415 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory()); 406 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory());
416 407
417 GURL origin("http://example.com"); 408 GURL origin("http://example.com");
418 RegistrationData data; 409 RegistrationData data;
419 data.registration_id = 100; 410 data.registration_id = 100;
420 data.scope = URL(origin, "/foo"); 411 data.scope = URL(origin, "/foo");
421 data.script = URL(origin, "/script.js"); 412 data.script = URL(origin, "/script.js");
422 data.version_id = 200; 413 data.version_id = 200;
423 414
424 Resource resource1 = CreateResource(1, URL(origin, "/resource1"));
425 Resource resource2 = CreateResource(2, URL(origin, "/resource2"));
426
427 std::vector<Resource> resources1; 415 std::vector<Resource> resources1;
428 resources1.push_back(resource1); 416 resources1.push_back(CreateResource(1, URL(origin, "/resource1")));
429 resources1.push_back(resource2); 417 resources1.push_back(CreateResource(2, URL(origin, "/resource2")));
430 418
431 EXPECT_TRUE(database->WriteRegistration(data, resources1)); 419 EXPECT_TRUE(database->WriteRegistration(data, resources1));
432 420
433 // Make sure that the registration and resource records are stored. 421 // Make sure that the registration and resource records are stored.
434 RegistrationData data_out; 422 RegistrationData data_out;
435 std::vector<Resource> resources_out; 423 std::vector<Resource> resources_out;
436 EXPECT_TRUE(database->ReadRegistration( 424 EXPECT_TRUE(database->ReadRegistration(
437 data.registration_id, origin, &data_out, &resources_out)); 425 data.registration_id, origin, &data_out, &resources_out));
438 VerifyRegistrationData(data, data_out); 426 VerifyRegistrationData(data, data_out);
439 VerifyResourceRecords(resources1, resources_out); 427 VerifyResourceRecords(resources1, resources_out);
440 428
441 // Update the registration. 429 // Update the registration.
442 RegistrationData updated_data = data; 430 RegistrationData updated_data = data;
443 updated_data.version_id = data.version_id + 1; 431 updated_data.version_id = data.version_id + 1;
444 Resource resource3 = CreateResource(3, URL(origin, "/resource3"));
445 Resource resource4 = CreateResource(4, URL(origin, "/resource4"));
446 std::vector<Resource> resources2; 432 std::vector<Resource> resources2;
447 resources2.push_back(resource3); 433 resources2.push_back(CreateResource(3, URL(origin, "/resource3")));
448 resources2.push_back(resource4); 434 resources2.push_back(CreateResource(4, URL(origin, "/resource4")));
449 435
450 EXPECT_TRUE(database->WriteRegistration(updated_data, resources2)); 436 EXPECT_TRUE(database->WriteRegistration(updated_data, resources2));
451 437
452 // Make sure that |updated_data| is stored and resources referred from |data| 438 // Make sure that |updated_data| is stored and resources referred from |data|
453 // is moved to the purgeable list. 439 // is moved to the purgeable list.
454 resources_out.clear(); 440 resources_out.clear();
455 EXPECT_TRUE(database->ReadRegistration( 441 EXPECT_TRUE(database->ReadRegistration(
456 updated_data.registration_id, origin, &data_out, &resources_out)); 442 updated_data.registration_id, origin, &data_out, &resources_out));
457 VerifyRegistrationData(updated_data, data_out); 443 VerifyRegistrationData(updated_data, data_out);
458 VerifyResourceRecords(resources2, resources_out); 444 VerifyResourceRecords(resources2, resources_out);
459 445
460 std::set<int64> purgeable_resource_ids; 446 std::set<int64> purgeable_ids_out;
461 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_resource_ids)); 447 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_ids_out));
462 EXPECT_EQ(2u, purgeable_resource_ids.size()); 448 EXPECT_EQ(2u, purgeable_ids_out.size());
463 EXPECT_TRUE(ContainsKey(purgeable_resource_ids, resource1.resource_id)); 449 EXPECT_TRUE(ContainsKey(purgeable_ids_out, resources1[0].resource_id));
464 EXPECT_TRUE(ContainsKey(purgeable_resource_ids, resource2.resource_id)); 450 EXPECT_TRUE(ContainsKey(purgeable_ids_out, resources1[1].resource_id));
465 } 451 }
466 452
467 TEST(ServiceWorkerDatabaseTest, Registration_Multiple) { 453 TEST(ServiceWorkerDatabaseTest, Registration_Multiple) {
468 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory()); 454 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory());
469
470 GURL origin("http://example.com"); 455 GURL origin("http://example.com");
471 456
472 // Add registration1. 457 // Add registration1.
473 RegistrationData data1; 458 RegistrationData data1;
474 data1.registration_id = 100; 459 data1.registration_id = 100;
475 data1.scope = URL(origin, "/foo"); 460 data1.scope = URL(origin, "/foo");
476 data1.script = URL(origin, "/script1.js"); 461 data1.script = URL(origin, "/script1.js");
477 data1.version_id = 200; 462 data1.version_id = 200;
478 GURL origin1 = data1.scope.GetOrigin();
479
480 Resource resource1 = CreateResource(1, URL(origin, "/resource1"));
481 Resource resource2 = CreateResource(2, URL(origin, "/resource2"));
482 463
483 std::vector<Resource> resources1; 464 std::vector<Resource> resources1;
484 resources1.push_back(resource1); 465 resources1.push_back(CreateResource(1, URL(origin, "/resource1")));
485 resources1.push_back(resource2); 466 resources1.push_back(CreateResource(2, URL(origin, "/resource2")));
486 EXPECT_TRUE(database->WriteRegistration(data1, resources1)); 467 EXPECT_TRUE(database->WriteRegistration(data1, resources1));
487 468
488 // Add registration2. 469 // Add registration2.
489 RegistrationData data2; 470 RegistrationData data2;
490 data2.registration_id = 101; 471 data2.registration_id = 101;
491 data2.scope = URL(origin, "/bar"); 472 data2.scope = URL(origin, "/bar");
492 data2.script = URL(origin, "/script2.js"); 473 data2.script = URL(origin, "/script2.js");
493 data2.version_id = 201; 474 data2.version_id = 201;
494 GURL origin2 = data2.scope.GetOrigin();
495
496 Resource resource3 = CreateResource(3, URL(origin, "/resource3"));
497 Resource resource4 = CreateResource(4, URL(origin, "/resource4"));
498 475
499 std::vector<Resource> resources2; 476 std::vector<Resource> resources2;
500 resources2.push_back(resource3); 477 resources2.push_back(CreateResource(3, URL(origin, "/resource3")));
501 resources2.push_back(resource4); 478 resources2.push_back(CreateResource(4, URL(origin, "/resource4")));
502 EXPECT_TRUE(database->WriteRegistration(data2, resources2)); 479 EXPECT_TRUE(database->WriteRegistration(data2, resources2));
503 480
504 // Make sure that registration1 is stored. 481 // Make sure that registration1 is stored.
505 RegistrationData data_out; 482 RegistrationData data_out;
506 std::vector<Resource> resources_out; 483 std::vector<Resource> resources_out;
507 EXPECT_TRUE(database->ReadRegistration( 484 EXPECT_TRUE(database->ReadRegistration(
508 data1.registration_id, origin, &data_out, &resources_out)); 485 data1.registration_id, origin, &data_out, &resources_out));
509 VerifyRegistrationData(data1, data_out); 486 VerifyRegistrationData(data1, data_out);
510 VerifyResourceRecords(resources1, resources_out); 487 VerifyResourceRecords(resources1, resources_out);
511 488
512 // Make sure that registration2 is also stored. 489 // Make sure that registration2 is also stored.
513 resources_out.clear(); 490 resources_out.clear();
514 EXPECT_TRUE(database->ReadRegistration( 491 EXPECT_TRUE(database->ReadRegistration(
515 data2.registration_id, origin, &data_out, &resources_out)); 492 data2.registration_id, origin, &data_out, &resources_out));
516 VerifyRegistrationData(data2, data_out); 493 VerifyRegistrationData(data2, data_out);
517 VerifyResourceRecords(resources2, resources_out); 494 VerifyResourceRecords(resources2, resources_out);
518 495
519 std::set<int64> purgeable_resource_ids; 496 std::set<int64> purgeable_ids_out;
520 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_resource_ids)); 497 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_ids_out));
521 EXPECT_TRUE(purgeable_resource_ids.empty()); 498 EXPECT_TRUE(purgeable_ids_out.empty());
522 499
523 // Delete registration1. 500 // Delete registration1.
524 EXPECT_TRUE(database->DeleteRegistration(data1.registration_id, origin)); 501 EXPECT_TRUE(database->DeleteRegistration(data1.registration_id, origin));
525 502
526 // Make sure that registration1 is gone. 503 // Make sure that registration1 is gone.
527 resources_out.clear(); 504 resources_out.clear();
528 EXPECT_FALSE(database->ReadRegistration( 505 EXPECT_FALSE(database->ReadRegistration(
529 data1.registration_id, origin, &data_out, &resources_out)); 506 data1.registration_id, origin, &data_out, &resources_out));
530 EXPECT_TRUE(resources_out.empty()); 507 EXPECT_TRUE(resources_out.empty());
531 508
532 purgeable_resource_ids.clear(); 509 purgeable_ids_out.clear();
533 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_resource_ids)); 510 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_ids_out));
534 EXPECT_EQ(2u, purgeable_resource_ids.size()); 511 EXPECT_EQ(2u, purgeable_ids_out.size());
535 EXPECT_TRUE(ContainsKey(purgeable_resource_ids, resource1.resource_id)); 512 EXPECT_TRUE(ContainsKey(purgeable_ids_out, resources1[0].resource_id));
536 EXPECT_TRUE(ContainsKey(purgeable_resource_ids, resource2.resource_id)); 513 EXPECT_TRUE(ContainsKey(purgeable_ids_out, resources1[1].resource_id));
537 514
538 // Make sure that registration2 is still alive. 515 // Make sure that registration2 is still alive.
539 resources_out.clear(); 516 resources_out.clear();
540 EXPECT_TRUE(database->ReadRegistration( 517 EXPECT_TRUE(database->ReadRegistration(
541 data2.registration_id, origin, &data_out, &resources_out)); 518 data2.registration_id, origin, &data_out, &resources_out));
542 VerifyRegistrationData(data2, data_out); 519 VerifyRegistrationData(data2, data_out);
543 VerifyResourceRecords(resources2, resources_out); 520 VerifyResourceRecords(resources2, resources_out);
544 } 521 }
545 522
546 TEST(ServiceWorkerDatabaseTest, UncommittedResourceIds) { 523 TEST(ServiceWorkerDatabaseTest, UncommittedResourceIds) {
547 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory()); 524 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory());
548 525
549 // Write {1, 2, 3}. 526 // Write {1, 2, 3}.
550 std::set<int64> ids1; 527 std::set<int64> ids1;
551 ids1.insert(1); 528 ids1.insert(1);
552 ids1.insert(2); 529 ids1.insert(2);
553 ids1.insert(3); 530 ids1.insert(3);
554 EXPECT_TRUE(database->WriteUncommittedResourceIds(ids1)); 531 EXPECT_TRUE(database->WriteUncommittedResourceIds(ids1));
555 532
556 std::set<int64> ids_out; 533 std::set<int64> ids_out;
557 EXPECT_TRUE(database->GetUncommittedResourceIds(&ids_out)); 534 EXPECT_TRUE(database->GetUncommittedResourceIds(&ids_out));
558 EXPECT_EQ(ids1.size(), ids_out.size()); 535 EXPECT_EQ(ids1, ids_out);
559 EXPECT_TRUE(base::STLIncludes(ids1, ids_out));
560 536
561 // Write {2, 4}. 537 // Write {2, 4}.
562 std::set<int64> ids2; 538 std::set<int64> ids2;
563 ids2.insert(2); 539 ids2.insert(2);
564 ids2.insert(4); 540 ids2.insert(4);
565 EXPECT_TRUE(database->WriteUncommittedResourceIds(ids2)); 541 EXPECT_TRUE(database->WriteUncommittedResourceIds(ids2));
566 542
567 ids_out.clear(); 543 ids_out.clear();
568 EXPECT_TRUE(database->GetUncommittedResourceIds(&ids_out)); 544 EXPECT_TRUE(database->GetUncommittedResourceIds(&ids_out));
569 EXPECT_EQ(4U, ids_out.size()); 545 std::set<int64> expected = base::STLSetUnion<std::set<int64> >(ids1, ids2);
570 EXPECT_TRUE(ContainsKey(ids_out, 1)); 546 EXPECT_EQ(expected, ids_out);
571 EXPECT_TRUE(ContainsKey(ids_out, 2));
572 EXPECT_TRUE(ContainsKey(ids_out, 3));
573 EXPECT_TRUE(ContainsKey(ids_out, 4));
574 547
575 // Delete {2, 3}. 548 // Delete {2, 3}.
576 std::set<int64> ids3; 549 std::set<int64> ids3;
577 ids3.insert(2); 550 ids3.insert(2);
578 ids3.insert(3); 551 ids3.insert(3);
579 EXPECT_TRUE(database->ClearUncommittedResourceIds(ids3)); 552 EXPECT_TRUE(database->ClearUncommittedResourceIds(ids3));
580 553
581 ids_out.clear(); 554 ids_out.clear();
582 EXPECT_TRUE(database->GetUncommittedResourceIds(&ids_out)); 555 EXPECT_TRUE(database->GetUncommittedResourceIds(&ids_out));
583 EXPECT_EQ(2U, ids_out.size()); 556 expected = base::STLSetDifference<std::set<int64> >(expected, ids3);
584 EXPECT_TRUE(ContainsKey(ids_out, 1)); 557 EXPECT_EQ(expected, ids_out);
585 EXPECT_TRUE(ContainsKey(ids_out, 4));
586 } 558 }
587 559
588 TEST(ServiceWorkerDatabaseTest, PurgeableResourceIds) { 560 TEST(ServiceWorkerDatabaseTest, PurgeableResourceIds) {
589 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory()); 561 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory());
590 562
591 // Write {1, 2, 3}. 563 // Write {1, 2, 3}.
592 std::set<int64> ids1; 564 std::set<int64> ids1;
593 ids1.insert(1); 565 ids1.insert(1);
594 ids1.insert(2); 566 ids1.insert(2);
595 ids1.insert(3); 567 ids1.insert(3);
596 EXPECT_TRUE(database->WritePurgeableResourceIds(ids1)); 568 EXPECT_TRUE(database->WritePurgeableResourceIds(ids1));
597 569
598 std::set<int64> ids_out; 570 std::set<int64> ids_out;
599 EXPECT_TRUE(database->GetPurgeableResourceIds(&ids_out)); 571 EXPECT_TRUE(database->GetPurgeableResourceIds(&ids_out));
600 EXPECT_EQ(ids1.size(), ids_out.size()); 572 EXPECT_EQ(ids1, ids_out);
601 EXPECT_TRUE(base::STLIncludes(ids1, ids_out));
602 573
603 // Write {2, 4}. 574 // Write {2, 4}.
604 std::set<int64> ids2; 575 std::set<int64> ids2;
605 ids2.insert(2); 576 ids2.insert(2);
606 ids2.insert(4); 577 ids2.insert(4);
607 EXPECT_TRUE(database->WritePurgeableResourceIds(ids2)); 578 EXPECT_TRUE(database->WritePurgeableResourceIds(ids2));
608 579
609 ids_out.clear(); 580 ids_out.clear();
610 EXPECT_TRUE(database->GetPurgeableResourceIds(&ids_out)); 581 EXPECT_TRUE(database->GetPurgeableResourceIds(&ids_out));
611 EXPECT_EQ(4U, ids_out.size()); 582 std::set<int64> expected = base::STLSetUnion<std::set<int64> >(ids1, ids2);
612 EXPECT_TRUE(ContainsKey(ids_out, 1)); 583 EXPECT_EQ(expected, ids_out);
613 EXPECT_TRUE(ContainsKey(ids_out, 2));
614 EXPECT_TRUE(ContainsKey(ids_out, 3));
615 EXPECT_TRUE(ContainsKey(ids_out, 4));
616 584
617 // Delete {2, 3}. 585 // Delete {2, 3}.
618 std::set<int64> ids3; 586 std::set<int64> ids3;
619 ids3.insert(2); 587 ids3.insert(2);
620 ids3.insert(3); 588 ids3.insert(3);
621 EXPECT_TRUE(database->ClearPurgeableResourceIds(ids3)); 589 EXPECT_TRUE(database->ClearPurgeableResourceIds(ids3));
622 590
623 ids_out.clear(); 591 ids_out.clear();
624 EXPECT_TRUE(database->GetPurgeableResourceIds(&ids_out)); 592 EXPECT_TRUE(database->GetPurgeableResourceIds(&ids_out));
625 EXPECT_EQ(2U, ids_out.size()); 593 expected = base::STLSetDifference<std::set<int64> >(expected, ids3);
626 EXPECT_TRUE(ContainsKey(ids_out, 1)); 594 EXPECT_EQ(expected, ids_out);
627 EXPECT_TRUE(ContainsKey(ids_out, 4));
628 } 595 }
629 596
630 TEST(ServiceWorkerDatabaseTest, DeleteAllDataForOrigin) { 597 TEST(ServiceWorkerDatabaseTest, DeleteAllDataForOrigin) {
631 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory()); 598 scoped_ptr<ServiceWorkerDatabase> database(CreateDatabaseInMemory());
632 599
633 // Data associated with |origin1| will be removed. 600 // Data associated with |origin1| will be removed.
634 GURL origin1("http://example.com"); 601 GURL origin1("http://example.com");
635 GURL origin2("http://example.org"); 602 GURL origin2("http://example.org");
636 603
637 // |origin1| has two registrations. 604 // |origin1| has two registrations.
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
694 std::set<int64> purgeable_ids_out; 661 std::set<int64> purgeable_ids_out;
695 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_ids_out)); 662 EXPECT_TRUE(database->GetPurgeableResourceIds(&purgeable_ids_out));
696 EXPECT_EQ(4u, purgeable_ids_out.size()); 663 EXPECT_EQ(4u, purgeable_ids_out.size());
697 EXPECT_TRUE(ContainsKey(purgeable_ids_out, 1)); 664 EXPECT_TRUE(ContainsKey(purgeable_ids_out, 1));
698 EXPECT_TRUE(ContainsKey(purgeable_ids_out, 2)); 665 EXPECT_TRUE(ContainsKey(purgeable_ids_out, 2));
699 EXPECT_TRUE(ContainsKey(purgeable_ids_out, 3)); 666 EXPECT_TRUE(ContainsKey(purgeable_ids_out, 3));
700 EXPECT_TRUE(ContainsKey(purgeable_ids_out, 4)); 667 EXPECT_TRUE(ContainsKey(purgeable_ids_out, 4));
701 } 668 }
702 669
703 } // namespace content 670 } // namespace content
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698