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 <stddef.h> | 5 #include <stddef.h> |
6 #include <stdint.h> | 6 #include <stdint.h> |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/files/file_path.h" | 10 #include "base/files/file_path.h" |
(...skipping 26 matching lines...) Expand all Loading... |
37 | 37 |
38 // This constant copied from save_package.cc. | 38 // This constant copied from save_package.cc. |
39 #if defined(OS_WIN) | 39 #if defined(OS_WIN) |
40 const uint32_t kMaxFilePathLength = MAX_PATH - 1; | 40 const uint32_t kMaxFilePathLength = MAX_PATH - 1; |
41 const uint32_t kMaxFileNameLength = MAX_PATH - 1; | 41 const uint32_t kMaxFileNameLength = MAX_PATH - 1; |
42 #elif defined(OS_POSIX) | 42 #elif defined(OS_POSIX) |
43 const uint32_t kMaxFilePathLength = PATH_MAX - 1; | 43 const uint32_t kMaxFilePathLength = PATH_MAX - 1; |
44 const uint32_t kMaxFileNameLength = NAME_MAX; | 44 const uint32_t kMaxFileNameLength = NAME_MAX; |
45 #endif | 45 #endif |
46 | 46 |
47 // Used to make long filenames. | |
48 std::string long_file_name( | |
49 "EFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz01234567" | |
50 "89ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz012345" | |
51 "6789ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz0123" | |
52 "456789ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789a"); | |
53 | |
54 bool HasOrdinalNumber(const base::FilePath::StringType& filename) { | 47 bool HasOrdinalNumber(const base::FilePath::StringType& filename) { |
55 base::FilePath::StringType::size_type r_paren_index = | 48 base::FilePath::StringType::size_type r_paren_index = |
56 filename.rfind(FPL(')')); | 49 filename.rfind(FPL(')')); |
57 base::FilePath::StringType::size_type l_paren_index = | 50 base::FilePath::StringType::size_type l_paren_index = |
58 filename.rfind(FPL('(')); | 51 filename.rfind(FPL('(')); |
59 if (l_paren_index >= r_paren_index) | 52 if (l_paren_index >= r_paren_index) |
60 return false; | 53 return false; |
61 | 54 |
62 for (base::FilePath::StringType::size_type i = l_paren_index + 1; | 55 for (base::FilePath::StringType::size_type i = l_paren_index + 1; |
63 i != r_paren_index; ++i) { | 56 i != r_paren_index; ++i) { |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
105 | 98 |
106 // Do the initialization in SetUp so contents() is initialized by | 99 // Do the initialization in SetUp so contents() is initialized by |
107 // RenderViewHostImplTestHarness::SetUp. | 100 // RenderViewHostImplTestHarness::SetUp. |
108 ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); | 101 ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); |
109 | 102 |
110 save_package_success_ = | 103 save_package_success_ = |
111 new SavePackage(contents(), SAVE_PAGE_TYPE_AS_COMPLETE_HTML, | 104 new SavePackage(contents(), SAVE_PAGE_TYPE_AS_COMPLETE_HTML, |
112 temp_dir_.path().AppendASCII("testfile" HTML_EXTENSION), | 105 temp_dir_.path().AppendASCII("testfile" HTML_EXTENSION), |
113 temp_dir_.path().AppendASCII("testfile_files")); | 106 temp_dir_.path().AppendASCII("testfile_files")); |
114 | 107 |
115 // We need to construct a path that is *almost* kMaxFilePathLength long | 108 base::FilePath::StringType long_file_name = GetLongFileName(); |
116 long_file_name.reserve(kMaxFilePathLength + long_file_name.length()); | |
117 while (long_file_name.length() < kMaxFilePathLength) | |
118 long_file_name += long_file_name; | |
119 long_file_name.resize( | |
120 kMaxFilePathLength - 9 - temp_dir_.path().value().length()); | |
121 | |
122 save_package_fail_ = new SavePackage( | 109 save_package_fail_ = new SavePackage( |
123 contents(), SAVE_PAGE_TYPE_AS_COMPLETE_HTML, | 110 contents(), SAVE_PAGE_TYPE_AS_COMPLETE_HTML, |
124 temp_dir_.path().AppendASCII(long_file_name + HTML_EXTENSION), | 111 temp_dir_.path().Append(long_file_name + FPL_HTML_EXTENSION), |
125 temp_dir_.path().AppendASCII(long_file_name + "_files")); | 112 temp_dir_.path().Append(long_file_name + FPL("_files"))); |
126 } | 113 } |
127 | 114 |
128 BrowserContext* CreateBrowserContext() override { | 115 BrowserContext* CreateBrowserContext() override { |
129 // This method is invoked after the browser threads have been created and | 116 // This method is invoked after the browser threads have been created and |
130 // obviously before the BrowserContext is created. This is the correct time | 117 // obviously before the BrowserContext is created. This is the correct time |
131 // to create a ResourceDispatcherHostImpl so that our SavePackage objects | 118 // to create a ResourceDispatcherHostImpl so that our SavePackage objects |
132 // can initialize correctly. | 119 // can initialize correctly. |
133 rdh_.reset(new ResourceDispatcherHostImpl); | 120 rdh_.reset(new ResourceDispatcherHostImpl); |
134 return RenderViewHostImplTestHarness::CreateBrowserContext(); | 121 return RenderViewHostImplTestHarness::CreateBrowserContext(); |
135 } | 122 } |
136 | 123 |
137 void TearDown() override { | 124 void TearDown() override { |
138 DeleteContents(); | 125 DeleteContents(); |
139 base::RunLoop().RunUntilIdle(); | 126 base::RunLoop().RunUntilIdle(); |
140 | 127 |
141 save_package_success_ = nullptr; | 128 save_package_success_ = nullptr; |
142 save_package_fail_ = nullptr; | 129 save_package_fail_ = nullptr; |
143 rdh_.reset(); | 130 rdh_.reset(); |
144 | 131 |
145 RenderViewHostImplTestHarness::TearDown(); | 132 RenderViewHostImplTestHarness::TearDown(); |
146 } | 133 } |
147 | 134 |
| 135 // Returns a path that is *almost* kMaxFilePathLength long |
| 136 base::FilePath::StringType GetLongFileName() const { |
| 137 size_t target_length = |
| 138 kMaxFilePathLength - 9 - temp_dir_.path().value().length(); |
| 139 return base::FilePath::StringType(target_length, FPL('a')); |
| 140 } |
| 141 |
148 private: | 142 private: |
149 // SavePackage for successfully generating file name. | 143 // SavePackage for successfully generating file name. |
150 scoped_refptr<SavePackage> save_package_success_; | 144 scoped_refptr<SavePackage> save_package_success_; |
151 // SavePackage for failed generating file name. | 145 // SavePackage for failed generating file name. |
152 scoped_refptr<SavePackage> save_package_fail_; | 146 scoped_refptr<SavePackage> save_package_fail_; |
153 | 147 |
154 base::ScopedTempDir temp_dir_; | 148 base::ScopedTempDir temp_dir_; |
155 | 149 |
156 std::unique_ptr<ResourceDispatcherHostImpl> rdh_; | 150 std::unique_ptr<ResourceDispatcherHostImpl> rdh_; |
157 }; | 151 }; |
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
230 } | 224 } |
231 | 225 |
232 // Crashing on Windows, see http://crbug.com/79365 | 226 // Crashing on Windows, see http://crbug.com/79365 |
233 #if defined(OS_WIN) | 227 #if defined(OS_WIN) |
234 #define MAYBE_TestLongSavePackageFilename DISABLED_TestLongSavePackageFilename | 228 #define MAYBE_TestLongSavePackageFilename DISABLED_TestLongSavePackageFilename |
235 #else | 229 #else |
236 #define MAYBE_TestLongSavePackageFilename TestLongSavePackageFilename | 230 #define MAYBE_TestLongSavePackageFilename TestLongSavePackageFilename |
237 #endif | 231 #endif |
238 TEST_F(SavePackageTest, MAYBE_TestLongSavePackageFilename) { | 232 TEST_F(SavePackageTest, MAYBE_TestLongSavePackageFilename) { |
239 const std::string base_url("http://www.google.com/"); | 233 const std::string base_url("http://www.google.com/"); |
240 const std::string long_file = long_file_name + ".css"; | 234 const base::FilePath::StringType long_file_name = |
241 const std::string url = base_url + long_file; | 235 GetLongFileName() + FPL(".css"); |
| 236 const std::string url = |
| 237 base_url + base::FilePath(long_file_name).AsUTF8Unsafe(); |
242 | 238 |
243 base::FilePath::StringType filename; | 239 base::FilePath::StringType filename; |
244 // Test that the filename is successfully shortened to fit. | 240 // Test that the filename is successfully shortened to fit. |
245 ASSERT_TRUE(GetGeneratedFilename(true, std::string(), url, false, &filename)); | 241 ASSERT_TRUE(GetGeneratedFilename(true, std::string(), url, false, &filename)); |
246 EXPECT_TRUE(filename.length() < long_file.length()); | 242 EXPECT_TRUE(filename.length() < long_file_name.length()); |
247 EXPECT_FALSE(HasOrdinalNumber(filename)); | 243 EXPECT_FALSE(HasOrdinalNumber(filename)); |
248 | 244 |
249 // Test that the filename is successfully shortened to fit, and gets an | 245 // Test that the filename is successfully shortened to fit, and gets an |
250 // an ordinal appended. | 246 // an ordinal appended. |
251 ASSERT_TRUE(GetGeneratedFilename(true, std::string(), url, false, &filename)); | 247 ASSERT_TRUE(GetGeneratedFilename(true, std::string(), url, false, &filename)); |
252 EXPECT_TRUE(filename.length() < long_file.length()); | 248 EXPECT_TRUE(filename.length() < long_file_name.length()); |
253 EXPECT_TRUE(HasOrdinalNumber(filename)); | 249 EXPECT_TRUE(HasOrdinalNumber(filename)); |
254 | 250 |
255 // Test that the filename is successfully shortened to fit, and gets a | 251 // Test that the filename is successfully shortened to fit, and gets a |
256 // different ordinal appended. | 252 // different ordinal appended. |
257 base::FilePath::StringType filename2; | 253 base::FilePath::StringType filename2; |
258 ASSERT_TRUE( | 254 ASSERT_TRUE( |
259 GetGeneratedFilename(true, std::string(), url, false, &filename2)); | 255 GetGeneratedFilename(true, std::string(), url, false, &filename2)); |
260 EXPECT_TRUE(filename2.length() < long_file.length()); | 256 EXPECT_TRUE(filename2.length() < long_file_name.length()); |
261 EXPECT_TRUE(HasOrdinalNumber(filename2)); | 257 EXPECT_TRUE(HasOrdinalNumber(filename2)); |
262 EXPECT_NE(filename, filename2); | 258 EXPECT_NE(filename, filename2); |
263 } | 259 } |
264 | 260 |
265 // Crashing on Windows, see http://crbug.com/79365 | 261 // Crashing on Windows, see http://crbug.com/79365 |
266 #if defined(OS_WIN) | 262 #if defined(OS_WIN) |
267 #define MAYBE_TestLongSafePureFilename DISABLED_TestLongSafePureFilename | 263 #define MAYBE_TestLongSafePureFilename DISABLED_TestLongSafePureFilename |
268 #else | 264 #else |
269 #define MAYBE_TestLongSafePureFilename TestLongSafePureFilename | 265 #define MAYBE_TestLongSafePureFilename TestLongSafePureFilename |
270 #endif | 266 #endif |
271 TEST_F(SavePackageTest, MAYBE_TestLongSafePureFilename) { | 267 TEST_F(SavePackageTest, MAYBE_TestLongSafePureFilename) { |
272 const base::FilePath save_dir(FPL("test_dir")); | 268 const base::FilePath save_dir(FPL("test_dir")); |
273 const base::FilePath::StringType ext(FPL_HTML_EXTENSION); | 269 const base::FilePath::StringType ext(FPL_HTML_EXTENSION); |
274 base::FilePath::StringType filename = | 270 base::FilePath::StringType filename = GetLongFileName(); |
275 #if defined(OS_WIN) | |
276 base::ASCIIToUTF16(long_file_name); | |
277 #else | |
278 long_file_name; | |
279 #endif | |
280 | 271 |
281 // Test that the filename + extension doesn't exceed kMaxFileNameLength | 272 // Test that the filename + extension doesn't exceed kMaxFileNameLength |
282 uint32_t max_path = SavePackage::GetMaxPathLengthForDirectory(save_dir); | 273 uint32_t max_path = SavePackage::GetMaxPathLengthForDirectory(save_dir); |
283 ASSERT_TRUE(SavePackage::TruncateBaseNameToFitPathConstraints( | 274 ASSERT_TRUE(SavePackage::TruncateBaseNameToFitPathConstraints( |
284 save_dir, ext, max_path, &filename)); | 275 save_dir, ext, max_path, &filename)); |
285 EXPECT_TRUE(filename.length() <= kMaxFileNameLength-ext.length()); | 276 EXPECT_TRUE(filename.length() <= kMaxFileNameLength-ext.length()); |
286 } | 277 } |
287 | 278 |
288 static const struct { | 279 static const struct { |
289 const base::FilePath::CharType* page_title; | 280 const base::FilePath::CharType* page_title; |
(...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
454 GURL mock_url = net::URLRequestMockHTTPJob::GetMockUrl("save_page/a.htm"); | 445 GURL mock_url = net::URLRequestMockHTTPJob::GetMockUrl("save_page/a.htm"); |
455 GURL view_source_url = | 446 GURL view_source_url = |
456 GURL(kViewSourceScheme + std::string(":") + mock_url.spec()); | 447 GURL(kViewSourceScheme + std::string(":") + mock_url.spec()); |
457 GURL actual_url = net::URLRequestMockHTTPJob::GetMockUrl("save_page/a.htm"); | 448 GURL actual_url = net::URLRequestMockHTTPJob::GetMockUrl("save_page/a.htm"); |
458 NavigateAndCommit(view_source_url); | 449 NavigateAndCommit(view_source_url); |
459 EXPECT_EQ(actual_url, GetUrlToBeSaved()); | 450 EXPECT_EQ(actual_url, GetUrlToBeSaved()); |
460 EXPECT_EQ(view_source_url, contents()->GetLastCommittedURL()); | 451 EXPECT_EQ(view_source_url, contents()->GetLastCommittedURL()); |
461 } | 452 } |
462 | 453 |
463 } // namespace content | 454 } // namespace content |
OLD | NEW |