| Index: chrome/browser/ui/webui/favicon_source_unittest.cc
|
| diff --git a/chrome/browser/ui/webui/favicon_source_unittest.cc b/chrome/browser/ui/webui/favicon_source_unittest.cc
|
| index 27105037d298460b6448c429d9d9a5bffd4dfc8a..1957aede2f68c3986f9d89884cd85c7909784b36 100644
|
| --- a/chrome/browser/ui/webui/favicon_source_unittest.cc
|
| +++ b/chrome/browser/ui/webui/favicon_source_unittest.cc
|
| @@ -8,6 +8,7 @@
|
| #include "base/strings/string_number_conversions.h"
|
| #include "chrome/browser/search/instant_service.h"
|
| #include "chrome/browser/search/instant_service_factory.h"
|
| +#include "chrome/common/favicon_url_parser.h"
|
| #include "chrome/test/base/testing_profile.h"
|
| #include "content/public/test/test_browser_thread.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
| @@ -52,140 +53,107 @@ class FaviconSourceTest : public testing::Test {
|
| DISALLOW_COPY_AND_ASSIGN(FaviconSourceTest);
|
| };
|
|
|
| -// Test parsing the chrome-search://favicon/ URLs
|
| -TEST_F(FaviconSourceTest, InstantParsing) {
|
| - const std::string path("chrome-search://favicon/http://www.google.com");
|
| - bool is_icon_url;
|
| - GURL url;
|
| - int size_in_dip;
|
| - ui::ScaleFactor scale_factor;
|
| -
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ(GURL(path), url);
|
| - EXPECT_EQ(16, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_100P, scale_factor);
|
| -}
|
| -
|
| // Test parsing the chrome://favicon URLs
|
| TEST_F(FaviconSourceTest, Parsing) {
|
| - const GURL kUrl("https://www.google.ca/imghp?hl=en&tab=wi");
|
| -
|
| - bool is_icon_url;
|
| - GURL url;
|
| - int size_in_dip;
|
| - ui::ScaleFactor scale_factor;
|
| + const std::string url("https://www.google.ca/imghp?hl=en&tab=wi");
|
| + int icon_types = chrome::TOUCH_PRECOMPOSED_ICON;
|
| + chrome::ParsedFaviconPath parsed;
|
|
|
| // 1) Test parsing path with no extra parameters.
|
| - const std::string path1 = kUrl.spec();
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path1, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ(kUrl, url);
|
| - EXPECT_EQ(16, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_100P, scale_factor);
|
| + const std::string path1 = url;
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path1, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ(url, parsed.url);
|
| + EXPECT_EQ(16, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
|
|
|
| // 2) Test parsing path with a 'size' parameter.
|
| //
|
| // Test that we can still parse the legacy 'size' parameter format.
|
| - const std::string path2 = "size/32/" + kUrl.spec();
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path2, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ(kUrl, url);
|
| - EXPECT_EQ(32, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_100P, scale_factor);
|
| + const std::string path2 = "size/32/" + url;
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path2, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ(url, parsed.url);
|
| + EXPECT_EQ(32, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
|
|
|
| // Test parsing current 'size' parameter format.
|
| - const std::string path3 = "size/32@1.4x/" + kUrl.spec();
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path3, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ(kUrl, url);
|
| - EXPECT_EQ(32, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_140P, scale_factor);
|
| + const std::string path3 = "size/32@1.4x/" + url;
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path3, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ(url, parsed.url);
|
| + EXPECT_EQ(32, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_140P, parsed.scale_factor);
|
|
|
| // Test that we pick the ui::ScaleFactor which is closest to the passed in
|
| // scale factor.
|
| - const std::string path4 = "size/16@1.41x/" + kUrl.spec();
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path4, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ(kUrl, url);
|
| - EXPECT_EQ(16, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_140P, scale_factor);
|
| + const std::string path4 = "size/16@1.41x/" + url;
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path4, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ(url, parsed.url);
|
| + EXPECT_EQ(16, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_140P, parsed.scale_factor);
|
|
|
| // Invalid cases.
|
| - const std::string path5 = "size/" + kUrl.spec();
|
| - EXPECT_FALSE(favicon_source()->ParsePath(path5, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - const std::string path6 = "size/@1x/" + kUrl.spec();
|
| - EXPECT_FALSE(favicon_source()->ParsePath(path6, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - const std::string path7 = "size/abc@1x/" + kUrl.spec();
|
| - EXPECT_FALSE(favicon_source()->ParsePath(path7, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| + const std::string path5 = "size/" + url;
|
| + EXPECT_FALSE(chrome::ParseFaviconPath(path5, icon_types, &parsed));
|
| + const std::string path6 = "size/@1x/" + url;
|
| + EXPECT_FALSE(chrome::ParseFaviconPath(path6, icon_types, &parsed));
|
| + const std::string path7 = "size/abc@1x/" + url;
|
| + EXPECT_FALSE(chrome::ParseFaviconPath(path7, icon_types, &parsed));
|
|
|
| // Part of url looks like 'size' parameter.
|
| const std::string path8 = "http://www.google.com/size/32@1.4x";
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path8, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ(path8, url.spec());
|
| - EXPECT_EQ(16, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_100P, scale_factor);
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path8, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ(path8, parsed.url);
|
| + EXPECT_EQ(16, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
|
|
|
| // 3) Test parsing path with the 'largest' parameter.
|
| - const std::string path9 = "largest/" + kUrl.spec();
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path9, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ(kUrl, url);
|
| - EXPECT_EQ(0, size_in_dip);
|
| + const std::string path9 = "largest/" + url;
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path9, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ(url, parsed.url);
|
| + EXPECT_EQ(0, parsed.size_in_dip);
|
| // The scale factor is meaningless when requesting the largest favicon.
|
|
|
| // 4) Test parsing path with 'iconurl' parameter.
|
| const std::string path10 = "iconurl/http://www.google.com/favicon.ico";
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path10, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_TRUE(is_icon_url);
|
| - EXPECT_EQ("http://www.google.com/favicon.ico", url.spec());
|
| - EXPECT_EQ(16, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_100P, scale_factor);
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path10, icon_types, &parsed));
|
| + EXPECT_TRUE(parsed.is_icon_url);
|
| + EXPECT_EQ("http://www.google.com/favicon.ico", parsed.url);
|
| + EXPECT_EQ(16, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
|
|
|
| // 5) Test parsing path with 'origin' parameter.
|
| - const std::string path11 = "origin/" + kUrl.spec();
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path11, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ("https://www.google.ca/", url.spec());
|
| - EXPECT_EQ(16, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_100P, scale_factor);
|
| + const std::string path11 = "origin/" + url;
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path11, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ("https://www.google.ca/", parsed.url);
|
| + EXPECT_EQ(16, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
|
|
|
| const std::string path12 = "origin/google.com";
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path12, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ("http://google.com/", url.spec());
|
| - EXPECT_EQ(16, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_100P, scale_factor);
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path12, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ("http://google.com/", parsed.url);
|
| + EXPECT_EQ(16, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
|
|
|
| // 6) Test parsing paths with both a 'size' parameter and a 'url modifier'
|
| // parameter.
|
| - const std::string path13 = "size/32@1.4x/origin/" + kUrl.spec();
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path13, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_FALSE(is_icon_url);
|
| - EXPECT_EQ("https://www.google.ca/", url.spec());
|
| - EXPECT_EQ(32, size_in_dip);
|
| - EXPECT_EQ(ui::SCALE_FACTOR_140P, scale_factor);
|
| + const std::string path13 = "size/32@1.4x/origin/" + url;
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path13, icon_types, &parsed));
|
| + EXPECT_FALSE(parsed.is_icon_url);
|
| + EXPECT_EQ("https://www.google.ca/", parsed.url);
|
| + EXPECT_EQ(32, parsed.size_in_dip);
|
| + EXPECT_EQ(ui::SCALE_FACTOR_140P, parsed.scale_factor);
|
|
|
| const std::string path14 =
|
| "largest/iconurl/http://www.google.com/favicon.ico";
|
| - EXPECT_TRUE(favicon_source()->ParsePath(path14, &is_icon_url, &url,
|
| - &size_in_dip, &scale_factor));
|
| - EXPECT_TRUE(is_icon_url);
|
| - EXPECT_EQ("http://www.google.com/favicon.ico", url.spec());
|
| - EXPECT_EQ(0, size_in_dip);
|
| + EXPECT_TRUE(chrome::ParseFaviconPath(path14, icon_types, &parsed));
|
| + EXPECT_TRUE(parsed.is_icon_url);
|
| + EXPECT_EQ("http://www.google.com/favicon.ico", parsed.url);
|
| + EXPECT_EQ(0, parsed.size_in_dip);
|
| }
|
|
|