Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "base/memory/scoped_ptr.h" | 5 #include "base/memory/scoped_ptr.h" |
| 6 #include "chrome/browser/favicon/favicon_handler.h" | 6 #include "chrome/browser/favicon/favicon_handler.h" |
| 7 #include "chrome/browser/favicon/favicon_service_factory.h" | 7 #include "chrome/browser/favicon/favicon_service_factory.h" |
| 8 #include "chrome/browser/history/history_service_factory.h" | 8 #include "chrome/browser/history/history_service_factory.h" |
| 9 #include "chrome/browser/profiles/profile.h" | 9 #include "chrome/browser/profiles/profile.h" |
| 10 #include "chrome/test/base/chrome_render_view_host_test_harness.h" | 10 #include "chrome/test/base/chrome_render_view_host_test_harness.h" |
| 11 #include "components/favicon/content/content_favicon_driver.h" | |
| 11 #include "content/public/browser/favicon_status.h" | 12 #include "content/public/browser/favicon_status.h" |
| 12 #include "content/public/browser/invalidate_type.h" | 13 #include "content/public/browser/invalidate_type.h" |
| 13 #include "content/public/browser/navigation_entry.h" | 14 #include "content/public/browser/navigation_entry.h" |
| 14 #include "content/public/browser/web_contents.h" | 15 #include "content/public/browser/web_contents.h" |
| 15 #include "third_party/skia/include/core/SkBitmap.h" | 16 #include "third_party/skia/include/core/SkBitmap.h" |
| 16 #include "ui/gfx/codec/png_codec.h" | 17 #include "ui/gfx/codec/png_codec.h" |
| 17 #include "ui/gfx/favicon_size.h" | 18 #include "ui/gfx/favicon_size.h" |
| 18 #include "ui/gfx/image/image.h" | 19 #include "ui/gfx/image/image.h" |
| 19 | 20 |
| 20 class TestFaviconHandler; | 21 class TestFaviconHandler; |
| (...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 160 const std::vector<unsigned char> bitmap_data_; | 161 const std::vector<unsigned char> bitmap_data_; |
| 161 std::vector<chrome::FaviconBitmapResult> history_results_; | 162 std::vector<chrome::FaviconBitmapResult> history_results_; |
| 162 FaviconService::FaviconResultsCallback callback_; | 163 FaviconService::FaviconResultsCallback callback_; |
| 163 | 164 |
| 164 private: | 165 private: |
| 165 DISALLOW_COPY_AND_ASSIGN(HistoryRequestHandler); | 166 DISALLOW_COPY_AND_ASSIGN(HistoryRequestHandler); |
| 166 }; | 167 }; |
| 167 | 168 |
| 168 } // namespace | 169 } // namespace |
| 169 | 170 |
| 171 class MockFaviconDriver : public FaviconDriver { | |
|
blundell
2014/04/08 10:01:19
s/Mock/Test
jif
2014/04/08 11:55:47
Done.
| |
| 172 virtual bool IsOffTheRecord() OVERRIDE { return false; } | |
| 173 }; | |
| 170 | 174 |
| 171 class TestFaviconHandlerDelegate : public FaviconHandlerDelegate { | 175 class TestFaviconHandlerDelegate : public FaviconHandlerDelegate { |
| 172 public: | 176 public: |
| 173 TestFaviconHandlerDelegate() { | 177 TestFaviconHandlerDelegate() { |
| 174 } | 178 } |
| 175 | 179 |
| 176 virtual ~TestFaviconHandlerDelegate() { | 180 virtual ~TestFaviconHandlerDelegate() { |
| 177 } | 181 } |
| 178 | 182 |
| 179 virtual NavigationEntry* GetActiveEntry() OVERRIDE { | 183 virtual NavigationEntry* GetActiveEntry() OVERRIDE { |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 198 DISALLOW_COPY_AND_ASSIGN(TestFaviconHandlerDelegate); | 202 DISALLOW_COPY_AND_ASSIGN(TestFaviconHandlerDelegate); |
| 199 }; | 203 }; |
| 200 | 204 |
| 201 // This class is used to catch the FaviconHandler's download and history | 205 // This class is used to catch the FaviconHandler's download and history |
| 202 // request, and also provide the methods to access the FaviconHandler | 206 // request, and also provide the methods to access the FaviconHandler |
| 203 // internals. | 207 // internals. |
| 204 class TestFaviconHandler : public FaviconHandler { | 208 class TestFaviconHandler : public FaviconHandler { |
| 205 public: | 209 public: |
| 206 TestFaviconHandler(const GURL& page_url, | 210 TestFaviconHandler(const GURL& page_url, |
| 207 Profile* profile, | 211 Profile* profile, |
| 212 FaviconDriver* driver, | |
| 208 FaviconHandlerDelegate* delegate, | 213 FaviconHandlerDelegate* delegate, |
| 209 Type type) | 214 Type type) |
| 210 : FaviconHandler(profile, delegate, type), | 215 : FaviconHandler(profile, driver, delegate, type), |
| 211 entry_(NavigationEntry::Create()), | 216 entry_(NavigationEntry::Create()), |
| 212 download_id_(0), | 217 download_id_(0), |
| 213 num_favicon_updates_(0) { | 218 num_favicon_updates_(0) { |
| 214 entry_->SetURL(page_url); | 219 entry_->SetURL(page_url); |
| 215 download_handler_.reset(new DownloadHandler(this)); | 220 download_handler_.reset(new DownloadHandler(this)); |
| 216 } | 221 } |
| 217 | 222 |
| 218 virtual ~TestFaviconHandler() { | 223 virtual ~TestFaviconHandler() { |
| 219 } | 224 } |
| 220 | 225 |
| (...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 430 ScopedSetSupportedScaleFactors; | 435 ScopedSetSupportedScaleFactors; |
| 431 ScopedSetSupportedScaleFactors scoped_set_supported_scale_factors_; | 436 ScopedSetSupportedScaleFactors scoped_set_supported_scale_factors_; |
| 432 DISALLOW_COPY_AND_ASSIGN(FaviconHandlerTest); | 437 DISALLOW_COPY_AND_ASSIGN(FaviconHandlerTest); |
| 433 }; | 438 }; |
| 434 | 439 |
| 435 TEST_F(FaviconHandlerTest, GetFaviconFromHistory) { | 440 TEST_F(FaviconHandlerTest, GetFaviconFromHistory) { |
| 436 const GURL page_url("http://www.google.com"); | 441 const GURL page_url("http://www.google.com"); |
| 437 const GURL icon_url("http://www.google.com/favicon"); | 442 const GURL icon_url("http://www.google.com/favicon"); |
| 438 | 443 |
| 439 TestFaviconHandlerDelegate delegate; | 444 TestFaviconHandlerDelegate delegate; |
| 445 MockFaviconDriver driver; | |
| 440 Profile* profile = Profile::FromBrowserContext( | 446 Profile* profile = Profile::FromBrowserContext( |
| 441 web_contents()->GetBrowserContext()); | 447 web_contents()->GetBrowserContext()); |
| 442 TestFaviconHandler helper(page_url, profile, | 448 TestFaviconHandler helper( |
| 443 &delegate, FaviconHandler::FAVICON); | 449 page_url, profile, &driver, &delegate, FaviconHandler::FAVICON); |
| 444 | 450 |
| 445 helper.FetchFavicon(page_url); | 451 helper.FetchFavicon(page_url); |
| 446 HistoryRequestHandler* history_handler = helper.history_handler(); | 452 HistoryRequestHandler* history_handler = helper.history_handler(); |
| 447 // Ensure the data given to history is correct. | 453 // Ensure the data given to history is correct. |
| 448 ASSERT_TRUE(history_handler); | 454 ASSERT_TRUE(history_handler); |
| 449 EXPECT_EQ(page_url, history_handler->page_url_); | 455 EXPECT_EQ(page_url, history_handler->page_url_); |
| 450 EXPECT_EQ(GURL(), history_handler->icon_url_); | 456 EXPECT_EQ(GURL(), history_handler->icon_url_); |
| 451 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); | 457 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); |
| 452 | 458 |
| 453 SetFaviconBitmapResult(icon_url, &history_handler->history_results_); | 459 SetFaviconBitmapResult(icon_url, &history_handler->history_results_); |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 472 | 478 |
| 473 // Favicon shouldn't request to download icon. | 479 // Favicon shouldn't request to download icon. |
| 474 EXPECT_FALSE(helper.download_handler()->HasDownload()); | 480 EXPECT_FALSE(helper.download_handler()->HasDownload()); |
| 475 } | 481 } |
| 476 | 482 |
| 477 TEST_F(FaviconHandlerTest, DownloadFavicon) { | 483 TEST_F(FaviconHandlerTest, DownloadFavicon) { |
| 478 const GURL page_url("http://www.google.com"); | 484 const GURL page_url("http://www.google.com"); |
| 479 const GURL icon_url("http://www.google.com/favicon"); | 485 const GURL icon_url("http://www.google.com/favicon"); |
| 480 | 486 |
| 481 TestFaviconHandlerDelegate delegate; | 487 TestFaviconHandlerDelegate delegate; |
| 488 MockFaviconDriver driver; | |
| 482 Profile* profile = Profile::FromBrowserContext( | 489 Profile* profile = Profile::FromBrowserContext( |
| 483 web_contents()->GetBrowserContext()); | 490 web_contents()->GetBrowserContext()); |
| 484 TestFaviconHandler helper(page_url, profile, | 491 TestFaviconHandler helper( |
| 485 &delegate, FaviconHandler::FAVICON); | 492 page_url, profile, &driver, &delegate, FaviconHandler::FAVICON); |
| 486 | 493 |
| 487 helper.FetchFavicon(page_url); | 494 helper.FetchFavicon(page_url); |
| 488 HistoryRequestHandler* history_handler = helper.history_handler(); | 495 HistoryRequestHandler* history_handler = helper.history_handler(); |
| 489 // Ensure the data given to history is correct. | 496 // Ensure the data given to history is correct. |
| 490 ASSERT_TRUE(history_handler); | 497 ASSERT_TRUE(history_handler); |
| 491 EXPECT_EQ(page_url, history_handler->page_url_); | 498 EXPECT_EQ(page_url, history_handler->page_url_); |
| 492 EXPECT_EQ(GURL(), history_handler->icon_url_); | 499 EXPECT_EQ(GURL(), history_handler->icon_url_); |
| 493 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); | 500 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); |
| 494 | 501 |
| 495 // Set icon data expired | 502 // Set icon data expired |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 541 EXPECT_FALSE(favicon_status.image.IsEmpty()); | 548 EXPECT_FALSE(favicon_status.image.IsEmpty()); |
| 542 EXPECT_EQ(gfx::kFaviconSize, favicon_status.image.Width()); | 549 EXPECT_EQ(gfx::kFaviconSize, favicon_status.image.Width()); |
| 543 } | 550 } |
| 544 | 551 |
| 545 TEST_F(FaviconHandlerTest, UpdateAndDownloadFavicon) { | 552 TEST_F(FaviconHandlerTest, UpdateAndDownloadFavicon) { |
| 546 const GURL page_url("http://www.google.com"); | 553 const GURL page_url("http://www.google.com"); |
| 547 const GURL icon_url("http://www.google.com/favicon"); | 554 const GURL icon_url("http://www.google.com/favicon"); |
| 548 const GURL new_icon_url("http://www.google.com/new_favicon"); | 555 const GURL new_icon_url("http://www.google.com/new_favicon"); |
| 549 | 556 |
| 550 TestFaviconHandlerDelegate delegate; | 557 TestFaviconHandlerDelegate delegate; |
| 558 MockFaviconDriver driver; | |
| 551 Profile* profile = Profile::FromBrowserContext( | 559 Profile* profile = Profile::FromBrowserContext( |
| 552 web_contents()->GetBrowserContext()); | 560 web_contents()->GetBrowserContext()); |
| 553 TestFaviconHandler helper(page_url, profile, | 561 TestFaviconHandler helper( |
| 554 &delegate, FaviconHandler::FAVICON); | 562 page_url, profile, &driver, &delegate, FaviconHandler::FAVICON); |
| 555 | 563 |
| 556 helper.FetchFavicon(page_url); | 564 helper.FetchFavicon(page_url); |
| 557 HistoryRequestHandler* history_handler = helper.history_handler(); | 565 HistoryRequestHandler* history_handler = helper.history_handler(); |
| 558 // Ensure the data given to history is correct. | 566 // Ensure the data given to history is correct. |
| 559 ASSERT_TRUE(history_handler); | 567 ASSERT_TRUE(history_handler); |
| 560 EXPECT_EQ(page_url, history_handler->page_url_); | 568 EXPECT_EQ(page_url, history_handler->page_url_); |
| 561 EXPECT_EQ(GURL(), history_handler->icon_url_); | 569 EXPECT_EQ(GURL(), history_handler->icon_url_); |
| 562 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); | 570 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); |
| 563 | 571 |
| 564 // Set valid icon data. | 572 // Set valid icon data. |
| (...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 624 EXPECT_TRUE(favicon_status.valid); | 632 EXPECT_TRUE(favicon_status.valid); |
| 625 EXPECT_FALSE(favicon_status.image.IsEmpty()); | 633 EXPECT_FALSE(favicon_status.image.IsEmpty()); |
| 626 EXPECT_EQ(gfx::kFaviconSize, favicon_status.image.Width()); | 634 EXPECT_EQ(gfx::kFaviconSize, favicon_status.image.Width()); |
| 627 } | 635 } |
| 628 | 636 |
| 629 TEST_F(FaviconHandlerTest, FaviconInHistoryInvalid) { | 637 TEST_F(FaviconHandlerTest, FaviconInHistoryInvalid) { |
| 630 const GURL page_url("http://www.google.com"); | 638 const GURL page_url("http://www.google.com"); |
| 631 const GURL icon_url("http://www.google.com/favicon"); | 639 const GURL icon_url("http://www.google.com/favicon"); |
| 632 | 640 |
| 633 TestFaviconHandlerDelegate delegate; | 641 TestFaviconHandlerDelegate delegate; |
| 642 MockFaviconDriver driver; | |
| 634 Profile* profile = Profile::FromBrowserContext( | 643 Profile* profile = Profile::FromBrowserContext( |
| 635 web_contents()->GetBrowserContext()); | 644 web_contents()->GetBrowserContext()); |
| 636 TestFaviconHandler helper(page_url, profile, | 645 TestFaviconHandler helper( |
| 637 &delegate, FaviconHandler::FAVICON); | 646 page_url, profile, &driver, &delegate, FaviconHandler::FAVICON); |
| 638 | 647 |
| 639 helper.FetchFavicon(page_url); | 648 helper.FetchFavicon(page_url); |
| 640 HistoryRequestHandler* history_handler = helper.history_handler(); | 649 HistoryRequestHandler* history_handler = helper.history_handler(); |
| 641 // Ensure the data given to history is correct. | 650 // Ensure the data given to history is correct. |
| 642 ASSERT_TRUE(history_handler); | 651 ASSERT_TRUE(history_handler); |
| 643 EXPECT_EQ(page_url, history_handler->page_url_); | 652 EXPECT_EQ(page_url, history_handler->page_url_); |
| 644 EXPECT_EQ(GURL(), history_handler->icon_url_); | 653 EXPECT_EQ(GURL(), history_handler->icon_url_); |
| 645 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); | 654 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); |
| 646 | 655 |
| 647 // Set non empty but invalid data. | 656 // Set non empty but invalid data. |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 698 EXPECT_FALSE(favicon_status.image.IsEmpty()); | 707 EXPECT_FALSE(favicon_status.image.IsEmpty()); |
| 699 EXPECT_EQ(gfx::kFaviconSize, favicon_status.image.Width()); | 708 EXPECT_EQ(gfx::kFaviconSize, favicon_status.image.Width()); |
| 700 } | 709 } |
| 701 | 710 |
| 702 TEST_F(FaviconHandlerTest, UpdateFavicon) { | 711 TEST_F(FaviconHandlerTest, UpdateFavicon) { |
| 703 const GURL page_url("http://www.google.com"); | 712 const GURL page_url("http://www.google.com"); |
| 704 const GURL icon_url("http://www.google.com/favicon"); | 713 const GURL icon_url("http://www.google.com/favicon"); |
| 705 const GURL new_icon_url("http://www.google.com/new_favicon"); | 714 const GURL new_icon_url("http://www.google.com/new_favicon"); |
| 706 | 715 |
| 707 TestFaviconHandlerDelegate delegate; | 716 TestFaviconHandlerDelegate delegate; |
| 717 MockFaviconDriver driver; | |
| 708 Profile* profile = Profile::FromBrowserContext( | 718 Profile* profile = Profile::FromBrowserContext( |
| 709 web_contents()->GetBrowserContext()); | 719 web_contents()->GetBrowserContext()); |
| 710 TestFaviconHandler helper(page_url, profile, | 720 TestFaviconHandler helper( |
| 711 &delegate, FaviconHandler::FAVICON); | 721 page_url, profile, &driver, &delegate, FaviconHandler::FAVICON); |
| 712 | 722 |
| 713 helper.FetchFavicon(page_url); | 723 helper.FetchFavicon(page_url); |
| 714 HistoryRequestHandler* history_handler = helper.history_handler(); | 724 HistoryRequestHandler* history_handler = helper.history_handler(); |
| 715 // Ensure the data given to history is correct. | 725 // Ensure the data given to history is correct. |
| 716 ASSERT_TRUE(history_handler); | 726 ASSERT_TRUE(history_handler); |
| 717 EXPECT_EQ(page_url, history_handler->page_url_); | 727 EXPECT_EQ(page_url, history_handler->page_url_); |
| 718 EXPECT_EQ(GURL(), history_handler->icon_url_); | 728 EXPECT_EQ(GURL(), history_handler->icon_url_); |
| 719 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); | 729 EXPECT_EQ(chrome::FAVICON, history_handler->icon_type_); |
| 720 | 730 |
| 721 SetFaviconBitmapResult(icon_url, &history_handler->history_results_); | 731 SetFaviconBitmapResult(icon_url, &history_handler->history_results_); |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 761 EXPECT_TRUE(helper.GetEntry()->GetFavicon().valid); | 771 EXPECT_TRUE(helper.GetEntry()->GetFavicon().valid); |
| 762 EXPECT_FALSE(helper.GetEntry()->GetFavicon().image.IsEmpty()); | 772 EXPECT_FALSE(helper.GetEntry()->GetFavicon().image.IsEmpty()); |
| 763 } | 773 } |
| 764 | 774 |
| 765 TEST_F(FaviconHandlerTest, Download2ndFaviconURLCandidate) { | 775 TEST_F(FaviconHandlerTest, Download2ndFaviconURLCandidate) { |
| 766 const GURL page_url("http://www.google.com"); | 776 const GURL page_url("http://www.google.com"); |
| 767 const GURL icon_url("http://www.google.com/favicon"); | 777 const GURL icon_url("http://www.google.com/favicon"); |
| 768 const GURL new_icon_url("http://www.google.com/new_favicon"); | 778 const GURL new_icon_url("http://www.google.com/new_favicon"); |
| 769 | 779 |
| 770 TestFaviconHandlerDelegate delegate; | 780 TestFaviconHandlerDelegate delegate; |
| 781 MockFaviconDriver driver; | |
| 771 Profile* profile = Profile::FromBrowserContext( | 782 Profile* profile = Profile::FromBrowserContext( |
| 772 web_contents()->GetBrowserContext()); | 783 web_contents()->GetBrowserContext()); |
| 773 TestFaviconHandler helper(page_url, profile, | 784 TestFaviconHandler helper( |
| 774 &delegate, FaviconHandler::TOUCH); | 785 page_url, profile, &driver, &delegate, FaviconHandler::TOUCH); |
| 775 | 786 |
| 776 helper.FetchFavicon(page_url); | 787 helper.FetchFavicon(page_url); |
| 777 HistoryRequestHandler* history_handler = helper.history_handler(); | 788 HistoryRequestHandler* history_handler = helper.history_handler(); |
| 778 // Ensure the data given to history is correct. | 789 // Ensure the data given to history is correct. |
| 779 ASSERT_TRUE(history_handler); | 790 ASSERT_TRUE(history_handler); |
| 780 EXPECT_EQ(page_url, history_handler->page_url_); | 791 EXPECT_EQ(page_url, history_handler->page_url_); |
| 781 EXPECT_EQ(GURL(), history_handler->icon_url_); | 792 EXPECT_EQ(GURL(), history_handler->icon_url_); |
| 782 EXPECT_EQ(chrome::TOUCH_PRECOMPOSED_ICON | chrome::TOUCH_ICON, | 793 EXPECT_EQ(chrome::TOUCH_PRECOMPOSED_ICON | chrome::TOUCH_ICON, |
| 783 history_handler->icon_type_); | 794 history_handler->icon_type_); |
| 784 | 795 |
| (...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 874 EXPECT_LT(0U, history_handler->bitmap_data_.size()); | 885 EXPECT_LT(0U, history_handler->bitmap_data_.size()); |
| 875 EXPECT_EQ(page_url, history_handler->page_url_); | 886 EXPECT_EQ(page_url, history_handler->page_url_); |
| 876 } | 887 } |
| 877 | 888 |
| 878 TEST_F(FaviconHandlerTest, UpdateDuringDownloading) { | 889 TEST_F(FaviconHandlerTest, UpdateDuringDownloading) { |
| 879 const GURL page_url("http://www.google.com"); | 890 const GURL page_url("http://www.google.com"); |
| 880 const GURL icon_url("http://www.google.com/favicon"); | 891 const GURL icon_url("http://www.google.com/favicon"); |
| 881 const GURL new_icon_url("http://www.google.com/new_favicon"); | 892 const GURL new_icon_url("http://www.google.com/new_favicon"); |
| 882 | 893 |
| 883 TestFaviconHandlerDelegate delegate; | 894 TestFaviconHandlerDelegate delegate; |
| 895 MockFaviconDriver driver; | |
| 884 Profile* profile = Profile::FromBrowserContext( | 896 Profile* profile = Profile::FromBrowserContext( |
| 885 web_contents()->GetBrowserContext()); | 897 web_contents()->GetBrowserContext()); |
| 886 TestFaviconHandler helper(page_url, profile, | 898 TestFaviconHandler helper( |
| 887 &delegate, FaviconHandler::TOUCH); | 899 page_url, profile, &driver, &delegate, FaviconHandler::TOUCH); |
| 888 | 900 |
| 889 helper.FetchFavicon(page_url); | 901 helper.FetchFavicon(page_url); |
| 890 HistoryRequestHandler* history_handler = helper.history_handler(); | 902 HistoryRequestHandler* history_handler = helper.history_handler(); |
| 891 // Ensure the data given to history is correct. | 903 // Ensure the data given to history is correct. |
| 892 ASSERT_TRUE(history_handler); | 904 ASSERT_TRUE(history_handler); |
| 893 EXPECT_EQ(page_url, history_handler->page_url_); | 905 EXPECT_EQ(page_url, history_handler->page_url_); |
| 894 EXPECT_EQ(GURL(), history_handler->icon_url_); | 906 EXPECT_EQ(GURL(), history_handler->icon_url_); |
| 895 EXPECT_EQ(chrome::TOUCH_PRECOMPOSED_ICON | chrome::TOUCH_ICON, | 907 EXPECT_EQ(chrome::TOUCH_PRECOMPOSED_ICON | chrome::TOUCH_ICON, |
| 896 history_handler->icon_type_); | 908 history_handler->icon_type_); |
| 897 | 909 |
| (...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1018 scale_factors.push_back(ui::SCALE_FACTOR_100P); | 1030 scale_factors.push_back(ui::SCALE_FACTOR_100P); |
| 1019 scale_factors.push_back(ui::SCALE_FACTOR_200P); | 1031 scale_factors.push_back(ui::SCALE_FACTOR_200P); |
| 1020 ui::test::ScopedSetSupportedScaleFactors scoped_supported(scale_factors); | 1032 ui::test::ScopedSetSupportedScaleFactors scoped_supported(scale_factors); |
| 1021 | 1033 |
| 1022 Profile* profile = Profile::FromBrowserContext( | 1034 Profile* profile = Profile::FromBrowserContext( |
| 1023 web_contents()->GetBrowserContext()); | 1035 web_contents()->GetBrowserContext()); |
| 1024 | 1036 |
| 1025 // 1) Test that if there are several single resolution favicons to choose from | 1037 // 1) Test that if there are several single resolution favicons to choose from |
| 1026 // that the largest exact match is chosen. | 1038 // that the largest exact match is chosen. |
| 1027 TestFaviconHandlerDelegate delegate1; | 1039 TestFaviconHandlerDelegate delegate1; |
| 1028 TestFaviconHandler handler1(kPageURL, profile, | 1040 MockFaviconDriver driver; |
| 1029 &delegate1, FaviconHandler::FAVICON); | 1041 TestFaviconHandler handler1( |
| 1042 kPageURL, profile, &driver, &delegate1, FaviconHandler::FAVICON); | |
| 1030 const int kSizes1[] = { 16, 24, 32, 48, 256 }; | 1043 const int kSizes1[] = { 16, 24, 32, 48, 256 }; |
| 1031 std::vector<FaviconURL> urls1(kSourceIconURLs, | 1044 std::vector<FaviconURL> urls1(kSourceIconURLs, |
| 1032 kSourceIconURLs + arraysize(kSizes1)); | 1045 kSourceIconURLs + arraysize(kSizes1)); |
| 1033 DownloadTillDoneIgnoringHistory(&handler1, kPageURL, urls1, kSizes1); | 1046 DownloadTillDoneIgnoringHistory(&handler1, kPageURL, urls1, kSizes1); |
| 1034 | 1047 |
| 1035 content::FaviconStatus favicon_status1(handler1.GetEntry()->GetFavicon()); | 1048 content::FaviconStatus favicon_status1(handler1.GetEntry()->GetFavicon()); |
| 1036 EXPECT_EQ(0u, handler1.image_urls().size()); | 1049 EXPECT_EQ(0u, handler1.image_urls().size()); |
| 1037 EXPECT_TRUE(favicon_status1.valid); | 1050 EXPECT_TRUE(favicon_status1.valid); |
| 1038 EXPECT_FALSE(favicon_status1.image.IsEmpty()); | 1051 EXPECT_FALSE(favicon_status1.image.IsEmpty()); |
| 1039 EXPECT_EQ(gfx::kFaviconSize, favicon_status1.image.Width()); | 1052 EXPECT_EQ(gfx::kFaviconSize, favicon_status1.image.Width()); |
| 1040 | 1053 |
| 1041 size_t expected_index = 2u; | 1054 size_t expected_index = 2u; |
| 1042 EXPECT_EQ(32, kSizes1[expected_index]); | 1055 EXPECT_EQ(32, kSizes1[expected_index]); |
| 1043 EXPECT_EQ(kSourceIconURLs[expected_index].icon_url, | 1056 EXPECT_EQ(kSourceIconURLs[expected_index].icon_url, |
| 1044 handler1.GetEntry()->GetFavicon().url); | 1057 handler1.GetEntry()->GetFavicon().url); |
| 1045 | 1058 |
| 1046 // 2) Test that if there are several single resolution favicons to choose | 1059 // 2) Test that if there are several single resolution favicons to choose |
| 1047 // from, the exact match is preferred even if it results in upsampling. | 1060 // from, the exact match is preferred even if it results in upsampling. |
| 1048 TestFaviconHandlerDelegate delegate2; | 1061 TestFaviconHandlerDelegate delegate2; |
| 1049 TestFaviconHandler handler2(kPageURL, profile, | 1062 TestFaviconHandler handler2( |
| 1050 &delegate2, FaviconHandler::FAVICON); | 1063 kPageURL, profile, &driver, &delegate2, FaviconHandler::FAVICON); |
| 1051 const int kSizes2[] = { 16, 24, 48, 256 }; | 1064 const int kSizes2[] = { 16, 24, 48, 256 }; |
| 1052 std::vector<FaviconURL> urls2(kSourceIconURLs, | 1065 std::vector<FaviconURL> urls2(kSourceIconURLs, |
| 1053 kSourceIconURLs + arraysize(kSizes2)); | 1066 kSourceIconURLs + arraysize(kSizes2)); |
| 1054 DownloadTillDoneIgnoringHistory(&handler2, kPageURL, urls2, kSizes2); | 1067 DownloadTillDoneIgnoringHistory(&handler2, kPageURL, urls2, kSizes2); |
| 1055 EXPECT_TRUE(handler2.GetEntry()->GetFavicon().valid); | 1068 EXPECT_TRUE(handler2.GetEntry()->GetFavicon().valid); |
| 1056 expected_index = 0u; | 1069 expected_index = 0u; |
| 1057 EXPECT_EQ(16, kSizes2[expected_index]); | 1070 EXPECT_EQ(16, kSizes2[expected_index]); |
| 1058 EXPECT_EQ(kSourceIconURLs[expected_index].icon_url, | 1071 EXPECT_EQ(kSourceIconURLs[expected_index].icon_url, |
| 1059 handler2.GetEntry()->GetFavicon().url); | 1072 handler2.GetEntry()->GetFavicon().url); |
| 1060 | 1073 |
| 1061 // 3) Test that favicons which need to be upsampled a little or downsampled | 1074 // 3) Test that favicons which need to be upsampled a little or downsampled |
| 1062 // a little are preferred over huge favicons. | 1075 // a little are preferred over huge favicons. |
| 1063 TestFaviconHandlerDelegate delegate3; | 1076 TestFaviconHandlerDelegate delegate3; |
| 1064 TestFaviconHandler handler3(kPageURL, profile, | 1077 TestFaviconHandler handler3( |
| 1065 &delegate3, FaviconHandler::FAVICON); | 1078 kPageURL, profile, &driver, &delegate3, FaviconHandler::FAVICON); |
| 1066 const int kSizes3[] = { 256, 48 }; | 1079 const int kSizes3[] = { 256, 48 }; |
| 1067 std::vector<FaviconURL> urls3(kSourceIconURLs, | 1080 std::vector<FaviconURL> urls3(kSourceIconURLs, |
| 1068 kSourceIconURLs + arraysize(kSizes3)); | 1081 kSourceIconURLs + arraysize(kSizes3)); |
| 1069 DownloadTillDoneIgnoringHistory(&handler3, kPageURL, urls3, kSizes3); | 1082 DownloadTillDoneIgnoringHistory(&handler3, kPageURL, urls3, kSizes3); |
| 1070 EXPECT_TRUE(handler3.GetEntry()->GetFavicon().valid); | 1083 EXPECT_TRUE(handler3.GetEntry()->GetFavicon().valid); |
| 1071 expected_index = 1u; | 1084 expected_index = 1u; |
| 1072 EXPECT_EQ(48, kSizes3[expected_index]); | 1085 EXPECT_EQ(48, kSizes3[expected_index]); |
| 1073 EXPECT_EQ(kSourceIconURLs[expected_index].icon_url, | 1086 EXPECT_EQ(kSourceIconURLs[expected_index].icon_url, |
| 1074 handler3.GetEntry()->GetFavicon().url); | 1087 handler3.GetEntry()->GetFavicon().url); |
| 1075 | 1088 |
| 1076 TestFaviconHandlerDelegate delegate4; | 1089 TestFaviconHandlerDelegate delegate4; |
| 1077 TestFaviconHandler handler4(kPageURL, profile, | 1090 TestFaviconHandler handler4( |
| 1078 &delegate4, FaviconHandler::FAVICON); | 1091 kPageURL, profile, &driver, &delegate4, FaviconHandler::FAVICON); |
| 1079 const int kSizes4[] = { 17, 256 }; | 1092 const int kSizes4[] = { 17, 256 }; |
| 1080 std::vector<FaviconURL> urls4(kSourceIconURLs, | 1093 std::vector<FaviconURL> urls4(kSourceIconURLs, |
| 1081 kSourceIconURLs + arraysize(kSizes4)); | 1094 kSourceIconURLs + arraysize(kSizes4)); |
| 1082 DownloadTillDoneIgnoringHistory(&handler4, kPageURL, urls4, kSizes4); | 1095 DownloadTillDoneIgnoringHistory(&handler4, kPageURL, urls4, kSizes4); |
| 1083 EXPECT_TRUE(handler4.GetEntry()->GetFavicon().valid); | 1096 EXPECT_TRUE(handler4.GetEntry()->GetFavicon().valid); |
| 1084 expected_index = 0u; | 1097 expected_index = 0u; |
| 1085 EXPECT_EQ(17, kSizes4[expected_index]); | 1098 EXPECT_EQ(17, kSizes4[expected_index]); |
| 1086 EXPECT_EQ(kSourceIconURLs[expected_index].icon_url, | 1099 EXPECT_EQ(kSourceIconURLs[expected_index].icon_url, |
| 1087 handler4.GetEntry()->GetFavicon().url); | 1100 handler4.GetEntry()->GetFavicon().url); |
| 1088 } | 1101 } |
| (...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1166 download_id = favicon_tab_helper->StartDownload(missing_icon_url, 0); | 1179 download_id = favicon_tab_helper->StartDownload(missing_icon_url, 0); |
| 1167 EXPECT_NE(0, download_id); | 1180 EXPECT_NE(0, download_id); |
| 1168 // Report download success with HTTP 200 status. | 1181 // Report download success with HTTP 200 status. |
| 1169 favicon_tab_helper->DidDownloadFavicon(download_id, 200, missing_icon_url, | 1182 favicon_tab_helper->DidDownloadFavicon(download_id, 200, missing_icon_url, |
| 1170 empty_icons, empty_icon_sizes); | 1183 empty_icons, empty_icon_sizes); |
| 1171 // Icon is not marked as UnableToDownload as HTTP status is not 404. | 1184 // Icon is not marked as UnableToDownload as HTTP status is not 404. |
| 1172 EXPECT_FALSE(favicon_service->WasUnableToDownloadFavicon(missing_icon_url)); | 1185 EXPECT_FALSE(favicon_service->WasUnableToDownloadFavicon(missing_icon_url)); |
| 1173 } | 1186 } |
| 1174 | 1187 |
| 1175 } // namespace. | 1188 } // namespace. |
| OLD | NEW |