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

Side by Side 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: Moving tests to chrome/common/favicon/favicon_url_parser_unittest.cc 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « chrome/common/favicon/favicon_url_parser.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/common/favicon/favicon_url_parser.h"
6
7 #include "base/memory/scoped_ptr.h"
8 #include "chrome/common/favicon/favicon_types.h"
9 #include "testing/gtest/include/gtest/gtest.h"
10 #include "ui/base/layout.h"
11
12 class FaviconUrlParserTest : public testing::Test {
13 public:
14 FaviconUrlParserTest() {
15 // Set the supported scale factors because the supported scale factors
16 // affect the result of ParsePathAndScale().
17 std::vector<ui::ScaleFactor> supported_scale_factors;
18 supported_scale_factors.push_back(ui::SCALE_FACTOR_100P);
19 supported_scale_factors.push_back(ui::SCALE_FACTOR_140P);
20 scoped_set_supported_scale_factors_.reset(
21 new ui::test::ScopedSetSupportedScaleFactors(supported_scale_factors));
22 }
23
24 virtual ~FaviconUrlParserTest() {
25 }
26
27 private:
28 typedef scoped_ptr<ui::test::ScopedSetSupportedScaleFactors>
29 ScopedSetSupportedScaleFactors;
30 ScopedSetSupportedScaleFactors scoped_set_supported_scale_factors_;
31
32 DISALLOW_COPY_AND_ASSIGN(FaviconUrlParserTest);
33 };
34
35 // Test parsing the chrome://favicon URLs
36 TEST_F(FaviconUrlParserTest, Parsing) {
37 const std::string url("https://www.google.ca/imghp?hl=en&tab=wi");
38 int icon_types = chrome::TOUCH_PRECOMPOSED_ICON;
39 chrome::ParsedFaviconPath parsed;
40
41 // 1) Test parsing path with no extra parameters.
James Hawkins 2013/07/07 18:14:01 Each of these points should be a separate test.
pedro (no code reviews) 2013/07/10 01:27:39 Done.
42 const std::string path1 = url;
43 EXPECT_TRUE(chrome::ParseFaviconPath(path1, icon_types, &parsed));
44 EXPECT_FALSE(parsed.is_icon_url);
45 EXPECT_EQ(url, parsed.url);
46 EXPECT_EQ(16, parsed.size_in_dip);
47 EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
48
49 // 2) Test parsing path with a 'size' parameter.
50 //
51 // Test that we can still parse the legacy 'size' parameter format.
52 const std::string path2 = "size/32/" + url;
53 EXPECT_TRUE(chrome::ParseFaviconPath(path2, icon_types, &parsed));
54 EXPECT_FALSE(parsed.is_icon_url);
55 EXPECT_EQ(url, parsed.url);
56 EXPECT_EQ(32, parsed.size_in_dip);
57 EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
58
59 // Test parsing current 'size' parameter format.
60 const std::string path3 = "size/32@1.4x/" + url;
61 EXPECT_TRUE(chrome::ParseFaviconPath(path3, icon_types, &parsed));
62 EXPECT_FALSE(parsed.is_icon_url);
63 EXPECT_EQ(url, parsed.url);
64 EXPECT_EQ(32, parsed.size_in_dip);
65 EXPECT_EQ(ui::SCALE_FACTOR_140P, parsed.scale_factor);
66
67 // Test that we pick the ui::ScaleFactor which is closest to the passed in
68 // scale factor.
69 const std::string path4 = "size/16@1.41x/" + url;
70 EXPECT_TRUE(chrome::ParseFaviconPath(path4, icon_types, &parsed));
71 EXPECT_FALSE(parsed.is_icon_url);
72 EXPECT_EQ(url, parsed.url);
73 EXPECT_EQ(16, parsed.size_in_dip);
74 EXPECT_EQ(ui::SCALE_FACTOR_140P, parsed.scale_factor);
75
76 // Invalid cases.
77 const std::string path5 = "size/" + url;
78 EXPECT_FALSE(chrome::ParseFaviconPath(path5, icon_types, &parsed));
79 const std::string path6 = "size/@1x/" + url;
80 EXPECT_FALSE(chrome::ParseFaviconPath(path6, icon_types, &parsed));
81 const std::string path7 = "size/abc@1x/" + url;
82 EXPECT_FALSE(chrome::ParseFaviconPath(path7, icon_types, &parsed));
83
84 // Part of url looks like 'size' parameter.
85 const std::string path8 = "http://www.google.com/size/32@1.4x";
86 EXPECT_TRUE(chrome::ParseFaviconPath(path8, icon_types, &parsed));
87 EXPECT_FALSE(parsed.is_icon_url);
88 EXPECT_EQ(path8, parsed.url);
89 EXPECT_EQ(16, parsed.size_in_dip);
90 EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
91
92 // 3) Test parsing path with the 'largest' parameter.
93 const std::string path9 = "largest/" + url;
94 EXPECT_TRUE(chrome::ParseFaviconPath(path9, icon_types, &parsed));
95 EXPECT_FALSE(parsed.is_icon_url);
96 EXPECT_EQ(url, parsed.url);
97 EXPECT_EQ(0, parsed.size_in_dip);
98 // The scale factor is meaningless when requesting the largest favicon.
99
100 // 4) Test parsing path with 'iconurl' parameter.
101 const std::string path10 = "iconurl/http://www.google.com/favicon.ico";
102 EXPECT_TRUE(chrome::ParseFaviconPath(path10, icon_types, &parsed));
103 EXPECT_TRUE(parsed.is_icon_url);
104 EXPECT_EQ("http://www.google.com/favicon.ico", parsed.url);
105 EXPECT_EQ(16, parsed.size_in_dip);
106 EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
107
108 // 5) Test parsing path with 'origin' parameter.
109 const std::string path11 = "origin/" + url;
110 EXPECT_TRUE(chrome::ParseFaviconPath(path11, icon_types, &parsed));
111 EXPECT_FALSE(parsed.is_icon_url);
112 EXPECT_EQ("https://www.google.ca/", parsed.url);
113 EXPECT_EQ(16, parsed.size_in_dip);
114 EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
115
116 const std::string path12 = "origin/google.com";
117 EXPECT_TRUE(chrome::ParseFaviconPath(path12, icon_types, &parsed));
118 EXPECT_FALSE(parsed.is_icon_url);
119 EXPECT_EQ("http://google.com/", parsed.url);
120 EXPECT_EQ(16, parsed.size_in_dip);
121 EXPECT_EQ(ui::SCALE_FACTOR_100P, parsed.scale_factor);
122
123 // 6) Test parsing paths with both a 'size' parameter and a 'url modifier'
124 // parameter.
125 const std::string path13 = "size/32@1.4x/origin/" + url;
126 EXPECT_TRUE(chrome::ParseFaviconPath(path13, icon_types, &parsed));
127 EXPECT_FALSE(parsed.is_icon_url);
128 EXPECT_EQ("https://www.google.ca/", parsed.url);
129 EXPECT_EQ(32, parsed.size_in_dip);
130 EXPECT_EQ(ui::SCALE_FACTOR_140P, parsed.scale_factor);
131
132 const std::string path14 =
133 "largest/iconurl/http://www.google.com/favicon.ico";
134 EXPECT_TRUE(chrome::ParseFaviconPath(path14, icon_types, &parsed));
135 EXPECT_TRUE(parsed.is_icon_url);
136 EXPECT_EQ("http://www.google.com/favicon.ico", parsed.url);
137 EXPECT_EQ(0, parsed.size_in_dip);
138 }
OLDNEW
« 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