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

Side by Side Diff: chrome/browser/history/history_backend_unittest.cc

Issue 11746010: Cleanup history favicon code (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 11 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 | « chrome/browser/history/history_backend.cc ('k') | chrome/browser/history/history_types.h » ('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 <algorithm> 5 #include <algorithm>
6 #include <set> 6 #include <set>
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/basictypes.h" 9 #include "base/basictypes.h"
10 #include "base/bind.h" 10 #include "base/bind.h"
(...skipping 1269 matching lines...) Expand 10 before | Expand all | Expand 10 after
1280 backend_->db_->AddURL(url_info2); 1280 backend_->db_->AddURL(url_info2);
1281 1281
1282 history::RedirectList redirects; 1282 history::RedirectList redirects;
1283 redirects.push_back(url2); 1283 redirects.push_back(url2);
1284 redirects.push_back(url1); 1284 redirects.push_back(url1);
1285 backend_->recent_redirects_.Put(url1, redirects); 1285 backend_->recent_redirects_.Put(url1, redirects);
1286 1286
1287 const GURL icon_url1("http://www.google.com/icon"); 1287 const GURL icon_url1("http://www.google.com/icon");
1288 const GURL icon_url2("http://www.google.com/icon2"); 1288 const GURL icon_url2("http://www.google.com/icon2");
1289 1289
1290 // Create mapping for a page with two favicons. 1290 // Generate bitmap data for a page with two favicons.
1291 IconURLSizesMap two_icon_url_sizes; 1291 std::vector<FaviconBitmapData> two_favicon_bitmap_data;
1292 two_icon_url_sizes[icon_url1] = GetSizesSmallAndLarge(); 1292 GenerateFaviconBitmapData(icon_url1, GetSizesSmallAndLarge(),
1293 two_icon_url_sizes[icon_url2] = GetSizesSmallAndLarge(); 1293 icon_url2, GetSizesSmallAndLarge(), &two_favicon_bitmap_data);
1294 1294
1295 // Create a mapping for a page with a single favicon. 1295 // Generate bitmap data for a page with a single favicon.
1296 IconURLSizesMap one_icon_url_sizes; 1296 std::vector<FaviconBitmapData> one_favicon_bitmap_data;
1297 one_icon_url_sizes[icon_url1] = GetSizesSmallAndLarge(); 1297 GenerateFaviconBitmapData(icon_url1, GetSizesSmallAndLarge(),
1298 1298 &one_favicon_bitmap_data);
1299 std::vector<FaviconBitmapData> favicon_bitmap_data;
1300 1299
1301 // Add two favicons 1300 // Add two favicons
1302 backend_->SetFavicons(url1, FAVICON, favicon_bitmap_data, 1301 backend_->SetFavicons(url1, FAVICON, two_favicon_bitmap_data);
1303 two_icon_url_sizes);
1304 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON)); 1302 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON));
1305 EXPECT_EQ(2u, NumIconMappingsForPageURL(url2, FAVICON)); 1303 EXPECT_EQ(2u, NumIconMappingsForPageURL(url2, FAVICON));
1306 1304
1307 // Add one touch_icon 1305 // Add one touch_icon
1308 backend_->SetFavicons(url1, TOUCH_ICON, favicon_bitmap_data, 1306 backend_->SetFavicons(url1, TOUCH_ICON, one_favicon_bitmap_data);
1309 one_icon_url_sizes);
1310 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_ICON)); 1307 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_ICON));
1311 EXPECT_EQ(1u, NumIconMappingsForPageURL(url2, TOUCH_ICON)); 1308 EXPECT_EQ(1u, NumIconMappingsForPageURL(url2, TOUCH_ICON));
1312 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON)); 1309 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON));
1313 1310
1314 // Add one TOUCH_PRECOMPOSED_ICON 1311 // Add one TOUCH_PRECOMPOSED_ICON
1315 backend_->SetFavicons(url1, TOUCH_PRECOMPOSED_ICON, favicon_bitmap_data, 1312 backend_->SetFavicons(url1, TOUCH_PRECOMPOSED_ICON, one_favicon_bitmap_data);
1316 one_icon_url_sizes);
1317 // The touch_icon was replaced. 1313 // The touch_icon was replaced.
1318 EXPECT_EQ(0u, NumIconMappingsForPageURL(url1, TOUCH_ICON)); 1314 EXPECT_EQ(0u, NumIconMappingsForPageURL(url1, TOUCH_ICON));
1319 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON)); 1315 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON));
1320 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_PRECOMPOSED_ICON)); 1316 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_PRECOMPOSED_ICON));
1321 EXPECT_EQ(1u, NumIconMappingsForPageURL(url2, TOUCH_PRECOMPOSED_ICON)); 1317 EXPECT_EQ(1u, NumIconMappingsForPageURL(url2, TOUCH_PRECOMPOSED_ICON));
1322 1318
1323 // Add a touch_icon. 1319 // Add a touch_icon.
1324 backend_->SetFavicons(url1, TOUCH_ICON, favicon_bitmap_data, 1320 backend_->SetFavicons(url1, TOUCH_ICON, one_favicon_bitmap_data);
1325 one_icon_url_sizes);
1326 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_ICON)); 1321 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_ICON));
1327 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON)); 1322 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON));
1328 // The TOUCH_PRECOMPOSED_ICON was replaced. 1323 // The TOUCH_PRECOMPOSED_ICON was replaced.
1329 EXPECT_EQ(0u, NumIconMappingsForPageURL(url1, TOUCH_PRECOMPOSED_ICON)); 1324 EXPECT_EQ(0u, NumIconMappingsForPageURL(url1, TOUCH_PRECOMPOSED_ICON));
1330 1325
1331 // Add a single favicon. 1326 // Add a single favicon.
1332 backend_->SetFavicons(url1, FAVICON, favicon_bitmap_data, 1327 backend_->SetFavicons(url1, FAVICON, one_favicon_bitmap_data);
1333 one_icon_url_sizes);
1334 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_ICON)); 1328 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_ICON));
1335 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, FAVICON)); 1329 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, FAVICON));
1336 EXPECT_EQ(1u, NumIconMappingsForPageURL(url2, FAVICON)); 1330 EXPECT_EQ(1u, NumIconMappingsForPageURL(url2, FAVICON));
1337 1331
1338 // Add two favicons. 1332 // Add two favicons.
1339 backend_->SetFavicons(url1, FAVICON, favicon_bitmap_data, 1333 backend_->SetFavicons(url1, FAVICON, two_favicon_bitmap_data);
1340 two_icon_url_sizes);
1341 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_ICON)); 1334 EXPECT_EQ(1u, NumIconMappingsForPageURL(url1, TOUCH_ICON));
1342 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON)); 1335 EXPECT_EQ(2u, NumIconMappingsForPageURL(url1, FAVICON));
1343 } 1336 }
1344 1337
1345 // Test that there is no churn in icon mappings from calling 1338 // Test that there is no churn in icon mappings from calling
1346 // SetFavicons() twice with the same |icon_url_sizes| parameter. 1339 // SetFavicons() twice with the same |favicon_bitmap_data| parameter.
1347 TEST_F(HistoryBackendTest, SetFaviconMappingsForPageDuplicates) { 1340 TEST_F(HistoryBackendTest, SetFaviconMappingsForPageDuplicates) {
1348 const GURL url("http://www.google.com/"); 1341 const GURL url("http://www.google.com/");
1349 const GURL icon_url("http://www.google.com/icon"); 1342 const GURL icon_url("http://www.google.com/icon");
1343
1350 std::vector<FaviconBitmapData> favicon_bitmap_data; 1344 std::vector<FaviconBitmapData> favicon_bitmap_data;
1345 GenerateFaviconBitmapData(icon_url, GetSizesSmallAndLarge(),
1346 &favicon_bitmap_data);
1351 1347
1352 IconURLSizesMap icon_url_sizes; 1348 backend_->SetFavicons(url, FAVICON, favicon_bitmap_data);
1353 icon_url_sizes[icon_url] = GetSizesSmallAndLarge();
1354
1355 backend_->SetFavicons(url, FAVICON, favicon_bitmap_data, icon_url_sizes);
1356 1349
1357 std::vector<IconMapping> icon_mappings; 1350 std::vector<IconMapping> icon_mappings;
1358 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL( 1351 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(
1359 url, FAVICON, &icon_mappings)); 1352 url, FAVICON, &icon_mappings));
1360 EXPECT_EQ(1u, icon_mappings.size()); 1353 EXPECT_EQ(1u, icon_mappings.size());
1361 IconMappingID mapping_id = icon_mappings[0].mapping_id; 1354 IconMappingID mapping_id = icon_mappings[0].mapping_id;
1362 1355
1363 backend_->SetFavicons(url, FAVICON, favicon_bitmap_data, icon_url_sizes); 1356 backend_->SetFavicons(url, FAVICON, favicon_bitmap_data);
1364 1357
1365 icon_mappings.clear(); 1358 icon_mappings.clear();
1366 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL( 1359 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(
1367 url, FAVICON, &icon_mappings)); 1360 url, FAVICON, &icon_mappings));
1368 EXPECT_EQ(1u, icon_mappings.size()); 1361 EXPECT_EQ(1u, icon_mappings.size());
1369 1362
1370 // The same row in the icon_mapping table should be used for the mapping as 1363 // The same row in the icon_mapping table should be used for the mapping as
1371 // before. 1364 // before.
1372 EXPECT_EQ(mapping_id, icon_mappings[0].mapping_id); 1365 EXPECT_EQ(mapping_id, icon_mappings[0].mapping_id);
1373 } 1366 }
1374 1367
1375 // Test that setting favicons for a page which already has data does the 1368 // Test that calling SetFavicons() with FaviconBitmapData of different pixel
1376 // right thing. 1369 // sizes than the initially passed in FaviconBitmapData deletes the no longer
1377 TEST_F(HistoryBackendTest, SetFavicons) { 1370 // used favicon bitmaps.
1378 const GURL page_url("http://www.google.com/");
1379 std::vector<FaviconBitmapData> favicon_bitmap_data;
1380 IconURLSizesMap icon_url_sizes;
1381
1382 // Set |page_url| as having two favicons each available from the web at two
1383 // sizes.
1384 const GURL icon_url1("http://www.google.com/icon1");
1385 const GURL icon_url2("http://www.google.com/icon2");
1386
1387 icon_url_sizes[icon_url1] = GetSizesSmallAndLarge();
1388 icon_url_sizes[icon_url2] = GetSizesSmallAndLarge();
1389
1390 // Set only sizes info for the favicons.
1391 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data,
1392 icon_url_sizes);
1393
1394 std::vector<IconMapping> icon_mappings;
1395 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(
1396 page_url, &icon_mappings));
1397 EXPECT_EQ(2u, icon_mappings.size());
1398 for (size_t i = 0; i < icon_mappings.size(); ++i) {
1399 EXPECT_FALSE(backend_->thumbnail_db_->GetFaviconBitmaps(
1400 icon_mappings[i].icon_id, NULL));
1401 }
1402
1403 // Add bitmap data to the favicons.
1404 GenerateFaviconBitmapData(icon_url1,
1405 GetSizesSmall(),
1406 icon_url2,
1407 GetSizesSmallAndLarge(),
1408 &favicon_bitmap_data);
1409
1410 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data,
1411 icon_url_sizes);
1412
1413 icon_mappings.clear();
1414 EXPECT_TRUE(GetSortedIconMappingsForPageURL(page_url, &icon_mappings));
1415 EXPECT_EQ(2u, icon_mappings.size());
1416
1417 GURL icon_url;
1418 IconType icon_type;
1419 FaviconSizes favicon_sizes;
1420 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1421 icon_mappings[0].icon_id, &icon_url, &icon_type, &favicon_sizes));
1422 EXPECT_EQ(icon_url1, icon_url);
1423 EXPECT_EQ(FAVICON, icon_type);
1424 EXPECT_EQ(GetSizesSmallAndLarge(), favicon_sizes);
1425
1426 std::vector<FaviconBitmap> favicon_bitmaps;
1427 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconBitmaps(
1428 icon_mappings[0].icon_id, &favicon_bitmaps));
1429 EXPECT_EQ(1u, favicon_bitmaps.size());
1430 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmaps[0].bitmap_data));
1431 EXPECT_EQ(kSmallSize, favicon_bitmaps[0].pixel_size);
1432
1433 favicon_sizes.clear();
1434 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1435 icon_mappings[1].icon_id, &icon_url, &icon_type, &favicon_sizes));
1436 EXPECT_EQ(icon_url2, icon_url);
1437 EXPECT_EQ(FAVICON, icon_type);
1438 EXPECT_EQ(GetSizesSmallAndLarge(), favicon_sizes);
1439
1440 favicon_bitmaps.clear();
1441 EXPECT_TRUE(GetSortedFaviconBitmaps(icon_mappings[1].icon_id,
1442 &favicon_bitmaps));
1443
1444 EXPECT_EQ(2u, favicon_bitmaps.size());
1445 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmaps[0].bitmap_data));
1446 EXPECT_EQ(kSmallSize, favicon_bitmaps[0].pixel_size);
1447 EXPECT_TRUE(BitmapDataEqual('c', favicon_bitmaps[1].bitmap_data));
1448 EXPECT_EQ(kLargeSize, favicon_bitmaps[1].pixel_size);
1449
1450 // Notifications should have been broadcast for each call to SetFavicons().
1451 EXPECT_EQ(2, num_broadcasted_notifications());
1452
1453 // Change the sizes for which the favicon at icon_url1 is available at from
1454 // the web. Verify that all the data remains valid.
1455 icon_url_sizes[icon_url1] = GetSizesTinySmallAndLarge();
1456 favicon_bitmap_data.clear();
1457 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data,
1458 icon_url_sizes);
1459
1460 icon_mappings.clear();
1461 EXPECT_TRUE(GetSortedIconMappingsForPageURL(page_url, &icon_mappings));
1462 EXPECT_EQ(2u, icon_mappings.size());
1463
1464 favicon_sizes.clear();
1465 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1466 icon_mappings[0].icon_id, &icon_url, &icon_type, &favicon_sizes));
1467 EXPECT_EQ(icon_url1, icon_url);
1468 EXPECT_EQ(FAVICON, icon_type);
1469 EXPECT_EQ(GetSizesTinySmallAndLarge(), favicon_sizes);
1470
1471 favicon_bitmaps.clear();
1472 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconBitmaps(
1473 icon_mappings[0].icon_id, &favicon_bitmaps));
1474 EXPECT_EQ(1u, favicon_bitmaps.size());
1475
1476 favicon_sizes.clear();
1477 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1478 icon_mappings[1].icon_id, &icon_url, &icon_type, &favicon_sizes));
1479 EXPECT_EQ(icon_url2, icon_url);
1480 EXPECT_EQ(FAVICON, icon_type);
1481 EXPECT_EQ(GetSizesSmallAndLarge(), favicon_sizes);
1482
1483 favicon_bitmaps.clear();
1484 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconBitmaps(
1485 icon_mappings[1].icon_id, &favicon_bitmaps));
1486 EXPECT_EQ(2u, favicon_bitmaps.size());
1487
1488 // No notifications should have been sent because changing the favicon sizes
1489 // did not result in deleting any favicon bitmaps.
1490 EXPECT_EQ(2, num_broadcasted_notifications());
1491 }
1492
1493 // Test that changing the sizes that a favicon is available at from the web
1494 // deletes stale favicons and favicon bitmaps.
1495 TEST_F(HistoryBackendTest, SetFaviconsDeleteBitmaps) { 1371 TEST_F(HistoryBackendTest, SetFaviconsDeleteBitmaps) {
1496 const GURL page_url("http://www.google.com/"); 1372 const GURL page_url("http://www.google.com/");
1497 const GURL icon_url("http://www.google.com/icon"); 1373 const GURL icon_url("http://www.google.com/icon");
1498 1374
1499 // Set |page_url| as having one favicon with two different sizes.
1500 IconURLSizesMap icon_url_sizes;
1501 icon_url_sizes[icon_url] = GetSizesSmallAndLarge();
1502
1503 std::vector<FaviconBitmapData> favicon_bitmap_data; 1375 std::vector<FaviconBitmapData> favicon_bitmap_data;
1504 GenerateFaviconBitmapData(icon_url, GetSizesSmallAndLarge(), 1376 GenerateFaviconBitmapData(icon_url, GetSizesSmallAndLarge(),
1505 &favicon_bitmap_data); 1377 &favicon_bitmap_data);
1378 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
1506 1379
1507 // Add bitmap data and sizes information to the database. 1380 // Test initial state.
1508 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 1381 std::vector<IconMapping> icon_mappings;
1509 icon_url_sizes); 1382 EXPECT_TRUE(GetSortedIconMappingsForPageURL(page_url, &icon_mappings));
1510 1383 EXPECT_EQ(1u, icon_mappings.size());
1511 FaviconID favicon_id = backend_->thumbnail_db_->GetFaviconIDForFaviconURL( 1384 EXPECT_EQ(icon_url, icon_mappings[0].icon_url);
1512 icon_url, FAVICON, NULL); 1385 EXPECT_EQ(FAVICON, icon_mappings[0].icon_type);
1513 EXPECT_NE(0, favicon_id); 1386 FaviconID favicon_id = icon_mappings[0].icon_id;
1514 1387
1515 std::vector<FaviconBitmap> favicon_bitmaps; 1388 std::vector<FaviconBitmap> favicon_bitmaps;
1516 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconBitmaps(favicon_id, 1389 EXPECT_TRUE(GetSortedFaviconBitmaps(favicon_id, &favicon_bitmaps));
1517 &favicon_bitmaps));
1518 EXPECT_EQ(2u, favicon_bitmaps.size()); 1390 EXPECT_EQ(2u, favicon_bitmaps.size());
1391 FaviconBitmapID small_bitmap_id = favicon_bitmaps[0].bitmap_id;
1392 EXPECT_NE(0, small_bitmap_id);
1393 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmaps[0].bitmap_data));
1394 EXPECT_EQ(kSmallSize, favicon_bitmaps[0].pixel_size);
1395 FaviconBitmapID large_bitmap_id = favicon_bitmaps[1].bitmap_id;
1396 EXPECT_NE(0, large_bitmap_id);
1397 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmaps[1].bitmap_data));
1398 EXPECT_EQ(kLargeSize, favicon_bitmaps[1].pixel_size);
1519 1399
1520 // Change the bitmap sizes available from the web only to the small size only. 1400 // Call SetFavicons() with bitmap data for only the large bitmap. Check that
1521 icon_url_sizes[icon_url] = GetSizesSmall(); 1401 // the small bitmap is in fact deleted.
1402 GenerateFaviconBitmapData(icon_url, GetSizesLarge(), &favicon_bitmap_data);
1403 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
1404
1405 scoped_refptr<base::RefCountedMemory> bitmap_data_out;
1406 gfx::Size pixel_size_out;
1407 EXPECT_FALSE(backend_->thumbnail_db_->GetFaviconBitmap(small_bitmap_id,
1408 NULL, &bitmap_data_out, &pixel_size_out));
1409 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconBitmap(large_bitmap_id,
1410 NULL, &bitmap_data_out, &pixel_size_out));
1411 EXPECT_TRUE(BitmapDataEqual('a', bitmap_data_out));
1412 EXPECT_EQ(kLargeSize, pixel_size_out);
1413
1414 icon_mappings.clear();
1415 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1416 &icon_mappings));
1417 EXPECT_EQ(1u, icon_mappings.size());
1418 EXPECT_EQ(favicon_id, icon_mappings[0].icon_id);
1419
1420 // Call SetFavicons() with no bitmap data. Check that the bitmaps and icon
1421 // mappings are deleted.
1522 favicon_bitmap_data.clear(); 1422 favicon_bitmap_data.clear();
1523 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 1423 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
1524 icon_url_sizes);
1525 1424
1526 favicon_id = backend_->thumbnail_db_->GetFaviconIDForFaviconURL( 1425 EXPECT_FALSE(backend_->thumbnail_db_->GetFaviconBitmap(large_bitmap_id, NULL,
1527 icon_url, FAVICON, NULL); 1426 NULL, NULL));
1528 EXPECT_NE(0, favicon_id); 1427 icon_mappings.clear();
1428 EXPECT_FALSE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1429 &icon_mappings));
1529 1430
1530 favicon_bitmaps.clear(); 1431 // Notifications should have been broadcast for each call to SetFavicons().
1531 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconBitmaps(favicon_id, 1432 EXPECT_EQ(3, num_broadcasted_notifications());
1532 &favicon_bitmaps));
1533 EXPECT_EQ(1u, favicon_bitmaps.size());
1534 EXPECT_EQ(kSmallSize, favicon_bitmaps[0].pixel_size);
1535
1536 // Clear |icon_url_sizes|. SetFavicons() should delete the remaining favicon
1537 // and its favicon bitmap.
1538 icon_url_sizes.clear();
1539 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, icon_url_sizes);
1540 EXPECT_EQ(0, backend_->thumbnail_db_->GetFaviconIDForFaviconURL(
1541 icon_url, FAVICON, NULL));
1542 EXPECT_FALSE(backend_->thumbnail_db_->GetFaviconBitmaps(favicon_id, NULL));
1543 } 1433 }
1544 1434
1545 // Test updating a single favicon bitmap's data via SetFavicons. 1435 // Test updating a single favicon bitmap's data via SetFavicons.
1546 TEST_F(HistoryBackendTest, SetFaviconsReplaceBitmapData) { 1436 TEST_F(HistoryBackendTest, SetFaviconsReplaceBitmapData) {
1547
1548 const GURL page_url("http://www.google.com/"); 1437 const GURL page_url("http://www.google.com/");
1549 const GURL icon_url("http://www.google.com/icon"); 1438 const GURL icon_url("http://www.google.com/icon");
1550 IconURLSizesMap icon_url_sizes;
1551 icon_url_sizes[icon_url] = GetSizesSmall();
1552 1439
1553 std::vector<unsigned char> data_initial; 1440 std::vector<unsigned char> data_initial;
1554 data_initial.push_back('a'); 1441 data_initial.push_back('a');
1555 1442
1556 FaviconBitmapData bitmap_data_element; 1443 FaviconBitmapData bitmap_data_element;
1557 bitmap_data_element.bitmap_data = 1444 bitmap_data_element.bitmap_data =
1558 base::RefCountedBytes::TakeVector(&data_initial); 1445 base::RefCountedBytes::TakeVector(&data_initial);
1559 bitmap_data_element.pixel_size = kSmallSize; 1446 bitmap_data_element.pixel_size = kSmallSize;
1560 bitmap_data_element.icon_url = icon_url; 1447 bitmap_data_element.icon_url = icon_url;
1561 std::vector<FaviconBitmapData> favicon_bitmap_data; 1448 std::vector<FaviconBitmapData> favicon_bitmap_data;
1562 favicon_bitmap_data.push_back(bitmap_data_element); 1449 favicon_bitmap_data.push_back(bitmap_data_element);
1563 1450
1564 // Add bitmap to the database. 1451 // Add bitmap to the database.
1565 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 1452 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
1566 icon_url_sizes);
1567 1453
1568 FaviconID original_favicon_id = 1454 FaviconID original_favicon_id =
1569 backend_->thumbnail_db_->GetFaviconIDForFaviconURL(icon_url, FAVICON, 1455 backend_->thumbnail_db_->GetFaviconIDForFaviconURL(icon_url, FAVICON,
1570 NULL); 1456 NULL);
1571 EXPECT_NE(0, original_favicon_id); 1457 EXPECT_NE(0, original_favicon_id);
1572 FaviconBitmap original_favicon_bitmap; 1458 FaviconBitmap original_favicon_bitmap;
1573 EXPECT_TRUE( 1459 EXPECT_TRUE(
1574 GetOnlyFaviconBitmap(original_favicon_id, &original_favicon_bitmap)); 1460 GetOnlyFaviconBitmap(original_favicon_id, &original_favicon_bitmap));
1575 EXPECT_TRUE(BitmapDataEqual('a', original_favicon_bitmap.bitmap_data)); 1461 EXPECT_TRUE(BitmapDataEqual('a', original_favicon_bitmap.bitmap_data));
1576 1462
1577 EXPECT_EQ(1, num_broadcasted_notifications()); 1463 EXPECT_EQ(1, num_broadcasted_notifications());
1578 1464
1579 // Call SetFavicons() with completely identical data. 1465 // Call SetFavicons() with completely identical data.
1580 std::vector<unsigned char> updated_data; 1466 std::vector<unsigned char> updated_data;
1581 updated_data.push_back('a'); 1467 updated_data.push_back('a');
1582 favicon_bitmap_data[0].bitmap_data = new base::RefCountedBytes(updated_data); 1468 favicon_bitmap_data[0].bitmap_data = new base::RefCountedBytes(updated_data);
1583 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 1469 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
1584 icon_url_sizes);
1585 1470
1586 FaviconID updated_favicon_id = 1471 FaviconID updated_favicon_id =
1587 backend_->thumbnail_db_->GetFaviconIDForFaviconURL(icon_url, FAVICON, 1472 backend_->thumbnail_db_->GetFaviconIDForFaviconURL(icon_url, FAVICON,
1588 NULL); 1473 NULL);
1589 EXPECT_NE(0, updated_favicon_id); 1474 EXPECT_NE(0, updated_favicon_id);
1590 FaviconBitmap updated_favicon_bitmap; 1475 FaviconBitmap updated_favicon_bitmap;
1591 EXPECT_TRUE( 1476 EXPECT_TRUE(
1592 GetOnlyFaviconBitmap(updated_favicon_id, &updated_favicon_bitmap)); 1477 GetOnlyFaviconBitmap(updated_favicon_id, &updated_favicon_bitmap));
1593 EXPECT_TRUE(BitmapDataEqual('a', updated_favicon_bitmap.bitmap_data)); 1478 EXPECT_TRUE(BitmapDataEqual('a', updated_favicon_bitmap.bitmap_data));
1594 1479
1595 // Because the bitmap data is byte equivalent, no notifications should have 1480 // Because the bitmap data is byte equivalent, no notifications should have
1596 // been broadcasted. 1481 // been broadcasted.
1597 EXPECT_EQ(1, num_broadcasted_notifications()); 1482 EXPECT_EQ(1, num_broadcasted_notifications());
1598 1483
1599 // Call SetFavicons() with identical data but a different bitmap. 1484 // Call SetFavicons() with identical data but a different bitmap.
1600 updated_data[0] = 'b'; 1485 updated_data[0] = 'b';
1601 favicon_bitmap_data[0].bitmap_data = new base::RefCountedBytes(updated_data); 1486 favicon_bitmap_data[0].bitmap_data = new base::RefCountedBytes(updated_data);
1602 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 1487 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
1603 icon_url_sizes);
1604 1488
1605 updated_favicon_id = 1489 updated_favicon_id =
1606 backend_->thumbnail_db_->GetFaviconIDForFaviconURL(icon_url, FAVICON, 1490 backend_->thumbnail_db_->GetFaviconIDForFaviconURL(icon_url, FAVICON,
1607 NULL); 1491 NULL);
1608 EXPECT_NE(0, updated_favicon_id); 1492 EXPECT_NE(0, updated_favicon_id);
1609 EXPECT_TRUE( 1493 EXPECT_TRUE(
1610 GetOnlyFaviconBitmap(updated_favicon_id, &updated_favicon_bitmap)); 1494 GetOnlyFaviconBitmap(updated_favicon_id, &updated_favicon_bitmap));
1611 EXPECT_TRUE(BitmapDataEqual('b', updated_favicon_bitmap.bitmap_data)); 1495 EXPECT_TRUE(BitmapDataEqual('b', updated_favicon_bitmap.bitmap_data));
1612 1496
1613 // There should be no churn in FaviconIDs or FaviconBitmapIds even though 1497 // There should be no churn in FaviconIDs or FaviconBitmapIds even though
1614 // the bitmap data changed. 1498 // the bitmap data changed.
1615 EXPECT_EQ(original_favicon_bitmap.icon_id, updated_favicon_bitmap.icon_id); 1499 EXPECT_EQ(original_favicon_bitmap.icon_id, updated_favicon_bitmap.icon_id);
1616 EXPECT_EQ(original_favicon_bitmap.bitmap_id, 1500 EXPECT_EQ(original_favicon_bitmap.bitmap_id,
1617 updated_favicon_bitmap.bitmap_id); 1501 updated_favicon_bitmap.bitmap_id);
1618 1502
1619 // A notification should have been broadcasted as the favicon bitmap data has 1503 // A notification should have been broadcasted as the favicon bitmap data has
1620 // changed. 1504 // changed.
1621 EXPECT_EQ(2, num_broadcasted_notifications()); 1505 EXPECT_EQ(2, num_broadcasted_notifications());
1622 } 1506 }
1623 1507
1624 // Test that if two pages share the same FaviconID, changing the favicon for 1508 // Test that if two pages share the same FaviconID, changing the favicon for
1625 // one page does not affect the other. 1509 // one page does not affect the other.
1626 TEST_F(HistoryBackendTest, SetFaviconsSameFaviconURLForTwoPages) { 1510 TEST_F(HistoryBackendTest, SetFaviconsSameFaviconURLForTwoPages) {
1627 GURL icon_url("http://www.google.com/favicon.ico"); 1511 GURL icon_url("http://www.google.com/favicon.ico");
1628 GURL icon_url_new("http://www.google.com/favicon2.ico"); 1512 GURL icon_url_new("http://www.google.com/favicon2.ico");
1629 GURL page_url1("http://www.google.com"); 1513 GURL page_url1("http://www.google.com");
1630 GURL page_url2("http://www.google.ca"); 1514 GURL page_url2("http://www.google.ca");
1631 1515
1632 IconURLSizesMap icon_url_sizes;
1633 icon_url_sizes[icon_url] = GetSizesSmallAndLarge();
1634
1635 std::vector<FaviconBitmapData> favicon_bitmap_data; 1516 std::vector<FaviconBitmapData> favicon_bitmap_data;
1636 GenerateFaviconBitmapData(icon_url, GetSizesSmallAndLarge(), 1517 GenerateFaviconBitmapData(icon_url, GetSizesSmallAndLarge(),
1637 &favicon_bitmap_data); 1518 &favicon_bitmap_data);
1638 1519
1639 backend_->SetFavicons(page_url1, FAVICON, favicon_bitmap_data, 1520 backend_->SetFavicons(page_url1, FAVICON, favicon_bitmap_data);
1640 icon_url_sizes);
1641 1521
1642 std::vector<GURL> icon_urls; 1522 std::vector<GURL> icon_urls;
1643 icon_urls.push_back(icon_url); 1523 icon_urls.push_back(icon_url);
1644 1524
1645 HistoryBackend::FaviconResults results; 1525 std::vector<FaviconBitmapResult> bitmap_results;
1646 backend_->UpdateFaviconMappingsAndFetch( 1526 backend_->UpdateFaviconMappingsAndFetch(
1647 page_url2, icon_urls, FAVICON, kSmallSize.width(), 1527 page_url2, icon_urls, FAVICON, kSmallSize.width(),
1648 GetScaleFactors1x2x(), &results); 1528 GetScaleFactors1x2x(), &bitmap_results);
1649 1529
1650 // Check that the same FaviconID is mapped to both page URLs. 1530 // Check that the same FaviconID is mapped to both page URLs.
1651 std::vector<IconMapping> icon_mappings; 1531 std::vector<IconMapping> icon_mappings;
1652 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL( 1532 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(
1653 page_url1, &icon_mappings)); 1533 page_url1, &icon_mappings));
1654 EXPECT_EQ(1u, icon_mappings.size()); 1534 EXPECT_EQ(1u, icon_mappings.size());
1655 FaviconID favicon_id = icon_mappings[0].icon_id; 1535 FaviconID favicon_id = icon_mappings[0].icon_id;
1656 EXPECT_NE(0, favicon_id); 1536 EXPECT_NE(0, favicon_id);
1657 1537
1658 icon_mappings.clear(); 1538 icon_mappings.clear();
1659 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL( 1539 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(
1660 page_url2, &icon_mappings)); 1540 page_url2, &icon_mappings));
1661 EXPECT_EQ(1u, icon_mappings.size()); 1541 EXPECT_EQ(1u, icon_mappings.size());
1662 EXPECT_EQ(favicon_id, icon_mappings[0].icon_id); 1542 EXPECT_EQ(favicon_id, icon_mappings[0].icon_id);
1663 1543
1664 // Change the icon URL that |page_url1| is mapped to. 1544 // Change the icon URL that |page_url1| is mapped to.
1665 icon_url_sizes.clear();
1666 icon_url_sizes[icon_url_new] = GetSizesSmall();
1667 GenerateFaviconBitmapData(icon_url_new, GetSizesSmall(), 1545 GenerateFaviconBitmapData(icon_url_new, GetSizesSmall(),
1668 &favicon_bitmap_data); 1546 &favicon_bitmap_data);
1669 backend_->SetFavicons(page_url1, FAVICON, favicon_bitmap_data, 1547 backend_->SetFavicons(page_url1, FAVICON, favicon_bitmap_data);
1670 icon_url_sizes);
1671 1548
1672 // |page_url1| should map to a new FaviconID and have valid bitmap data. 1549 // |page_url1| should map to a new FaviconID and have valid bitmap data.
1673 icon_mappings.clear(); 1550 icon_mappings.clear();
1674 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL( 1551 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(
1675 page_url1, &icon_mappings)); 1552 page_url1, &icon_mappings));
1676 EXPECT_EQ(1u, icon_mappings.size()); 1553 EXPECT_EQ(1u, icon_mappings.size());
1677 EXPECT_EQ(icon_url_new, icon_mappings[0].icon_url); 1554 EXPECT_EQ(icon_url_new, icon_mappings[0].icon_url);
1678 EXPECT_NE(favicon_id, icon_mappings[0].icon_id); 1555 EXPECT_NE(favicon_id, icon_mappings[0].icon_id);
1679 1556
1680 std::vector<FaviconBitmap> favicon_bitmaps; 1557 std::vector<FaviconBitmap> favicon_bitmaps;
(...skipping 12 matching lines...) Expand all
1693 favicon_bitmaps.clear(); 1570 favicon_bitmaps.clear();
1694 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconBitmaps(favicon_id, 1571 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconBitmaps(favicon_id,
1695 &favicon_bitmaps)); 1572 &favicon_bitmaps));
1696 EXPECT_EQ(2u, favicon_bitmaps.size()); 1573 EXPECT_EQ(2u, favicon_bitmaps.size());
1697 1574
1698 // A notification should have been broadcast for each call to SetFavicons() 1575 // A notification should have been broadcast for each call to SetFavicons()
1699 // and each call to UpdateFaviconMappingsAndFetch(). 1576 // and each call to UpdateFaviconMappingsAndFetch().
1700 EXPECT_EQ(3, num_broadcasted_notifications()); 1577 EXPECT_EQ(3, num_broadcasted_notifications());
1701 } 1578 }
1702 1579
1703 // Test that there is no churn from calling UpdateFaviconMappingsAndFetch() 1580 // Test that no notifications are broadcast as a result of calling
1704 // for an icon URL which is already mapped to the passed in page URL. 1581 // UpdateFaviconMappingsAndFetch() for an icon URL which is already
1582 // mapped to the passed in page URL.
1705 TEST_F(HistoryBackendTest, UpdateFaviconMappingsAndFetchNoChange) { 1583 TEST_F(HistoryBackendTest, UpdateFaviconMappingsAndFetchNoChange) {
1706 GURL page_url("http://www.google.com"); 1584 GURL page_url("http://www.google.com");
1707 GURL icon_url("http://www.google.com/favicon.ico"); 1585 GURL icon_url("http://www.google.com/favicon.ico");
1708 std::vector<FaviconBitmapData> favicon_bitmap_data; 1586 std::vector<FaviconBitmapData> favicon_bitmap_data;
1587 GenerateFaviconBitmapData(icon_url, GetSizesSmall(), &favicon_bitmap_data);
1709 1588
1710 IconURLSizesMap icon_url_sizes; 1589 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
1711 icon_url_sizes[icon_url] = GetSizesSmall();
1712
1713 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data,
1714 icon_url_sizes);
1715 1590
1716 FaviconID icon_id = backend_->thumbnail_db_->GetFaviconIDForFaviconURL( 1591 FaviconID icon_id = backend_->thumbnail_db_->GetFaviconIDForFaviconURL(
1717 icon_url, FAVICON, NULL); 1592 icon_url, FAVICON, NULL);
1718 EXPECT_NE(0, icon_id); 1593 EXPECT_NE(0, icon_id);
1719 EXPECT_EQ(1, num_broadcasted_notifications()); 1594 EXPECT_EQ(1, num_broadcasted_notifications());
1720 1595
1721 std::vector<GURL> icon_urls; 1596 std::vector<GURL> icon_urls;
1722 icon_urls.push_back(icon_url); 1597 icon_urls.push_back(icon_url);
1723 1598
1724 HistoryBackend::FaviconResults results; 1599 std::vector<FaviconBitmapResult> bitmap_results;
1725 backend_->UpdateFaviconMappingsAndFetch( 1600 backend_->UpdateFaviconMappingsAndFetch(
1726 page_url, icon_urls, FAVICON, kSmallSize.width(), 1601 page_url, icon_urls, FAVICON, kSmallSize.width(),
1727 GetScaleFactors1x2x(), &results); 1602 GetScaleFactors1x2x(), &bitmap_results);
1728 1603
1729 EXPECT_EQ(icon_id, backend_->thumbnail_db_->GetFaviconIDForFaviconURL( 1604 EXPECT_EQ(icon_id, backend_->thumbnail_db_->GetFaviconIDForFaviconURL(
1730 icon_url, FAVICON, NULL)); 1605 icon_url, FAVICON, NULL));
1731 1606
1732 // No notification should have been broadcast as no icon mapping, favicon, 1607 // No notification should have been broadcast as no icon mapping, favicon,
1733 // or favicon bitmap was updated, added or removed. 1608 // or favicon bitmap was updated, added or removed.
1734 EXPECT_EQ(1, num_broadcasted_notifications()); 1609 EXPECT_EQ(1, num_broadcasted_notifications());
1735 } 1610 }
1736 1611
1737 // Test repeatedly calling MergeFavicon(). |page_url| is initially not known 1612 // Test repeatedly calling MergeFavicon(). |page_url| is initially not known
1738 // to the database. 1613 // to the database.
1739 TEST_F(HistoryBackendTest, MergeFaviconPageURLNotInDB) { 1614 TEST_F(HistoryBackendTest, MergeFaviconPageURLNotInDB) {
1740 GURL page_url("http://www.google.com"); 1615 GURL page_url("http://www.google.com");
1741 GURL icon_url("http:/www.google.com/favicon.ico"); 1616 GURL icon_url("http:/www.google.com/favicon.ico");
1742 1617
1743 std::vector<unsigned char> data; 1618 std::vector<unsigned char> data;
1744 data.push_back('a'); 1619 data.push_back('a');
1745 scoped_refptr<base::RefCountedBytes> bitmap_data( 1620 scoped_refptr<base::RefCountedBytes> bitmap_data(
1746 new base::RefCountedBytes(data)); 1621 new base::RefCountedBytes(data));
1747 1622
1748 backend_->MergeFavicon(page_url, icon_url, FAVICON, bitmap_data, kSmallSize); 1623 backend_->MergeFavicon(page_url, icon_url, FAVICON, bitmap_data, kSmallSize);
1749 1624
1750 // |page_url| should now be mapped to |icon_url| and sizes should be set 1625 // |page_url| should now be mapped to |icon_url| and the favicon bitmap should
1751 // to GetDefaultFaviconSizes(). 1626 // not be expired.
1752 std::vector<IconMapping> icon_mappings; 1627 std::vector<IconMapping> icon_mappings;
1753 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url, 1628 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1754 &icon_mappings)); 1629 &icon_mappings));
1755 EXPECT_EQ(1u, icon_mappings.size()); 1630 EXPECT_EQ(1u, icon_mappings.size());
1756 EXPECT_EQ(icon_url, icon_mappings[0].icon_url); 1631 EXPECT_EQ(icon_url, icon_mappings[0].icon_url);
1757 1632
1758 FaviconSizes favicon_sizes;
1759 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1760 icon_mappings[0].icon_id, NULL, NULL, &favicon_sizes));
1761 EXPECT_EQ(GetDefaultFaviconSizes(), favicon_sizes);
1762
1763 FaviconBitmap favicon_bitmap; 1633 FaviconBitmap favicon_bitmap;
1764 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap)); 1634 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap));
1635 EXPECT_NE(base::Time(), favicon_bitmap.last_updated);
1765 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmap.bitmap_data)); 1636 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmap.bitmap_data));
1766 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size); 1637 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size);
1767 1638
1768 data[0] = 'b'; 1639 data[0] = 'b';
1769 bitmap_data = new base::RefCountedBytes(data); 1640 bitmap_data = new base::RefCountedBytes(data);
1770 backend_->MergeFavicon(page_url, icon_url, FAVICON, bitmap_data, kSmallSize); 1641 backend_->MergeFavicon(page_url, icon_url, FAVICON, bitmap_data, kSmallSize);
1771 1642
1772 // |page_url| should still have a single favicon bitmap. The bitmap data 1643 // |page_url| should still have a single favicon bitmap. The bitmap data
1773 // should be updated. 1644 // should be updated.
1774 icon_mappings.clear(); 1645 icon_mappings.clear();
1775 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url, 1646 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1776 &icon_mappings)); 1647 &icon_mappings));
1777 EXPECT_EQ(1u, icon_mappings.size()); 1648 EXPECT_EQ(1u, icon_mappings.size());
1778 EXPECT_EQ(icon_url, icon_mappings[0].icon_url); 1649 EXPECT_EQ(icon_url, icon_mappings[0].icon_url);
1779 1650
1780 favicon_sizes.clear();
1781 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1782 icon_mappings[0].icon_id, NULL, NULL, &favicon_sizes));
1783 EXPECT_EQ(GetDefaultFaviconSizes(), favicon_sizes);
1784
1785 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap)); 1651 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap));
1652 EXPECT_NE(base::Time(), favicon_bitmap.last_updated);
1786 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmap.bitmap_data)); 1653 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmap.bitmap_data));
1787 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size); 1654 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size);
1788 } 1655 }
1789 1656
1790 // Test calling MergeFavicon() when |page_url| is known to the database. 1657 // Test calling MergeFavicon() when |page_url| is known to the database.
1791 TEST_F(HistoryBackendTest, MergeFaviconPageURLInDB) { 1658 TEST_F(HistoryBackendTest, MergeFaviconPageURLInDB) {
1792 GURL page_url("http://www.google.com"); 1659 GURL page_url("http://www.google.com");
1793 GURL icon_url1("http:/www.google.com/favicon.ico"); 1660 GURL icon_url1("http:/www.google.com/favicon.ico");
1794 GURL icon_url2("http://www.google.com/favicon2.ico"); 1661 GURL icon_url2("http://www.google.com/favicon2.ico");
1795 1662
1796 IconURLSizesMap icon_url_sizes;
1797 icon_url_sizes[icon_url1] = GetSizesSmallAndLarge();
1798
1799 std::vector<FaviconBitmapData> favicon_bitmap_data; 1663 std::vector<FaviconBitmapData> favicon_bitmap_data;
1800 GenerateFaviconBitmapData(icon_url1, GetSizesSmall(), 1664 GenerateFaviconBitmapData(icon_url1, GetSizesSmall(),
1801 &favicon_bitmap_data); 1665 &favicon_bitmap_data);
1802 1666
1803 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 1667 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
1804 icon_url_sizes);
1805 1668
1806 // Test initial state. 1669 // Test initial state.
1807 std::vector<IconMapping> icon_mappings; 1670 std::vector<IconMapping> icon_mappings;
1808 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url, 1671 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1809 &icon_mappings)); 1672 &icon_mappings));
1810 EXPECT_EQ(1u, icon_mappings.size()); 1673 EXPECT_EQ(1u, icon_mappings.size());
1811 EXPECT_EQ(icon_url1, icon_mappings[0].icon_url); 1674 EXPECT_EQ(icon_url1, icon_mappings[0].icon_url);
1812 1675
1813 FaviconSizes favicon_sizes;
1814 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1815 icon_mappings[0].icon_id, NULL, NULL, &favicon_sizes));
1816 EXPECT_EQ(GetSizesSmallAndLarge(), favicon_sizes);
1817
1818 FaviconBitmap favicon_bitmap; 1676 FaviconBitmap favicon_bitmap;
1819 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap)); 1677 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap));
1678 EXPECT_NE(base::Time(), favicon_bitmap.last_updated);
1820 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmap.bitmap_data)); 1679 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmap.bitmap_data));
1821 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size); 1680 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size);
1822 1681
1823 EXPECT_EQ(1, num_broadcasted_notifications()); 1682 EXPECT_EQ(1, num_broadcasted_notifications());
1824 1683
1825 // 1) Merge identical favicon bitmap. 1684 // 1) Merge identical favicon bitmap.
1826 std::vector<unsigned char> data; 1685 std::vector<unsigned char> data;
1827 data.push_back('a'); 1686 data.push_back('a');
1828 scoped_refptr<base::RefCountedBytes> bitmap_data( 1687 scoped_refptr<base::RefCountedBytes> bitmap_data(
1829 new base::RefCountedBytes(data)); 1688 new base::RefCountedBytes(data));
1830 backend_->MergeFavicon(page_url, icon_url1, FAVICON, bitmap_data, kSmallSize); 1689 backend_->MergeFavicon(page_url, icon_url1, FAVICON, bitmap_data, kSmallSize);
1831 1690
1832 // All the data should stay the same and no notifications should have been 1691 // All the data should stay the same and no notifications should have been
1833 // sent. 1692 // sent.
1834 icon_mappings.clear(); 1693 icon_mappings.clear();
1835 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url, 1694 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1836 &icon_mappings)); 1695 &icon_mappings));
1837 EXPECT_EQ(1u, icon_mappings.size()); 1696 EXPECT_EQ(1u, icon_mappings.size());
1838 EXPECT_EQ(icon_url1, icon_mappings[0].icon_url); 1697 EXPECT_EQ(icon_url1, icon_mappings[0].icon_url);
1839 1698
1840 favicon_sizes.clear();
1841 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1842 icon_mappings[0].icon_id, NULL, NULL, &favicon_sizes));
1843 EXPECT_EQ(GetSizesSmallAndLarge(), favicon_sizes);
1844
1845 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap)); 1699 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap));
1700 EXPECT_NE(base::Time(), favicon_bitmap.last_updated);
1846 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmap.bitmap_data)); 1701 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmap.bitmap_data));
1847 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size); 1702 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size);
1848 1703
1849 EXPECT_EQ(1, num_broadcasted_notifications()); 1704 EXPECT_EQ(1, num_broadcasted_notifications());
1850 1705
1851 // 2) Merge favicon bitmap of the same size. 1706 // 2) Merge favicon bitmap of the same size.
1852 data[0] = 'b'; 1707 data[0] = 'b';
1853 bitmap_data = new base::RefCountedBytes(data); 1708 bitmap_data = new base::RefCountedBytes(data);
1854 backend_->MergeFavicon(page_url, icon_url1, FAVICON, bitmap_data, kSmallSize); 1709 backend_->MergeFavicon(page_url, icon_url1, FAVICON, bitmap_data, kSmallSize);
1855 1710
1856 // The small favicon bitmap at |icon_url1| should be overwritten and favicon 1711 // The small favicon bitmap at |icon_url1| should be overwritten and favicon
1857 // sizes should remain unchanged. No notification should be sent. 1712 // sizes should remain unchanged. No notification should be sent.
1858 icon_mappings.clear(); 1713 icon_mappings.clear();
1859 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url, 1714 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1860 &icon_mappings)); 1715 &icon_mappings));
1861 EXPECT_EQ(1u, icon_mappings.size()); 1716 EXPECT_EQ(1u, icon_mappings.size());
1862 EXPECT_EQ(icon_url1, icon_mappings[0].icon_url); 1717 EXPECT_EQ(icon_url1, icon_mappings[0].icon_url);
1863 1718
1864 favicon_sizes.clear();
1865 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1866 icon_mappings[0].icon_id, NULL, NULL, &favicon_sizes));
1867 EXPECT_EQ(GetSizesSmallAndLarge(), favicon_sizes);
1868
1869 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap)); 1719 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap));
1720 EXPECT_NE(base::Time(), favicon_bitmap.last_updated);
1870 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmap.bitmap_data)); 1721 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmap.bitmap_data));
1871 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size); 1722 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size);
1872 1723
1873 EXPECT_EQ(1, num_broadcasted_notifications()); 1724 EXPECT_EQ(1, num_broadcasted_notifications());
1874 1725
1875 // 3) Merge favicon for the same icon URL, but a pixel size for which there is 1726 // 3) Merge favicon for the same icon URL, but a pixel size for which there is
1876 // no favicon bitmap. 1727 // no favicon bitmap.
1877 data[0] = 'c'; 1728 data[0] = 'c';
1878 bitmap_data = new base::RefCountedBytes(data); 1729 bitmap_data = new base::RefCountedBytes(data);
1879 backend_->MergeFavicon(page_url, icon_url1, FAVICON, bitmap_data, kTinySize); 1730 backend_->MergeFavicon(page_url, icon_url1, FAVICON, bitmap_data, kTinySize);
1880 1731
1881 // A new favicon bitmap should be created and favicon sizes should be set to 1732 // A new favicon bitmap should be created and the preexisting favicon bitmap
1882 // the default. 1733 // ('b') should be expired.
1883 icon_mappings.clear(); 1734 icon_mappings.clear();
1884 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url, 1735 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1885 &icon_mappings)); 1736 &icon_mappings));
1886 EXPECT_EQ(1u, icon_mappings.size()); 1737 EXPECT_EQ(1u, icon_mappings.size());
1887 EXPECT_EQ(icon_url1, icon_mappings[0].icon_url); 1738 EXPECT_EQ(icon_url1, icon_mappings[0].icon_url);
1888 1739
1889 favicon_sizes.clear();
1890 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1891 icon_mappings[0].icon_id, NULL, NULL, &favicon_sizes));
1892 EXPECT_EQ(GetDefaultFaviconSizes(), favicon_sizes);
1893
1894 std::vector<FaviconBitmap> favicon_bitmaps; 1740 std::vector<FaviconBitmap> favicon_bitmaps;
1895 EXPECT_TRUE(GetSortedFaviconBitmaps(icon_mappings[0].icon_id, 1741 EXPECT_TRUE(GetSortedFaviconBitmaps(icon_mappings[0].icon_id,
1896 &favicon_bitmaps)); 1742 &favicon_bitmaps));
1743 EXPECT_NE(base::Time(), favicon_bitmaps[0].last_updated);
1897 EXPECT_TRUE(BitmapDataEqual('c', favicon_bitmaps[0].bitmap_data)); 1744 EXPECT_TRUE(BitmapDataEqual('c', favicon_bitmaps[0].bitmap_data));
1898 EXPECT_EQ(kTinySize, favicon_bitmaps[0].pixel_size); 1745 EXPECT_EQ(kTinySize, favicon_bitmaps[0].pixel_size);
1746 EXPECT_EQ(base::Time(), favicon_bitmaps[1].last_updated);
1899 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmaps[1].bitmap_data)); 1747 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmaps[1].bitmap_data));
1900 EXPECT_EQ(kSmallSize, favicon_bitmaps[1].pixel_size); 1748 EXPECT_EQ(kSmallSize, favicon_bitmaps[1].pixel_size);
1901 1749
1902 // 4) Merge favicon for an icon URL different from the icon URLs already 1750 // 4) Merge favicon for an icon URL different from the icon URLs already
1903 // mapped to page URL. 1751 // mapped to page URL.
1904 data[0] = 'd'; 1752 data[0] = 'd';
1905 bitmap_data = new base::RefCountedBytes(data); 1753 bitmap_data = new base::RefCountedBytes(data);
1906 backend_->MergeFavicon(page_url, icon_url2, FAVICON, bitmap_data, kSmallSize); 1754 backend_->MergeFavicon(page_url, icon_url2, FAVICON, bitmap_data, kSmallSize);
1907 1755
1908 // The existing favicon bitmaps should be copied over to the newly created 1756 // The existing favicon bitmaps should be copied over to the newly created
1909 // favicon at |icon_url2|. |page_url| should solely be mapped to |icon_url2|. 1757 // favicon at |icon_url2|. |page_url| should solely be mapped to |icon_url2|.
1910 icon_mappings.clear(); 1758 icon_mappings.clear();
1911 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url, 1759 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url,
1912 &icon_mappings)); 1760 &icon_mappings));
1913 EXPECT_EQ(1u, icon_mappings.size()); 1761 EXPECT_EQ(1u, icon_mappings.size());
1914 EXPECT_EQ(icon_url2, icon_mappings[0].icon_url); 1762 EXPECT_EQ(icon_url2, icon_mappings[0].icon_url);
1915 1763
1916 favicon_sizes.clear();
1917 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1918 icon_mappings[0].icon_id, NULL, NULL, &favicon_sizes));
1919 EXPECT_EQ(GetDefaultFaviconSizes(), favicon_sizes);
1920
1921 favicon_bitmaps.clear(); 1764 favicon_bitmaps.clear();
1922 EXPECT_TRUE(GetSortedFaviconBitmaps(icon_mappings[0].icon_id, 1765 EXPECT_TRUE(GetSortedFaviconBitmaps(icon_mappings[0].icon_id,
1923 &favicon_bitmaps)); 1766 &favicon_bitmaps));
1767 EXPECT_EQ(base::Time(), favicon_bitmaps[0].last_updated);
1924 EXPECT_TRUE(BitmapDataEqual('c', favicon_bitmaps[0].bitmap_data)); 1768 EXPECT_TRUE(BitmapDataEqual('c', favicon_bitmaps[0].bitmap_data));
1925 EXPECT_EQ(kTinySize, favicon_bitmaps[0].pixel_size); 1769 EXPECT_EQ(kTinySize, favicon_bitmaps[0].pixel_size);
1926 // The favicon being merged should take precedence over the preexisting 1770 // The favicon being merged should take precedence over the preexisting
1927 // favicon bitmaps. 1771 // favicon bitmaps.
1772 EXPECT_NE(base::Time(), favicon_bitmaps[1].last_updated);
1928 EXPECT_TRUE(BitmapDataEqual('d', favicon_bitmaps[1].bitmap_data)); 1773 EXPECT_TRUE(BitmapDataEqual('d', favicon_bitmaps[1].bitmap_data));
1929 EXPECT_EQ(kSmallSize, favicon_bitmaps[1].pixel_size); 1774 EXPECT_EQ(kSmallSize, favicon_bitmaps[1].pixel_size);
1930 1775
1931 // A notification should have been broadcast for each call to SetFavicons() 1776 // A notification should have been broadcast for each call to SetFavicons()
1932 // and MergeFavicon(). 1777 // and MergeFavicon().
1933 EXPECT_EQ(3, num_broadcasted_notifications()); 1778 EXPECT_EQ(3, num_broadcasted_notifications());
1934 } 1779 }
1935 1780
1936 // Test calling MergeFavicon() when |icon_url| is known to the database but not 1781 // Test calling MergeFavicon() when |icon_url| is known to the database but not
1937 // mapped to |page_url|. 1782 // mapped to |page_url|.
1938 TEST_F(HistoryBackendTest, MergeFaviconIconURLMappedToDifferentPageURL) { 1783 TEST_F(HistoryBackendTest, MergeFaviconIconURLMappedToDifferentPageURL) {
1939 GURL page_url1("http://www.google.com"); 1784 GURL page_url1("http://www.google.com");
1940 GURL page_url2("http://news.google.com"); 1785 GURL page_url2("http://news.google.com");
1941 GURL icon_url("http:/www.google.com/favicon.ico"); 1786 GURL icon_url("http:/www.google.com/favicon.ico");
1942 1787
1943 IconURLSizesMap icon_url_sizes;
1944 icon_url_sizes[icon_url] = GetSizesSmallAndLarge();
1945
1946 std::vector<FaviconBitmapData> favicon_bitmap_data; 1788 std::vector<FaviconBitmapData> favicon_bitmap_data;
1947 GenerateFaviconBitmapData(icon_url, GetSizesSmall(), 1789 GenerateFaviconBitmapData(icon_url, GetSizesSmall(),
1948 &favicon_bitmap_data); 1790 &favicon_bitmap_data);
1949 1791
1950 backend_->SetFavicons(page_url1, FAVICON, favicon_bitmap_data, 1792 backend_->SetFavicons(page_url1, FAVICON, favicon_bitmap_data);
1951 icon_url_sizes);
1952 1793
1953 // Test initial state. 1794 // Test initial state.
1954 std::vector<IconMapping> icon_mappings; 1795 std::vector<IconMapping> icon_mappings;
1955 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url1, 1796 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url1,
1956 &icon_mappings)); 1797 &icon_mappings));
1957 EXPECT_EQ(1u, icon_mappings.size()); 1798 EXPECT_EQ(1u, icon_mappings.size());
1958 EXPECT_EQ(icon_url, icon_mappings[0].icon_url); 1799 EXPECT_EQ(icon_url, icon_mappings[0].icon_url);
1959 1800
1960 FaviconSizes favicon_sizes;
1961 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1962 icon_mappings[0].icon_id, NULL, NULL, &favicon_sizes));
1963 EXPECT_EQ(GetSizesSmallAndLarge(), favicon_sizes);
1964
1965 FaviconBitmap favicon_bitmap; 1801 FaviconBitmap favicon_bitmap;
1966 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap)); 1802 EXPECT_TRUE(GetOnlyFaviconBitmap(icon_mappings[0].icon_id, &favicon_bitmap));
1803 EXPECT_NE(base::Time(), favicon_bitmap.last_updated);
1967 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmap.bitmap_data)); 1804 EXPECT_TRUE(BitmapDataEqual('a', favicon_bitmap.bitmap_data));
1968 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size); 1805 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size);
1969 1806
1970 std::vector<unsigned char> data; 1807 std::vector<unsigned char> data;
1971 data.push_back('b'); 1808 data.push_back('b');
1972 scoped_refptr<base::RefCountedBytes> bitmap_data( 1809 scoped_refptr<base::RefCountedBytes> bitmap_data(
1973 new base::RefCountedBytes(data)); 1810 new base::RefCountedBytes(data));
1974 backend_->MergeFavicon(page_url2, icon_url, FAVICON, bitmap_data, kSmallSize); 1811 backend_->MergeFavicon(page_url2, icon_url, FAVICON, bitmap_data, kSmallSize);
1975 1812
1976 // The small favicon bitmap at |icon_url| should be overwritten. |page_url1| 1813 // The small favicon bitmap at |icon_url| should be overwritten. |page_url1|
(...skipping 10 matching lines...) Expand all
1987 &icon_mappings)); 1824 &icon_mappings));
1988 EXPECT_EQ(1u, icon_mappings.size()); 1825 EXPECT_EQ(1u, icon_mappings.size());
1989 EXPECT_EQ(favicon_id, icon_mappings[0].icon_id); 1826 EXPECT_EQ(favicon_id, icon_mappings[0].icon_id);
1990 1827
1991 GURL icon_url_in_db; 1828 GURL icon_url_in_db;
1992 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader( 1829 EXPECT_TRUE(backend_->thumbnail_db_->GetFaviconHeader(
1993 icon_mappings[0].icon_id, &icon_url_in_db, NULL, NULL)); 1830 icon_mappings[0].icon_id, &icon_url_in_db, NULL, NULL));
1994 EXPECT_EQ(icon_url, icon_url_in_db); 1831 EXPECT_EQ(icon_url, icon_url_in_db);
1995 1832
1996 EXPECT_TRUE(GetOnlyFaviconBitmap(favicon_id, &favicon_bitmap)); 1833 EXPECT_TRUE(GetOnlyFaviconBitmap(favicon_id, &favicon_bitmap));
1834 EXPECT_NE(base::Time(), favicon_bitmap.last_updated);
1997 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmap.bitmap_data)); 1835 EXPECT_TRUE(BitmapDataEqual('b', favicon_bitmap.bitmap_data));
1998 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size); 1836 EXPECT_EQ(kSmallSize, favicon_bitmap.pixel_size);
1999 } 1837 }
2000 1838
2001 // Test that MergeFavicon() does not add more than 1839 // Test that MergeFavicon() does not add more than
2002 // |kMaxFaviconBitmapsPerIconURL| to a favicon. 1840 // |kMaxFaviconBitmapsPerIconURL| to a favicon.
2003 TEST_F(HistoryBackendTest, MergeFaviconMaxFaviconBitmapsPerIconURL) { 1841 TEST_F(HistoryBackendTest, MergeFaviconMaxFaviconBitmapsPerIconURL) {
2004 GURL page_url("http://www.google.com"); 1842 GURL page_url("http://www.google.com");
2005 std::string icon_url_string("http://www.google.com/favicon.ico"); 1843 std::string icon_url_string("http://www.google.com/favicon.ico");
2006 size_t replace_index = icon_url_string.size() - 1; 1844 size_t replace_index = icon_url_string.size() - 1;
(...skipping 25 matching lines...) Expand all
2032 EXPECT_EQ(kMaxFaviconBitmapsPerIconURL, favicon_bitmaps.size()); 1870 EXPECT_EQ(kMaxFaviconBitmapsPerIconURL, favicon_bitmaps.size());
2033 } 1871 }
2034 1872
2035 // Tests that the favicon set by MergeFavicon() shows up in the result of 1873 // Tests that the favicon set by MergeFavicon() shows up in the result of
2036 // GetFaviconsForURL(). 1874 // GetFaviconsForURL().
2037 TEST_F(HistoryBackendTest, MergeFaviconShowsUpInGetFaviconsForURLResult) { 1875 TEST_F(HistoryBackendTest, MergeFaviconShowsUpInGetFaviconsForURLResult) {
2038 GURL page_url("http://www.google.com"); 1876 GURL page_url("http://www.google.com");
2039 GURL icon_url("http://www.google.com/favicon.ico"); 1877 GURL icon_url("http://www.google.com/favicon.ico");
2040 GURL merged_icon_url("http://wwww.google.com/favicon2.ico"); 1878 GURL merged_icon_url("http://wwww.google.com/favicon2.ico");
2041 1879
2042 IconURLSizesMap icon_url_sizes;
2043 icon_url_sizes[icon_url] = GetSizesSmallAndLarge();
2044
2045 std::vector<FaviconBitmapData> favicon_bitmap_data; 1880 std::vector<FaviconBitmapData> favicon_bitmap_data;
2046 GenerateFaviconBitmapData(icon_url, GetSizesSmallAndLarge(), 1881 GenerateFaviconBitmapData(icon_url, GetSizesSmallAndLarge(),
2047 &favicon_bitmap_data); 1882 &favicon_bitmap_data);
2048 1883
2049 // Set some preexisting favicons for |page_url|. 1884 // Set some preexisting favicons for |page_url|.
2050 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 1885 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
2051 icon_url_sizes);
2052 1886
2053 // Merge small favicon. 1887 // Merge small favicon.
2054 std::vector<unsigned char> data; 1888 std::vector<unsigned char> data;
2055 data.push_back('c'); 1889 data.push_back('c');
2056 scoped_refptr<base::RefCountedBytes> bitmap_data( 1890 scoped_refptr<base::RefCountedBytes> bitmap_data(
2057 new base::RefCountedBytes(data)); 1891 new base::RefCountedBytes(data));
2058 backend_->MergeFavicon(page_url, merged_icon_url, FAVICON, bitmap_data, 1892 backend_->MergeFavicon(page_url, merged_icon_url, FAVICON, bitmap_data,
2059 kSmallSize); 1893 kSmallSize);
2060 1894
2061 // Request favicon bitmaps for both 1x and 2x to simulate request done by 1895 // Request favicon bitmaps for both 1x and 2x to simulate request done by
2062 // BookmarkModel::GetFavicon(). 1896 // BookmarkModel::GetFavicon().
2063 HistoryBackend::FaviconResults results; 1897 std::vector<FaviconBitmapResult> bitmap_results;
2064 backend_->GetFaviconsForURL(page_url, FAVICON, kSmallSize.width(), 1898 backend_->GetFaviconsForURL(page_url, FAVICON, kSmallSize.width(),
2065 GetScaleFactors1x2x(), &results); 1899 GetScaleFactors1x2x(), &bitmap_results);
2066 1900
2067 EXPECT_EQ(2u, results.bitmap_results.size()); 1901 EXPECT_EQ(2u, bitmap_results.size());
2068 const FaviconBitmapResult& first_result = results.bitmap_results[0]; 1902 const FaviconBitmapResult& first_result = bitmap_results[0];
2069 const FaviconBitmapResult& result = 1903 const FaviconBitmapResult& result =
2070 (first_result.pixel_size == kSmallSize) ? first_result 1904 (first_result.pixel_size == kSmallSize) ? first_result
2071 : results.bitmap_results[1]; 1905 : bitmap_results[1];
2072 EXPECT_TRUE(BitmapDataEqual('c', result.bitmap_data)); 1906 EXPECT_TRUE(BitmapDataEqual('c', result.bitmap_data));
2073 } 1907 }
2074 1908
2075 // Test UpdateFaviconMapingsAndFetch() when multiple icon types are passed in. 1909 // Test UpdateFaviconMapingsAndFetch() when multiple icon types are passed in.
2076 TEST_F(HistoryBackendTest, UpdateFaviconMappingsAndFetchMultipleIconTypes) { 1910 TEST_F(HistoryBackendTest, UpdateFaviconMappingsAndFetchMultipleIconTypes) {
2077 GURL page_url1("http://www.google.com"); 1911 GURL page_url1("http://www.google.com");
2078 GURL page_url2("http://news.google.com"); 1912 GURL page_url2("http://news.google.com");
2079 GURL page_url3("http://mail.google.com"); 1913 GURL page_url3("http://mail.google.com");
2080 GURL icon_urla("http://www.google.com/favicon1.ico"); 1914 GURL icon_urla("http://www.google.com/favicon1.ico");
2081 GURL icon_urlb("http://www.google.com/favicon2.ico"); 1915 GURL icon_urlb("http://www.google.com/favicon2.ico");
2082 GURL icon_urlc("http://www.google.com/favicon3.ico"); 1916 GURL icon_urlc("http://www.google.com/favicon3.ico");
2083 1917
2084 // |page_url1| is mapped to |icon_urla| which if of type TOUCH_ICON. 1918 // |page_url1| is mapped to |icon_urla| which if of type TOUCH_ICON.
2085 IconURLSizesMap icon_url_sizes;
2086 icon_url_sizes[icon_urla] = GetSizesSmall();
2087
2088 std::vector<FaviconBitmapData> favicon_bitmap_data; 1919 std::vector<FaviconBitmapData> favicon_bitmap_data;
2089 GenerateFaviconBitmapData(icon_urla, GetSizesSmall(), &favicon_bitmap_data); 1920 GenerateFaviconBitmapData(icon_urla, GetSizesSmall(), &favicon_bitmap_data);
2090 backend_->SetFavicons(page_url1, TOUCH_ICON, favicon_bitmap_data, 1921 backend_->SetFavicons(page_url1, TOUCH_ICON, favicon_bitmap_data);
2091 icon_url_sizes);
2092 1922
2093 // |page_url2| is mapped to |icon_urlb| and |icon_urlc| which are of type 1923 // |page_url2| is mapped to |icon_urlb| and |icon_urlc| which are of type
2094 // TOUCH_PRECOMPOSED_ICON. 1924 // TOUCH_PRECOMPOSED_ICON.
2095 icon_url_sizes.clear();
2096 icon_url_sizes[icon_urlb] = GetSizesSmall();
2097 icon_url_sizes[icon_urlc] = GetSizesSmall();
2098 GenerateFaviconBitmapData(icon_urlb, GetSizesSmall(), icon_urlc, 1925 GenerateFaviconBitmapData(icon_urlb, GetSizesSmall(), icon_urlc,
2099 GetSizesSmall(), &favicon_bitmap_data); 1926 GetSizesSmall(), &favicon_bitmap_data);
2100 backend_->SetFavicons(page_url2, TOUCH_PRECOMPOSED_ICON, favicon_bitmap_data, 1927 backend_->SetFavicons(page_url2, TOUCH_PRECOMPOSED_ICON, favicon_bitmap_data);
2101 icon_url_sizes);
2102 1928
2103 std::vector<GURL> icon_urls; 1929 std::vector<GURL> icon_urls;
2104 icon_urls.push_back(icon_urla); 1930 icon_urls.push_back(icon_urla);
2105 icon_urls.push_back(icon_urlb); 1931 icon_urls.push_back(icon_urlb);
2106 icon_urls.push_back(icon_urlc); 1932 icon_urls.push_back(icon_urlc);
2107 1933
2108 HistoryBackend::FaviconResults results; 1934 std::vector<FaviconBitmapResult> bitmap_results;
2109 backend_->UpdateFaviconMappingsAndFetch( 1935 backend_->UpdateFaviconMappingsAndFetch(
2110 page_url3, icon_urls, (TOUCH_ICON | TOUCH_PRECOMPOSED_ICON), 1936 page_url3, icon_urls, (TOUCH_ICON | TOUCH_PRECOMPOSED_ICON),
2111 kSmallSize.width(), GetScaleFactors1x2x(), &results); 1937 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results);
2112 1938
2113 // |page_url1| and |page_url2| should still be mapped to the same icon URLs. 1939 // |page_url1| and |page_url2| should still be mapped to the same icon URLs.
2114 std::vector<IconMapping> icon_mappings; 1940 std::vector<IconMapping> icon_mappings;
2115 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url1, 1941 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(page_url1,
2116 &icon_mappings)); 1942 &icon_mappings));
2117 EXPECT_EQ(1u, icon_mappings.size()); 1943 EXPECT_EQ(1u, icon_mappings.size());
2118 EXPECT_EQ(icon_urla, icon_mappings[0].icon_url); 1944 EXPECT_EQ(icon_urla, icon_mappings[0].icon_url);
2119 EXPECT_EQ(TOUCH_ICON, icon_mappings[0].icon_type); 1945 EXPECT_EQ(TOUCH_ICON, icon_mappings[0].icon_type);
2120 1946
2121 icon_mappings.clear(); 1947 icon_mappings.clear();
(...skipping 14 matching lines...) Expand all
2136 EXPECT_EQ(icon_urlc, icon_mappings[1].icon_url); 1962 EXPECT_EQ(icon_urlc, icon_mappings[1].icon_url);
2137 EXPECT_EQ(TOUCH_PRECOMPOSED_ICON, icon_mappings[1].icon_type); 1963 EXPECT_EQ(TOUCH_PRECOMPOSED_ICON, icon_mappings[1].icon_type);
2138 } 1964 }
2139 1965
2140 // Test the results of GetFaviconsFromDB() when there are no found 1966 // Test the results of GetFaviconsFromDB() when there are no found
2141 // favicons. 1967 // favicons.
2142 TEST_F(HistoryBackendTest, GetFaviconsFromDBEmpty) { 1968 TEST_F(HistoryBackendTest, GetFaviconsFromDBEmpty) {
2143 const GURL page_url("http://www.google.com/"); 1969 const GURL page_url("http://www.google.com/");
2144 1970
2145 std::vector<FaviconBitmapResult> bitmap_results; 1971 std::vector<FaviconBitmapResult> bitmap_results;
2146 IconURLSizesMap icon_url_sizes;
2147 EXPECT_FALSE(backend_->GetFaviconsFromDB(page_url, FAVICON, 1972 EXPECT_FALSE(backend_->GetFaviconsFromDB(page_url, FAVICON,
2148 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results, 1973 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results));
2149 &icon_url_sizes));
2150 EXPECT_TRUE(bitmap_results.empty()); 1974 EXPECT_TRUE(bitmap_results.empty());
2151 EXPECT_TRUE(icon_url_sizes.empty());
2152 } 1975 }
2153 1976
2154 // Test the results of GetFaviconsFromDB() when there are matching favicons 1977 // Test the results of GetFaviconsFromDB() when there are matching favicons
2155 // but there are no associated favicon bitmaps. 1978 // but there are no associated favicon bitmaps.
2156 TEST_F(HistoryBackendTest, GetFaviconsFromDBNoFaviconBitmaps) { 1979 TEST_F(HistoryBackendTest, GetFaviconsFromDBNoFaviconBitmaps) {
2157 const GURL page_url("http://www.google.com/"); 1980 const GURL page_url("http://www.google.com/");
2158 const GURL icon_url("http://www.google.com/icon1"); 1981 const GURL icon_url("http://www.google.com/icon1");
2159 1982
2160 IconURLSizesMap icon_url_sizes; 1983 FaviconID icon_id = backend_->thumbnail_db_->AddFavicon(icon_url, FAVICON,
2161 icon_url_sizes[icon_url] = GetSizesSmallAndLarge(); 1984 GetSizesSmallAndLarge());
2162 1985 EXPECT_NE(0, icon_id);
2163 // No favicon bitmaps. 1986 EXPECT_NE(0, backend_->thumbnail_db_->AddIconMapping(page_url, icon_id));
2164 std::vector<FaviconBitmapData> favicon_bitmap_data;
2165
2166 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data,
2167 icon_url_sizes);
2168 1987
2169 std::vector<FaviconBitmapResult> bitmap_results_out; 1988 std::vector<FaviconBitmapResult> bitmap_results_out;
2170 IconURLSizesMap icon_url_sizes_out; 1989 EXPECT_FALSE(backend_->GetFaviconsFromDB(page_url, FAVICON,
2171 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON, kSmallSize.width(), 1990 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2172 GetScaleFactors1x2x(), &bitmap_results_out, &icon_url_sizes_out));
2173 EXPECT_TRUE(bitmap_results_out.empty()); 1991 EXPECT_TRUE(bitmap_results_out.empty());
2174 EXPECT_EQ(icon_url_sizes, icon_url_sizes_out);
2175 } 1992 }
2176 1993
2177 // Test that GetFaviconsFromDB() returns results for the bitmaps which most 1994 // Test that GetFaviconsFromDB() returns results for the bitmaps which most
2178 // closely match the passed in desired size and scale factors. 1995 // closely match the passed in desired size and scale factors.
2179 TEST_F(HistoryBackendTest, GetFaviconsFromDBSelectClosestMatch) { 1996 TEST_F(HistoryBackendTest, GetFaviconsFromDBSelectClosestMatch) {
2180 const GURL page_url("http://www.google.com/"); 1997 const GURL page_url("http://www.google.com/");
2181
2182 const GURL icon_url("http://www.google.com/icon1"); 1998 const GURL icon_url("http://www.google.com/icon1");
2183 IconURLSizesMap icon_url_sizes;
2184 icon_url_sizes[icon_url] = GetSizesTinySmallAndLarge();
2185 1999
2186 std::vector<FaviconBitmapData> favicon_bitmap_data; 2000 std::vector<FaviconBitmapData> favicon_bitmap_data;
2187 GenerateFaviconBitmapData(icon_url, GetSizesTinySmallAndLarge(), 2001 GenerateFaviconBitmapData(icon_url, GetSizesTinySmallAndLarge(),
2188 &favicon_bitmap_data); 2002 &favicon_bitmap_data);
2189 2003
2190 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 2004 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
2191 icon_url_sizes);
2192 2005
2193 std::vector<FaviconBitmapResult> bitmap_results_out; 2006 std::vector<FaviconBitmapResult> bitmap_results_out;
2194 IconURLSizesMap icon_url_sizes_out;
2195 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON, kSmallSize.width(), 2007 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON, kSmallSize.width(),
2196 GetScaleFactors1x2x(), &bitmap_results_out, &icon_url_sizes_out)); 2008 GetScaleFactors1x2x(), &bitmap_results_out));
2197 2009
2198 // The bitmap data for the 1x and 2x bitmaps should be returned as their sizes 2010 // The bitmap data for the small and large bitmaps should be returned as their
2199 // match exactly. 2011 // sizes match exactly.
2200
2201 EXPECT_EQ(2u, bitmap_results_out.size()); 2012 EXPECT_EQ(2u, bitmap_results_out.size());
2202 // No required order for results. 2013 // No required order for results.
2203 if (bitmap_results_out[0].pixel_size == kLargeSize) { 2014 if (bitmap_results_out[0].pixel_size == kLargeSize) {
2204 FaviconBitmapResult tmp_result = bitmap_results_out[0]; 2015 FaviconBitmapResult tmp_result = bitmap_results_out[0];
2205 bitmap_results_out[0] = bitmap_results_out[1]; 2016 bitmap_results_out[0] = bitmap_results_out[1];
2206 bitmap_results_out[1] = tmp_result; 2017 bitmap_results_out[1] = tmp_result;
2207 } 2018 }
2208 2019
2209 EXPECT_FALSE(bitmap_results_out[0].expired); 2020 EXPECT_FALSE(bitmap_results_out[0].expired);
2210 EXPECT_TRUE(BitmapDataEqual('b', bitmap_results_out[0].bitmap_data)); 2021 EXPECT_TRUE(BitmapDataEqual('b', bitmap_results_out[0].bitmap_data));
2211 EXPECT_EQ(kSmallSize, bitmap_results_out[0].pixel_size); 2022 EXPECT_EQ(kSmallSize, bitmap_results_out[0].pixel_size);
2212 EXPECT_EQ(icon_url, bitmap_results_out[0].icon_url); 2023 EXPECT_EQ(icon_url, bitmap_results_out[0].icon_url);
2213 EXPECT_EQ(FAVICON, bitmap_results_out[0].icon_type); 2024 EXPECT_EQ(FAVICON, bitmap_results_out[0].icon_type);
2214 2025
2215 EXPECT_FALSE(bitmap_results_out[1].expired); 2026 EXPECT_FALSE(bitmap_results_out[1].expired);
2216 EXPECT_TRUE(BitmapDataEqual('c', bitmap_results_out[1].bitmap_data)); 2027 EXPECT_TRUE(BitmapDataEqual('c', bitmap_results_out[1].bitmap_data));
2217 EXPECT_EQ(kLargeSize, bitmap_results_out[1].pixel_size); 2028 EXPECT_EQ(kLargeSize, bitmap_results_out[1].pixel_size);
2218 EXPECT_EQ(icon_url, bitmap_results_out[1].icon_url); 2029 EXPECT_EQ(icon_url, bitmap_results_out[1].icon_url);
2219 EXPECT_EQ(FAVICON, bitmap_results_out[1].icon_type); 2030 EXPECT_EQ(FAVICON, bitmap_results_out[1].icon_type);
2220
2221 EXPECT_EQ(icon_url_sizes, icon_url_sizes_out);
2222 } 2031 }
2223 2032
2224 // Test that GetFaviconsFromDB() returns results from the icon URL whose 2033 // Test that GetFaviconsFromDB() returns results from the icon URL whose
2225 // bitmaps most closely match the passed in desired size and scale factors. 2034 // bitmaps most closely match the passed in desired size and scale factors.
2226 TEST_F(HistoryBackendTest, GetFaviconsFromDBSingleIconURL) { 2035 TEST_F(HistoryBackendTest, GetFaviconsFromDBSingleIconURL) {
2227 const GURL page_url("http://www.google.com/"); 2036 const GURL page_url("http://www.google.com/");
2228 2037
2229 const GURL icon_url1("http://www.google.com/icon1"); 2038 const GURL icon_url1("http://www.google.com/icon1");
2230 const GURL icon_url2("http://www.google.com/icon2"); 2039 const GURL icon_url2("http://www.google.com/icon2");
2231 IconURLSizesMap icon_url_sizes;
2232 icon_url_sizes[icon_url1] = GetSizesSmall();
2233 icon_url_sizes[icon_url2] = GetSizesSmallAndLarge();
2234 2040
2235 std::vector<FaviconBitmapData> favicon_bitmap_data; 2041 std::vector<FaviconBitmapData> favicon_bitmap_data;
2236 GenerateFaviconBitmapData(icon_url1, GetSizesSmall(), icon_url2, 2042 GenerateFaviconBitmapData(icon_url1, GetSizesSmall(), icon_url2,
2237 GetSizesLarge(), &favicon_bitmap_data); 2043 GetSizesLarge(), &favicon_bitmap_data);
2238 2044
2239 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 2045 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
2240 icon_url_sizes);
2241 2046
2242 std::vector<FaviconBitmapResult> bitmap_results_out; 2047 std::vector<FaviconBitmapResult> bitmap_results_out;
2243 IconURLSizesMap icon_url_sizes_out;
2244 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON, kSmallSize.width(), 2048 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON, kSmallSize.width(),
2245 GetScaleFactors1x2x(), &bitmap_results_out, &icon_url_sizes_out)); 2049 GetScaleFactors1x2x(), &bitmap_results_out));
2246 2050
2247 // The results should have results for the icon URL with the large bitmap as 2051 // The results should have results for the icon URL with the large bitmap as
2248 // downscaling is preferred to upscaling. 2052 // downscaling is preferred to upscaling.
2249 EXPECT_EQ(1u, bitmap_results_out.size()); 2053 EXPECT_EQ(1u, bitmap_results_out.size());
2250 EXPECT_EQ(kLargeSize, bitmap_results_out[0].pixel_size); 2054 EXPECT_EQ(kLargeSize, bitmap_results_out[0].pixel_size);
2251 EXPECT_EQ(icon_url2, bitmap_results_out[0].icon_url); 2055 EXPECT_EQ(icon_url2, bitmap_results_out[0].icon_url);
2252
2253 EXPECT_EQ(icon_url_sizes, icon_url_sizes_out);
2254 } 2056 }
2255 2057
2256 // Test the results of GetFaviconsFromDB() when called with different 2058 // Test the results of GetFaviconsFromDB() when called with different
2257 // |icon_types|. 2059 // |icon_types|.
2258 TEST_F(HistoryBackendTest, GetFaviconsFromDBIconType) { 2060 TEST_F(HistoryBackendTest, GetFaviconsFromDBIconType) {
2259 const GURL page_url("http://www.google.com/"); 2061 const GURL page_url("http://www.google.com/");
2260 const GURL icon_url1("http://www.google.com/icon1.png"); 2062 const GURL icon_url1("http://www.google.com/icon1.png");
2261 const GURL icon_url2("http://www.google.com/icon2.png"); 2063 const GURL icon_url2("http://www.google.com/icon2.png");
2262 2064
2263 IconURLSizesMap icon_url_sizes;
2264 icon_url_sizes[icon_url1] = GetSizesSmall();
2265
2266 std::vector<FaviconBitmapData> favicon_bitmap_data; 2065 std::vector<FaviconBitmapData> favicon_bitmap_data;
2267 GenerateFaviconBitmapData(icon_url1, GetSizesSmall(), &favicon_bitmap_data); 2066 GenerateFaviconBitmapData(icon_url1, GetSizesSmall(), &favicon_bitmap_data);
2268 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data, 2067 backend_->SetFavicons(page_url, FAVICON, favicon_bitmap_data);
2269 icon_url_sizes);
2270 2068
2271 IconURLSizesMap touch_icon_url_sizes;
2272 touch_icon_url_sizes[icon_url2] = GetSizesSmall();
2273 GenerateFaviconBitmapData(icon_url2, GetSizesSmall(), &favicon_bitmap_data); 2069 GenerateFaviconBitmapData(icon_url2, GetSizesSmall(), &favicon_bitmap_data);
2274 backend_->SetFavicons(page_url, TOUCH_ICON, favicon_bitmap_data, 2070 backend_->SetFavicons(page_url, TOUCH_ICON, favicon_bitmap_data);
2275 touch_icon_url_sizes);
2276 2071
2277 std::vector<FaviconBitmapResult> bitmap_results_out; 2072 std::vector<FaviconBitmapResult> bitmap_results_out;
2278 IconURLSizesMap icon_url_sizes_out;
2279 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON, 2073 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON,
2280 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out, 2074 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2281 &icon_url_sizes_out));
2282 2075
2283 EXPECT_EQ(1u, bitmap_results_out.size()); 2076 EXPECT_EQ(1u, bitmap_results_out.size());
2284 EXPECT_EQ(FAVICON, bitmap_results_out[0].icon_type); 2077 EXPECT_EQ(FAVICON, bitmap_results_out[0].icon_type);
2285 EXPECT_EQ(icon_url_sizes, icon_url_sizes_out); 2078 EXPECT_EQ(icon_url1, bitmap_results_out[0].icon_url);
2286 2079
2287 bitmap_results_out.clear(); 2080 bitmap_results_out.clear();
2288 icon_url_sizes_out.clear();
2289 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, TOUCH_ICON, 2081 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, TOUCH_ICON,
2290 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out, 2082 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2291 &icon_url_sizes_out));
2292 2083
2293 EXPECT_EQ(1u, bitmap_results_out.size()); 2084 EXPECT_EQ(1u, bitmap_results_out.size());
2294 EXPECT_EQ(TOUCH_ICON, bitmap_results_out[0].icon_type); 2085 EXPECT_EQ(TOUCH_ICON, bitmap_results_out[0].icon_type);
2295 EXPECT_EQ(touch_icon_url_sizes, icon_url_sizes_out); 2086 EXPECT_EQ(icon_url2, bitmap_results_out[0].icon_url);
2296 } 2087 }
2297 2088
2298 // Test that GetFaviconsFromDB() correctly sets the expired flag for bitmap 2089 // Test that GetFaviconsFromDB() correctly sets the expired flag for bitmap
2299 // reults. 2090 // reults.
2300 TEST_F(HistoryBackendTest, GetFaviconsFromDBExpired) { 2091 TEST_F(HistoryBackendTest, GetFaviconsFromDBExpired) {
2301 const GURL page_url("http://www.google.com/"); 2092 const GURL page_url("http://www.google.com/");
2302 const GURL icon_url("http://www.google.com/icon.png"); 2093 const GURL icon_url("http://www.google.com/icon.png");
2303 2094
2304 std::vector<unsigned char> data; 2095 std::vector<unsigned char> data;
2305 data.push_back('a'); 2096 data.push_back('a');
2306 scoped_refptr<base::RefCountedBytes> bitmap_data( 2097 scoped_refptr<base::RefCountedBytes> bitmap_data(
2307 base::RefCountedBytes::TakeVector(&data)); 2098 base::RefCountedBytes::TakeVector(&data));
2308 base::Time last_updated = base::Time::FromTimeT(0); 2099 base::Time last_updated = base::Time::FromTimeT(0);
2309 FaviconID icon_id = backend_->thumbnail_db_->AddFavicon(icon_url, FAVICON, 2100 FaviconID icon_id = backend_->thumbnail_db_->AddFavicon(icon_url, FAVICON,
2310 GetSizesSmallAndLarge(), bitmap_data, last_updated, kSmallSize); 2101 GetSizesSmallAndLarge(), bitmap_data, last_updated, kSmallSize);
2311 EXPECT_NE(0, icon_id); 2102 EXPECT_NE(0, icon_id);
2312 EXPECT_NE(0, backend_->thumbnail_db_->AddIconMapping(page_url, icon_id)); 2103 EXPECT_NE(0, backend_->thumbnail_db_->AddIconMapping(page_url, icon_id));
2313 2104
2314 std::vector<FaviconBitmapResult> bitmap_results_out; 2105 std::vector<FaviconBitmapResult> bitmap_results_out;
2315 IconURLSizesMap icon_url_sizes_out;
2316 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON, 2106 EXPECT_TRUE(backend_->GetFaviconsFromDB(page_url, FAVICON,
2317 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out, 2107 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2318 &icon_url_sizes_out));
2319 2108
2320 EXPECT_EQ(1u, bitmap_results_out.size()); 2109 EXPECT_EQ(1u, bitmap_results_out.size());
2321 EXPECT_TRUE(bitmap_results_out[0].expired); 2110 EXPECT_TRUE(bitmap_results_out[0].expired);
2322 } 2111 }
2323 2112
2324 // Check that UpdateFaviconMappingsAndFetch() call back to the UI when there is 2113 // Check that UpdateFaviconMappingsAndFetch() call back to the UI when there is
2325 // no valid thumbnail database. 2114 // no valid thumbnail database.
2326 TEST_F(HistoryBackendTest, UpdateFaviconMappingsAndFetchNoDB) { 2115 TEST_F(HistoryBackendTest, UpdateFaviconMappingsAndFetchNoDB) {
2327 // Make the thumbnail database invalid. 2116 // Make the thumbnail database invalid.
2328 backend_->thumbnail_db_.reset(); 2117 backend_->thumbnail_db_.reset();
2329 2118
2330 HistoryBackend::FaviconResults results; 2119 std::vector<FaviconBitmapResult> bitmap_results;
2331 results.bitmap_results.push_back(FaviconBitmapResult());
2332 results.size_map[GURL()] = FaviconSizes();
2333 2120
2334 backend_->UpdateFaviconMappingsAndFetch( 2121 backend_->UpdateFaviconMappingsAndFetch(
2335 GURL(), std::vector<GURL>(), FAVICON, kSmallSize.width(), 2122 GURL(), std::vector<GURL>(), FAVICON, kSmallSize.width(),
2336 GetScaleFactors1x2x(), &results); 2123 GetScaleFactors1x2x(), &bitmap_results);
2337 2124
2338 EXPECT_TRUE(results.bitmap_results.empty()); 2125 EXPECT_TRUE(bitmap_results.empty());
2339 EXPECT_TRUE(results.size_map.empty());
2340 } 2126 }
2341 2127
2342 TEST_F(HistoryBackendTest, CloneFaviconIsRestrictedToSameDomain) { 2128 TEST_F(HistoryBackendTest, CloneFaviconIsRestrictedToSameDomain) {
2343 const GURL url("http://www.google.com/"); 2129 const GURL url("http://www.google.com/");
2344 const GURL same_domain_url("http://www.google.com/subdir/index.html"); 2130 const GURL same_domain_url("http://www.google.com/subdir/index.html");
2345 const GURL foreign_domain_url("http://www.not-google.com/"); 2131 const GURL foreign_domain_url("http://www.not-google.com/");
2346 const GURL icon_url("http://www.google.com/icon.png"); 2132 const GURL icon_url("http://www.google.com/icon.png");
2347 2133
2348 // Add a favicon 2134 // Add a favicon
2349 IconURLSizesMap icon_url_sizes;
2350 icon_url_sizes[icon_url] = GetSizesSmall();
2351
2352 std::vector<FaviconBitmapData> favicon_bitmap_data; 2135 std::vector<FaviconBitmapData> favicon_bitmap_data;
2353 GenerateFaviconBitmapData(icon_url, GetSizesSmall(), &favicon_bitmap_data); 2136 GenerateFaviconBitmapData(icon_url, GetSizesSmall(), &favicon_bitmap_data);
2354 backend_->SetFavicons(url, FAVICON, favicon_bitmap_data, icon_url_sizes); 2137 backend_->SetFavicons(url, FAVICON, favicon_bitmap_data);
2355 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL( 2138 EXPECT_TRUE(backend_->thumbnail_db_->GetIconMappingsForPageURL(
2356 url, FAVICON, NULL)); 2139 url, FAVICON, NULL));
2357 2140
2358 // Validate starting state. 2141 // Validate starting state.
2359 std::vector<FaviconBitmapResult> bitmap_results_out; 2142 std::vector<FaviconBitmapResult> bitmap_results_out;
2360 IconURLSizesMap icon_url_sizes_out;
2361 EXPECT_TRUE(backend_->GetFaviconsFromDB(url, FAVICON, 2143 EXPECT_TRUE(backend_->GetFaviconsFromDB(url, FAVICON,
2362 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out, 2144 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2363 &icon_url_sizes_out));
2364 EXPECT_FALSE(backend_->GetFaviconsFromDB(same_domain_url, FAVICON, 2145 EXPECT_FALSE(backend_->GetFaviconsFromDB(same_domain_url, FAVICON,
2365 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out, 2146 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2366 &icon_url_sizes_out));
2367 EXPECT_FALSE(backend_->GetFaviconsFromDB(foreign_domain_url, FAVICON, 2147 EXPECT_FALSE(backend_->GetFaviconsFromDB(foreign_domain_url, FAVICON,
2368 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out, 2148 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2369 &icon_url_sizes_out));
2370 2149
2371 // Same-domain cloning should work. 2150 // Same-domain cloning should work.
2372 backend_->CloneFavicons(url, same_domain_url); 2151 backend_->CloneFavicons(url, same_domain_url);
2373 EXPECT_TRUE(backend_->GetFaviconsFromDB(same_domain_url, FAVICON, 2152 EXPECT_TRUE(backend_->GetFaviconsFromDB(same_domain_url, FAVICON,
2374 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out, 2153 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2375 &icon_url_sizes_out));
2376 2154
2377 // Foreign-domain cloning is forbidden. 2155 // Foreign-domain cloning is forbidden.
2378 backend_->CloneFavicons(url, foreign_domain_url); 2156 backend_->CloneFavicons(url, foreign_domain_url);
2379 EXPECT_FALSE(backend_->GetFaviconsFromDB(foreign_domain_url, FAVICON, 2157 EXPECT_FALSE(backend_->GetFaviconsFromDB(foreign_domain_url, FAVICON,
2380 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out, 2158 kSmallSize.width(), GetScaleFactors1x2x(), &bitmap_results_out));
2381 &icon_url_sizes_out));
2382 } 2159 }
2383 2160
2384 TEST_F(HistoryBackendTest, QueryFilteredURLs) { 2161 TEST_F(HistoryBackendTest, QueryFilteredURLs) {
2385 const char* google = "http://www.google.com/"; 2162 const char* google = "http://www.google.com/";
2386 const char* yahoo = "http://www.yahoo.com/"; 2163 const char* yahoo = "http://www.yahoo.com/";
2387 const char* yahoo_sports = "http://sports.yahoo.com/"; 2164 const char* yahoo_sports = "http://sports.yahoo.com/";
2388 const char* yahoo_sports_with_article1 = 2165 const char* yahoo_sports_with_article1 =
2389 "http://sports.yahoo.com/article1.htm"; 2166 "http://sports.yahoo.com/article1.htm";
2390 const char* yahoo_sports_with_article2 = 2167 const char* yahoo_sports_with_article2 =
2391 "http://sports.yahoo.com/article2.htm"; 2168 "http://sports.yahoo.com/article2.htm";
(...skipping 347 matching lines...) Expand 10 before | Expand all | Expand 10 after
2739 backend_->GetFirstRecordedTimeForTest()); 2516 backend_->GetFirstRecordedTimeForTest());
2740 2517
2741 EXPECT_FALSE(backend_->GetURL(args[0].url, &row)); 2518 EXPECT_FALSE(backend_->GetURL(args[0].url, &row));
2742 EXPECT_TRUE(backend_->GetURL(args[1].url, &row)); 2519 EXPECT_TRUE(backend_->GetURL(args[1].url, &row));
2743 EXPECT_FALSE(backend_->GetURL(args[2].url, &row)); 2520 EXPECT_FALSE(backend_->GetURL(args[2].url, &row));
2744 EXPECT_TRUE(backend_->GetURL(args[3].url, &row)); 2521 EXPECT_TRUE(backend_->GetURL(args[3].url, &row));
2745 EXPECT_FALSE(backend_->GetURL(args[4].url, &row)); 2522 EXPECT_FALSE(backend_->GetURL(args[4].url, &row));
2746 } 2523 }
2747 2524
2748 } // namespace history 2525 } // namespace history
OLDNEW
« no previous file with comments | « chrome/browser/history/history_backend.cc ('k') | chrome/browser/history/history_types.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698