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

Side by Side Diff: chrome/browser/ui/webui/fileicon_source_unittest.cc

Issue 291733004: Reduce the use of ui::ScaleFactor in webui/favicon (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 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
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 "base/memory/ref_counted_memory.h" 5 #include "base/memory/ref_counted_memory.h"
6 #include "base/message_loop/message_loop.h" 6 #include "base/message_loop/message_loop.h"
7 #include "chrome/browser/icon_manager.h" 7 #include "chrome/browser/icon_manager.h"
8 #include "chrome/browser/profiles/profile.h" 8 #include "chrome/browser/profiles/profile.h"
9 #include "chrome/browser/ui/webui/fileicon_source.h" 9 #include "chrome/browser/ui/webui/fileicon_source.h"
10 #include "chrome/test/base/testing_profile.h" 10 #include "chrome/test/base/testing_profile.h"
11 #include "content/public/test/test_browser_thread.h" 11 #include "content/public/test/test_browser_thread.h"
12 #include "testing/gmock/include/gmock/gmock.h" 12 #include "testing/gmock/include/gmock/gmock.h"
13 #include "testing/gtest/include/gtest/gtest.h" 13 #include "testing/gtest/include/gtest/gtest.h"
14 14
15 using content::BrowserThread; 15 using content::BrowserThread;
16 16
17 namespace { 17 namespace {
18 18
19 class TestFileIconSource : public FileIconSource { 19 class TestFileIconSource : public FileIconSource {
20 public: 20 public:
21 explicit TestFileIconSource() {} 21 explicit TestFileIconSource() {}
22 22
23 MOCK_METHOD4(FetchFileIcon, 23 MOCK_METHOD4(FetchFileIcon,
24 void(const base::FilePath& path, 24 void(const base::FilePath& path,
25 ui::ScaleFactor scale_factor, 25 float scale_factor,
26 IconLoader::IconSize icon_size, 26 IconLoader::IconSize icon_size,
27 const content::URLDataSource::GotDataCallback& callback)); 27 const content::URLDataSource::GotDataCallback& callback));
28 28
29 virtual ~TestFileIconSource() {} 29 virtual ~TestFileIconSource() {}
30 }; 30 };
31 31
32 class FileIconSourceTest : public testing::Test { 32 class FileIconSourceTest : public testing::Test {
33 public: 33 public:
34 FileIconSourceTest() 34 FileIconSourceTest()
35 : ui_thread_(BrowserThread::UI, base::MessageLoop::current()), 35 : ui_thread_(BrowserThread::UI, base::MessageLoop::current()),
36 file_thread_(BrowserThread::FILE, base::MessageLoop::current()) {} 36 file_thread_(BrowserThread::FILE, base::MessageLoop::current()) {}
37 37
38 static TestFileIconSource* CreateFileIconSource() { 38 static TestFileIconSource* CreateFileIconSource() {
39 return new TestFileIconSource(); 39 return new TestFileIconSource();
40 } 40 }
41 41
42 private: 42 private:
43 base::MessageLoopForUI loop_; 43 base::MessageLoopForUI loop_;
44 content::TestBrowserThread ui_thread_; 44 content::TestBrowserThread ui_thread_;
45 content::TestBrowserThread file_thread_; 45 content::TestBrowserThread file_thread_;
46 }; 46 };
47 47
48 const struct FetchFileIconExpectation { 48 const struct FetchFileIconExpectation {
49 const char* request_path; 49 const char* request_path;
50 const base::FilePath::CharType* unescaped_path; 50 const base::FilePath::CharType* unescaped_path;
51 ui::ScaleFactor scale_factor; 51 float scale_factor;
52 IconLoader::IconSize size; 52 IconLoader::IconSize size;
53 } kBasicExpectations[] = { 53 } kBasicExpectations[] = {
54 { "foo?bar", FILE_PATH_LITERAL("foo"), ui::SCALE_FACTOR_100P, 54 { "foo?bar", FILE_PATH_LITERAL("foo"), 1.0f, IconLoader::NORMAL },
55 { "foo?bar&scale=2x", FILE_PATH_LITERAL("foo"), 2.0f, IconLoader::NORMAL },
56 { "foo?iconsize=small", FILE_PATH_LITERAL("foo"), 1.0f, IconLoader::SMALL },
57 { "foo?iconsize=normal", FILE_PATH_LITERAL("foo"), 1.0f, IconLoader::NORMAL },
58 { "foo?iconsize=large", FILE_PATH_LITERAL("foo"), 1.0f, IconLoader::LARGE },
59 { "foo?iconsize=asdf", FILE_PATH_LITERAL("foo"), 1.0f, IconLoader::NORMAL },
60 { "foo?blah=b&iconsize=small", FILE_PATH_LITERAL("foo"), 1.0f,
61 IconLoader::SMALL },
62 { "foo?blah&iconsize=small", FILE_PATH_LITERAL("foo"), 1.0f,
63 IconLoader::SMALL },
64 { "a%3Fb%26c%3Dd.txt?iconsize=small", FILE_PATH_LITERAL("a?b&c=d.txt"), 1.0f,
65 IconLoader::SMALL },
66 { "a%3Ficonsize%3Dsmall?iconsize=large",
67 FILE_PATH_LITERAL("a?iconsize=small"), 1.0f, IconLoader::LARGE },
68 { "o%40%23%24%25%26*()%20%2B%3D%3F%2C%3A%3B%22.jpg",
69 FILE_PATH_LITERAL("o@#$%&*() +=?,:;\".jpg"), 1.0f, IconLoader::NORMAL },
70 #if defined(OS_WIN)
71 { "c:/foo/bar/baz", FILE_PATH_LITERAL("c:\\foo\\bar\\baz"), 1.0f,
55 IconLoader::NORMAL }, 72 IconLoader::NORMAL },
56 { "foo?bar&scale=2x", FILE_PATH_LITERAL("foo"), ui::SCALE_FACTOR_200P, 73 { "/foo?bar=asdf&asdf", FILE_PATH_LITERAL("\\foo"), 1.0f,
57 IconLoader::NORMAL },
58 { "foo?iconsize=small", FILE_PATH_LITERAL("foo"), ui::SCALE_FACTOR_100P,
59 IconLoader::SMALL },
60 { "foo?iconsize=normal", FILE_PATH_LITERAL("foo"), ui::SCALE_FACTOR_100P,
61 IconLoader::NORMAL },
62 { "foo?iconsize=large", FILE_PATH_LITERAL("foo"), ui::SCALE_FACTOR_100P,
63 IconLoader::LARGE },
64 { "foo?iconsize=asdf", FILE_PATH_LITERAL("foo"), ui::SCALE_FACTOR_100P,
65 IconLoader::NORMAL },
66 { "foo?blah=b&iconsize=small", FILE_PATH_LITERAL("foo"),
67 ui::SCALE_FACTOR_100P, IconLoader::SMALL },
68 { "foo?blah&iconsize=small", FILE_PATH_LITERAL("foo"), ui::SCALE_FACTOR_100P,
69 IconLoader::SMALL },
70 { "a%3Fb%26c%3Dd.txt?iconsize=small", FILE_PATH_LITERAL("a?b&c=d.txt"),
71 ui::SCALE_FACTOR_100P, IconLoader::SMALL },
72 { "a%3Ficonsize%3Dsmall?iconsize=large",
73 FILE_PATH_LITERAL("a?iconsize=small"), ui::SCALE_FACTOR_100P,
74 IconLoader::LARGE },
75 { "o%40%23%24%25%26*()%20%2B%3D%3F%2C%3A%3B%22.jpg",
76 FILE_PATH_LITERAL("o@#$%&*() +=?,:;\".jpg"), ui::SCALE_FACTOR_100P,
77 IconLoader::NORMAL },
78 #if defined(OS_WIN)
79 { "c:/foo/bar/baz", FILE_PATH_LITERAL("c:\\foo\\bar\\baz"),
80 ui::SCALE_FACTOR_100P, IconLoader::NORMAL },
81 { "/foo?bar=asdf&asdf", FILE_PATH_LITERAL("\\foo"), ui::SCALE_FACTOR_100P,
82 IconLoader::NORMAL }, 74 IconLoader::NORMAL },
83 { "c%3A%2Fusers%2Ffoo%20user%2Fbar.txt", 75 { "c%3A%2Fusers%2Ffoo%20user%2Fbar.txt",
84 FILE_PATH_LITERAL("c:\\users\\foo user\\bar.txt"), ui::SCALE_FACTOR_100P, 76 FILE_PATH_LITERAL("c:\\users\\foo user\\bar.txt"), 1.0f,
85 IconLoader::NORMAL }, 77 IconLoader::NORMAL },
86 { "c%3A%2Fusers%2F%C2%A9%202000.pdf", 78 { "c%3A%2Fusers%2F%C2%A9%202000.pdf",
87 FILE_PATH_LITERAL("c:\\users\\\xa9 2000.pdf"), ui::SCALE_FACTOR_100P, 79 FILE_PATH_LITERAL("c:\\users\\\xa9 2000.pdf"), 1.0f, IconLoader::NORMAL },
80 { "%E0%B6%9A%E0%B6%BB%E0%B7%9D%E0%B6%B8%E0%B7%8A",
81 FILE_PATH_LITERAL("\x0d9a\x0dbb\x0ddd\x0db8\x0dca"), 1.0f,
88 IconLoader::NORMAL }, 82 IconLoader::NORMAL },
89 { "%E0%B6%9A%E0%B6%BB%E0%B7%9D%E0%B6%B8%E0%B7%8A", 83 { "%2Ffoo%2Fbar", FILE_PATH_LITERAL("\\foo\\bar"), 1.0f, IconLoader::NORMAL },
90 FILE_PATH_LITERAL("\x0d9a\x0dbb\x0ddd\x0db8\x0dca"), ui::SCALE_FACTOR_100P, 84 { "%2Fbaz%20(1).txt?iconsize=small", FILE_PATH_LITERAL("\\baz (1).txt"),
85 1.0f, IconLoader::SMALL },
86 #else
87 { "/foo/bar/baz", FILE_PATH_LITERAL("/foo/bar/baz"), 1.0f,
91 IconLoader::NORMAL }, 88 IconLoader::NORMAL },
92 { "%2Ffoo%2Fbar", FILE_PATH_LITERAL("\\foo\\bar"), ui::SCALE_FACTOR_100P, 89 { "/foo?bar", FILE_PATH_LITERAL("/foo"), 1.0f, IconLoader::NORMAL },
93 IconLoader::NORMAL },
94 { "%2Fbaz%20(1).txt?iconsize=small", FILE_PATH_LITERAL("\\baz (1).txt"),
95 ui::SCALE_FACTOR_100P, IconLoader::SMALL },
96 #else
97 { "/foo/bar/baz", FILE_PATH_LITERAL("/foo/bar/baz"), ui::SCALE_FACTOR_100P,
98 IconLoader::NORMAL },
99 { "/foo?bar", FILE_PATH_LITERAL("/foo"), ui::SCALE_FACTOR_100P,
100 IconLoader::NORMAL },
101 { "%2Ffoo%2f%E0%B6%9A%E0%B6%BB%E0%B7%9D%E0%B6%B8%E0%B7%8A", 90 { "%2Ffoo%2f%E0%B6%9A%E0%B6%BB%E0%B7%9D%E0%B6%B8%E0%B7%8A",
102 FILE_PATH_LITERAL("/foo/\xe0\xb6\x9a\xe0\xb6\xbb\xe0\xb7\x9d") 91 FILE_PATH_LITERAL("/foo/\xe0\xb6\x9a\xe0\xb6\xbb\xe0\xb7\x9d")
103 FILE_PATH_LITERAL("\xe0\xb6\xb8\xe0\xb7\x8a"), ui::SCALE_FACTOR_100P, 92 FILE_PATH_LITERAL("\xe0\xb6\xb8\xe0\xb7\x8a"), 1.0f, IconLoader::NORMAL },
104 IconLoader::NORMAL }, 93 { "%2Ffoo%2Fbar", FILE_PATH_LITERAL("/foo/bar"), 1.0f, IconLoader::NORMAL },
105 { "%2Ffoo%2Fbar", FILE_PATH_LITERAL("/foo/bar"), ui::SCALE_FACTOR_100P, 94 { "%2Fbaz%20(1).txt?iconsize=small", FILE_PATH_LITERAL("/baz (1).txt"), 1.0f,
106 IconLoader::NORMAL }, 95 IconLoader::SMALL },
107 { "%2Fbaz%20(1).txt?iconsize=small", FILE_PATH_LITERAL("/baz (1).txt"),
108 ui::SCALE_FACTOR_100P, IconLoader::SMALL },
109 #endif 96 #endif
110 }; 97 };
111 98
112 // Test that the callback is NULL. 99 // Test that the callback is NULL.
113 MATCHER(CallbackIsNull, "") { 100 MATCHER(CallbackIsNull, "") {
114 return arg.is_null(); 101 return arg.is_null();
115 } 102 }
116 103
117 } // namespace 104 } // namespace
118 105
119 TEST_F(FileIconSourceTest, FileIconSource_Parse) { 106 TEST_F(FileIconSourceTest, FileIconSource_Parse) {
120 std::vector<ui::ScaleFactor> supported_scale_factors; 107 std::vector<ui::ScaleFactor> supported_scale_factors;
121 supported_scale_factors.push_back(ui::SCALE_FACTOR_100P); 108 supported_scale_factors.push_back(ui::SCALE_FACTOR_100P);
122 supported_scale_factors.push_back(ui::SCALE_FACTOR_200P); 109 supported_scale_factors.push_back(ui::SCALE_FACTOR_200P);
123 ui::test::ScopedSetSupportedScaleFactors scoped_supported( 110 ui::test::ScopedSetSupportedScaleFactors scoped_supported(
124 supported_scale_factors); 111 supported_scale_factors);
125 112
126 for (unsigned i = 0; i < arraysize(kBasicExpectations); i++) { 113 for (unsigned i = 0; i < arraysize(kBasicExpectations); i++) {
127 scoped_ptr<TestFileIconSource> source(CreateFileIconSource()); 114 scoped_ptr<TestFileIconSource> source(CreateFileIconSource());
128 content::URLDataSource::GotDataCallback callback; 115 content::URLDataSource::GotDataCallback callback;
129 EXPECT_CALL(*source.get(), 116 EXPECT_CALL(*source.get(),
130 FetchFileIcon( 117 FetchFileIcon(
131 base::FilePath(kBasicExpectations[i].unescaped_path), 118 base::FilePath(kBasicExpectations[i].unescaped_path),
132 kBasicExpectations[i].scale_factor, 119 kBasicExpectations[i].scale_factor,
133 kBasicExpectations[i].size, CallbackIsNull())); 120 kBasicExpectations[i].size, CallbackIsNull()));
134 source->StartDataRequest(kBasicExpectations[i].request_path, -1, -1, 121 source->StartDataRequest(kBasicExpectations[i].request_path, -1, -1,
135 callback); 122 callback);
136 } 123 }
137 } 124 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698