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

Unified Diff: chrome/common/favicon/favicon_url_parser_unittest.cc

Issue 15388002: Supporting high dpi favicons in Instant Extended. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Sync and rebase Created 7 years, 5 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/common/favicon/favicon_url_parser.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/common/favicon/favicon_url_parser_unittest.cc
diff --git a/chrome/common/favicon/favicon_url_parser_unittest.cc b/chrome/common/favicon/favicon_url_parser_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..051bce1760477c316a88591e37a76dd9f46c8b1a
--- /dev/null
+++ b/chrome/common/favicon/favicon_url_parser_unittest.cc
@@ -0,0 +1,166 @@
+// Copyright (c) 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/common/favicon/favicon_url_parser.h"
+
+#include "base/memory/scoped_ptr.h"
+#include "chrome/common/favicon/favicon_types.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "ui/base/layout.h"
+
+class FaviconUrlParserTest : public testing::Test {
+ public:
+ FaviconUrlParserTest() {
+ // Set the supported scale factors because the supported scale factors
+ // affect the result of ParsePathAndScale().
+ std::vector<ui::ScaleFactor> supported_scale_factors;
+ supported_scale_factors.push_back(ui::SCALE_FACTOR_100P);
+ supported_scale_factors.push_back(ui::SCALE_FACTOR_140P);
+ scoped_set_supported_scale_factors_.reset(
+ new ui::test::ScopedSetSupportedScaleFactors(supported_scale_factors));
+ }
+
+ virtual ~FaviconUrlParserTest() {
+ }
+
+ private:
+ typedef scoped_ptr<ui::test::ScopedSetSupportedScaleFactors>
+ ScopedSetSupportedScaleFactors;
+ ScopedSetSupportedScaleFactors scoped_set_supported_scale_factors_;
+
+ DISALLOW_COPY_AND_ASSIGN(FaviconUrlParserTest);
+};
+
+// Test parsing path with no extra parameters.
+TEST_F(FaviconUrlParserTest, ParsingNoExtraParams) {
+ const std::string url("https://www.google.ca/imghp?hl=en&tab=wi");
+ int icon_types = chrome::TOUCH_PRECOMPOSED_ICON;
+ chrome::ParsedFaviconPath parsed;
+
+ 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);
+}
+
+// Test parsing path with a 'size' parameter.
+TEST_F(FaviconUrlParserTest, ParsingSizeParam) {
+ const std::string url("https://www.google.ca/imghp?hl=en&tab=wi");
+ int icon_types = chrome::TOUCH_PRECOMPOSED_ICON;
+ chrome::ParsedFaviconPath parsed;
+
+ // Test that we can still parse the legacy 'size' parameter format.
+ 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/" + 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/" + 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/" + 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(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);
+}
+
+// Test parsing path with the 'largest' parameter.
+TEST_F(FaviconUrlParserTest, ParsingLargestParam) {
+ const std::string url("https://www.google.ca/imghp?hl=en&tab=wi");
+ int icon_types = chrome::TOUCH_PRECOMPOSED_ICON;
+ chrome::ParsedFaviconPath parsed;
+
+ 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.
+}
+
+// Test parsing path with 'iconurl' parameter.
+TEST_F(FaviconUrlParserTest, ParsingIconUrlParam) {
+ const std::string url("https://www.google.ca/imghp?hl=en&tab=wi");
+ int icon_types = chrome::TOUCH_PRECOMPOSED_ICON;
+ chrome::ParsedFaviconPath parsed;
+
+ const std::string path10 = "iconurl/http://www.google.com/favicon.ico";
+ 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);
+}
+
+// Test parsing path with 'origin' parameter.
+TEST_F(FaviconUrlParserTest, ParsingOriginParam) {
+ const std::string url("https://www.google.ca/imghp?hl=en&tab=wi");
+ int icon_types = chrome::TOUCH_PRECOMPOSED_ICON;
+ chrome::ParsedFaviconPath parsed;
+
+ 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(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);
+}
+
+// Test parsing paths with both a 'size' parameter and a 'url modifier'
+// parameter.
+TEST_F(FaviconUrlParserTest, ParsingSizeParamAndUrlModifier) {
+ const std::string url("https://www.google.ca/imghp?hl=en&tab=wi");
+ int icon_types = chrome::TOUCH_PRECOMPOSED_ICON;
+ chrome::ParsedFaviconPath parsed;
+
+ 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(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);
+}
« no previous file with comments | « chrome/common/favicon/favicon_url_parser.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698