Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/file_path.h" | 5 #include "base/file_path.h" |
| 6 #include "base/file_util.h" | 6 #include "base/file_util.h" |
| 7 #include "base/path_service.h" | 7 #include "base/path_service.h" |
| 8 #include "base/scoped_temp_dir.h" | 8 #include "base/scoped_temp_dir.h" |
| 9 #include "chrome/app/chrome_command_ids.h" | 9 #include "chrome/app/chrome_command_ids.h" |
| 10 #include "chrome/browser/download/download_history.h" | 10 #include "chrome/browser/download/download_history.h" |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 37 #endif | 37 #endif |
| 38 | 38 |
| 39 class SavePageBrowserTest : public InProcessBrowserTest { | 39 class SavePageBrowserTest : public InProcessBrowserTest { |
| 40 protected: | 40 protected: |
| 41 void SetUp() { | 41 void SetUp() { |
| 42 ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &test_dir_)); | 42 ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &test_dir_)); |
| 43 ASSERT_TRUE(save_dir_.CreateUniqueTempDir()); | 43 ASSERT_TRUE(save_dir_.CreateUniqueTempDir()); |
| 44 InProcessBrowserTest::SetUp(); | 44 InProcessBrowserTest::SetUp(); |
| 45 } | 45 } |
| 46 | 46 |
| 47 void GetPaths(const std::string& prefix, | |
| 48 GURL* url, | |
| 49 FilePath* full_file_name, | |
| 50 FilePath* dir) { | |
| 51 *url = URLRequestMockHTTPJob::GetMockUrl( | |
| 52 FilePath(kTestDir).AppendASCII(prefix + ".htm")); | |
| 53 ui_test_utils::NavigateToURL(browser(), *url); | |
|
Paweł Hajdan Jr.
2011/08/11 17:26:40
GetPath doesn't really correspond to NavigateToURL
achuithb
2011/08/11 23:21:59
The problem is that the function does 2 separate t
Paweł Hajdan Jr.
2011/08/12 16:48:57
SGTM
| |
| 54 | |
| 55 *full_file_name = save_dir_.path().AppendASCII(prefix + ".htm"); | |
| 56 *dir = save_dir_.path().AppendASCII(prefix + "_files"); | |
| 57 } | |
| 58 | |
| 59 TabContents* GetCurrentTab() const { | |
| 60 TabContents* current_tab = browser()->GetSelectedTabContents(); | |
| 61 EXPECT_TRUE(current_tab); | |
| 62 return current_tab; | |
| 63 } | |
| 64 | |
| 65 | |
| 47 GURL WaitForSavePackageToFinish() const { | 66 GURL WaitForSavePackageToFinish() const { |
| 48 ui_test_utils::TestNotificationObserver observer; | 67 ui_test_utils::TestNotificationObserver observer; |
| 49 ui_test_utils::RegisterAndWait(&observer, | 68 ui_test_utils::RegisterAndWait(&observer, |
| 50 content::NOTIFICATION_SAVE_PACKAGE_SUCCESSFULLY_FINISHED, | 69 content::NOTIFICATION_SAVE_PACKAGE_SUCCESSFULLY_FINISHED, |
| 51 NotificationService::AllSources()); | 70 NotificationService::AllSources()); |
| 52 return Details<DownloadItem>(observer.details()).ptr()->original_url(); | 71 return Details<DownloadItem>(observer.details()).ptr()->original_url(); |
| 53 } | 72 } |
| 54 | 73 |
| 55 #if defined(OS_CHROMEOS) | 74 #if defined(OS_CHROMEOS) |
| 56 const ActiveDownloadsUI::DownloadList& GetDownloads() const { | 75 const ActiveDownloadsUI::DownloadList& GetDownloads() const { |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 145 std::vector<DownloadHistoryInfo> history_entries_; | 164 std::vector<DownloadHistoryInfo> history_entries_; |
| 146 | 165 |
| 147 // Path to directory containing test data. | 166 // Path to directory containing test data. |
| 148 FilePath test_dir_; | 167 FilePath test_dir_; |
| 149 | 168 |
| 150 // Temporary directory we will save pages to. | 169 // Temporary directory we will save pages to. |
| 151 ScopedTempDir save_dir_; | 170 ScopedTempDir save_dir_; |
| 152 }; | 171 }; |
| 153 | 172 |
| 154 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, SaveHTMLOnly) { | 173 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, SaveHTMLOnly) { |
| 155 FilePath file_name(FILE_PATH_LITERAL("a.htm")); | 174 GURL url; |
| 156 GURL url = URLRequestMockHTTPJob::GetMockUrl( | 175 FilePath full_file_name, dir; |
| 157 FilePath(kTestDir).Append(file_name)); | 176 GetPaths("a", &url, &full_file_name, &dir); |
| 158 ui_test_utils::NavigateToURL(browser(), url); | 177 ASSERT_TRUE(GetCurrentTab()->SavePage(full_file_name, dir, |
| 159 | |
| 160 TabContents* current_tab = browser()->GetSelectedTabContents(); | |
| 161 ASSERT_TRUE(current_tab); | |
| 162 | |
| 163 FilePath full_file_name = save_dir_.path().Append(file_name); | |
| 164 FilePath dir = save_dir_.path().AppendASCII("a_files"); | |
| 165 ASSERT_TRUE(current_tab->SavePage(full_file_name, dir, | |
| 166 SavePackage::SAVE_AS_ONLY_HTML)); | 178 SavePackage::SAVE_AS_ONLY_HTML)); |
|
Paweł Hajdan Jr.
2011/08/11 17:26:40
nit: Isn't this line misaligned now?
achuithb
2011/08/11 23:21:59
Done.
| |
| 167 | 179 |
| 168 EXPECT_EQ(url, WaitForSavePackageToFinish()); | 180 EXPECT_EQ(url, WaitForSavePackageToFinish()); |
| 169 | 181 |
| 170 CheckDownloadUI(full_file_name); | 182 CheckDownloadUI(full_file_name); |
| 171 CheckDownloadHistory(url, full_file_name, 1); // a.htm is 1 file. | 183 CheckDownloadHistory(url, full_file_name, 1); // a.htm is 1 file. |
| 172 | 184 |
| 173 EXPECT_TRUE(file_util::PathExists(full_file_name)); | 185 EXPECT_TRUE(file_util::PathExists(full_file_name)); |
| 174 EXPECT_FALSE(file_util::PathExists(dir)); | 186 EXPECT_FALSE(file_util::PathExists(dir)); |
| 175 EXPECT_TRUE(file_util::ContentsEqual( | 187 EXPECT_TRUE(file_util::ContentsEqual( |
| 176 test_dir_.Append(FilePath(kTestDir)).Append(file_name), | 188 test_dir_.Append(FilePath(kTestDir)).Append(FILE_PATH_LITERAL("a.htm")), |
| 177 full_file_name)); | 189 full_file_name)); |
| 178 } | 190 } |
| 179 | 191 |
| 180 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, SaveViewSourceHTMLOnly) { | 192 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, SaveViewSourceHTMLOnly) { |
| 181 FilePath file_name(FILE_PATH_LITERAL("a.htm")); | 193 FilePath file_name(FILE_PATH_LITERAL("a.htm")); |
| 182 GURL view_source_url = URLRequestMockHTTPJob::GetMockViewSourceUrl( | 194 GURL view_source_url = URLRequestMockHTTPJob::GetMockViewSourceUrl( |
| 183 FilePath(kTestDir).Append(file_name)); | 195 FilePath(kTestDir).Append(file_name)); |
| 184 GURL actual_page_url = URLRequestMockHTTPJob::GetMockUrl( | 196 GURL actual_page_url = URLRequestMockHTTPJob::GetMockUrl( |
| 185 FilePath(kTestDir).Append(file_name)); | 197 FilePath(kTestDir).Append(file_name)); |
| 186 ui_test_utils::NavigateToURL(browser(), view_source_url); | 198 ui_test_utils::NavigateToURL(browser(), view_source_url); |
| 187 | 199 |
| 188 TabContents* current_tab = browser()->GetSelectedTabContents(); | |
| 189 ASSERT_TRUE(current_tab); | |
| 190 | |
| 191 FilePath full_file_name = save_dir_.path().Append(file_name); | 200 FilePath full_file_name = save_dir_.path().Append(file_name); |
| 192 FilePath dir = save_dir_.path().AppendASCII("a_files"); | 201 FilePath dir = save_dir_.path().AppendASCII("a_files"); |
| 193 | 202 |
| 194 ASSERT_TRUE(current_tab->SavePage(full_file_name, dir, | 203 ASSERT_TRUE(GetCurrentTab()->SavePage(full_file_name, dir, |
| 195 SavePackage::SAVE_AS_ONLY_HTML)); | 204 SavePackage::SAVE_AS_ONLY_HTML)); |
| 196 | 205 |
| 197 EXPECT_EQ(actual_page_url, WaitForSavePackageToFinish()); | 206 EXPECT_EQ(actual_page_url, WaitForSavePackageToFinish()); |
| 198 | 207 |
| 199 CheckDownloadUI(full_file_name); | 208 CheckDownloadUI(full_file_name); |
| 200 CheckDownloadHistory(actual_page_url, full_file_name, 1); // a.htm is 1 file. | 209 CheckDownloadHistory(actual_page_url, full_file_name, 1); // a.htm is 1 file. |
| 201 | 210 |
| 202 EXPECT_TRUE(file_util::PathExists(full_file_name)); | 211 EXPECT_TRUE(file_util::PathExists(full_file_name)); |
| 203 EXPECT_FALSE(file_util::PathExists(dir)); | 212 EXPECT_FALSE(file_util::PathExists(dir)); |
| 204 EXPECT_TRUE(file_util::ContentsEqual( | 213 EXPECT_TRUE(file_util::ContentsEqual( |
| 205 test_dir_.Append(FilePath(kTestDir)).Append(file_name), | 214 test_dir_.Append(FilePath(kTestDir)).Append(file_name), |
| 206 full_file_name)); | 215 full_file_name)); |
| 207 } | 216 } |
| 208 | 217 |
| 209 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, SaveCompleteHTML) { | 218 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, SaveCompleteHTML) { |
| 210 FilePath file_name(FILE_PATH_LITERAL("b.htm")); | 219 GURL url; |
| 211 GURL url = URLRequestMockHTTPJob::GetMockUrl( | 220 FilePath full_file_name, dir; |
| 212 FilePath(kTestDir).Append(file_name)); | 221 GetPaths("b", &url, &full_file_name, &dir); |
| 213 ui_test_utils::NavigateToURL(browser(), url); | 222 ASSERT_TRUE(GetCurrentTab()->SavePage(full_file_name, dir, |
| 214 | |
| 215 TabContents* current_tab = browser()->GetSelectedTabContents(); | |
| 216 ASSERT_TRUE(current_tab); | |
| 217 | |
| 218 FilePath full_file_name = save_dir_.path().Append(file_name); | |
| 219 FilePath dir = save_dir_.path().AppendASCII("b_files"); | |
| 220 ASSERT_TRUE(current_tab->SavePage(full_file_name, dir, | |
| 221 SavePackage::SAVE_AS_COMPLETE_HTML)); | 223 SavePackage::SAVE_AS_COMPLETE_HTML)); |
|
Paweł Hajdan Jr.
2011/08/11 17:26:40
nit: Isn't this line misaligned now?
achuithb
2011/08/11 23:21:59
Done.
| |
| 222 | 224 |
| 223 EXPECT_EQ(url, WaitForSavePackageToFinish()); | 225 EXPECT_EQ(url, WaitForSavePackageToFinish()); |
| 224 | 226 |
| 225 CheckDownloadUI(full_file_name); | 227 CheckDownloadUI(full_file_name); |
| 226 CheckDownloadHistory(url, full_file_name, 3); // b.htm is 3 files. | 228 CheckDownloadHistory(url, full_file_name, 3); // b.htm is 3 files. |
| 227 | 229 |
| 228 EXPECT_TRUE(file_util::PathExists(full_file_name)); | 230 EXPECT_TRUE(file_util::PathExists(full_file_name)); |
| 229 EXPECT_TRUE(file_util::PathExists(dir)); | 231 EXPECT_TRUE(file_util::PathExists(dir)); |
| 230 EXPECT_TRUE(file_util::TextContentsEqual( | 232 EXPECT_TRUE(file_util::TextContentsEqual( |
| 231 test_dir_.Append(FilePath(kTestDir)).AppendASCII("b.saved1.htm"), | 233 test_dir_.Append(FilePath(kTestDir)).AppendASCII("b.saved1.htm"), |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 249 | 251 |
| 250 GURL url = URLRequestMockHTTPJob::GetMockUrl( | 252 GURL url = URLRequestMockHTTPJob::GetMockUrl( |
| 251 FilePath(kTestDir).Append(file_name)); | 253 FilePath(kTestDir).Append(file_name)); |
| 252 ui_test_utils::NavigateToURL(browser(), url); | 254 ui_test_utils::NavigateToURL(browser(), url); |
| 253 | 255 |
| 254 FilePath full_file_name = save_dir_.path().AppendASCII( | 256 FilePath full_file_name = save_dir_.path().AppendASCII( |
| 255 std::string("Test page for saving page feature") + kAppendedExtension); | 257 std::string("Test page for saving page feature") + kAppendedExtension); |
| 256 FilePath dir = save_dir_.path().AppendASCII( | 258 FilePath dir = save_dir_.path().AppendASCII( |
| 257 "Test page for saving page feature_files"); | 259 "Test page for saving page feature_files"); |
| 258 | 260 |
| 259 TabContents* current_tab = browser()->GetSelectedTabContents(); | 261 ASSERT_TRUE(GetCurrentTab()->SavePage(full_file_name, dir, |
| 260 ASSERT_TRUE(current_tab); | |
| 261 | |
| 262 ASSERT_TRUE(current_tab->SavePage(full_file_name, dir, | |
| 263 SavePackage::SAVE_AS_COMPLETE_HTML)); | 262 SavePackage::SAVE_AS_COMPLETE_HTML)); |
|
Paweł Hajdan Jr.
2011/08/11 17:26:40
nit: Isn't this line misaligned now?
achuithb
2011/08/11 23:21:59
Done.
| |
| 264 | 263 |
| 265 EXPECT_EQ(url, WaitForSavePackageToFinish()); | 264 EXPECT_EQ(url, WaitForSavePackageToFinish()); |
| 266 | 265 |
| 267 CheckDownloadUI(full_file_name); | 266 CheckDownloadUI(full_file_name); |
| 268 CheckDownloadHistory(url, full_file_name, 3); // b.htm is 3 files. | 267 CheckDownloadHistory(url, full_file_name, 3); // b.htm is 3 files. |
| 269 | 268 |
| 270 EXPECT_TRUE(file_util::PathExists(full_file_name)); | 269 EXPECT_TRUE(file_util::PathExists(full_file_name)); |
| 271 EXPECT_TRUE(file_util::PathExists(dir)); | 270 EXPECT_TRUE(file_util::PathExists(dir)); |
| 272 EXPECT_TRUE(file_util::TextContentsEqual( | 271 EXPECT_TRUE(file_util::TextContentsEqual( |
| 273 test_dir_.Append(FilePath(kTestDir)).AppendASCII("b.saved2.htm"), | 272 test_dir_.Append(FilePath(kTestDir)).AppendASCII("b.saved2.htm"), |
| 274 full_file_name)); | 273 full_file_name)); |
| 275 EXPECT_TRUE(file_util::ContentsEqual( | 274 EXPECT_TRUE(file_util::ContentsEqual( |
| 276 test_dir_.Append(FilePath(kTestDir)).AppendASCII("1.png"), | 275 test_dir_.Append(FilePath(kTestDir)).AppendASCII("1.png"), |
| 277 dir.AppendASCII("1.png"))); | 276 dir.AppendASCII("1.png"))); |
| 278 EXPECT_TRUE(file_util::ContentsEqual( | 277 EXPECT_TRUE(file_util::ContentsEqual( |
| 279 test_dir_.Append(FilePath(kTestDir)).AppendASCII("1.css"), | 278 test_dir_.Append(FilePath(kTestDir)).AppendASCII("1.css"), |
| 280 dir.AppendASCII("1.css"))); | 279 dir.AppendASCII("1.css"))); |
| 281 } | 280 } |
| 282 | 281 |
| 283 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, RemoveFromList) { | 282 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, RemoveFromList) { |
| 284 FilePath file_name(FILE_PATH_LITERAL("a.htm")); | 283 GURL url; |
| 285 GURL url = URLRequestMockHTTPJob::GetMockUrl( | 284 FilePath full_file_name, dir; |
| 286 FilePath(kTestDir).Append(file_name)); | 285 GetPaths("a", &url, &full_file_name, &dir); |
| 287 ui_test_utils::NavigateToURL(browser(), url); | 286 ASSERT_TRUE(GetCurrentTab()->SavePage(full_file_name, dir, |
| 288 | |
| 289 TabContents* current_tab = browser()->GetSelectedTabContents(); | |
| 290 ASSERT_TRUE(current_tab); | |
| 291 | |
| 292 FilePath full_file_name = save_dir_.path().Append(file_name); | |
| 293 FilePath dir = save_dir_.path().AppendASCII("a_files"); | |
| 294 ASSERT_TRUE(current_tab->SavePage(full_file_name, dir, | |
| 295 SavePackage::SAVE_AS_ONLY_HTML)); | 287 SavePackage::SAVE_AS_ONLY_HTML)); |
|
Paweł Hajdan Jr.
2011/08/11 17:26:40
nit: Isn't this line misaligned now?
achuithb
2011/08/11 23:21:59
Done.
| |
| 296 | 288 |
| 297 EXPECT_EQ(url, WaitForSavePackageToFinish()); | 289 EXPECT_EQ(url, WaitForSavePackageToFinish()); |
| 298 | 290 |
| 299 CheckDownloadUI(full_file_name); | 291 CheckDownloadUI(full_file_name); |
| 300 CheckDownloadHistory(url, full_file_name, 1); // a.htm is 1 file. | 292 CheckDownloadHistory(url, full_file_name, 1); // a.htm is 1 file. |
| 301 | 293 |
| 302 EXPECT_EQ(GetDownloadManager()->RemoveAllDownloads(), 1); | 294 EXPECT_EQ(GetDownloadManager()->RemoveAllDownloads(), 1); |
| 303 | 295 |
| 304 #if defined(OS_CHROMEOS) | 296 #if defined(OS_CHROMEOS) |
| 305 EXPECT_EQ(GetDownloads().size(), 0U); | 297 EXPECT_EQ(GetDownloads().size(), 0U); |
| 306 #endif | 298 #endif |
| 307 | 299 |
| 308 // Should not be in history. | 300 // Should not be in history. |
| 309 QueryDownloadHistory(); | 301 QueryDownloadHistory(); |
| 310 EXPECT_EQ(std::find_if(history_entries_.begin(), history_entries_.end(), | 302 EXPECT_EQ(std::find_if(history_entries_.begin(), history_entries_.end(), |
| 311 DownloadHistoryInfoMatch(url, full_file_name, 1)), | 303 DownloadHistoryInfoMatch(url, full_file_name, 1)), |
| 312 history_entries_.end()); | 304 history_entries_.end()); |
| 313 | 305 |
| 314 EXPECT_TRUE(file_util::PathExists(full_file_name)); | 306 EXPECT_TRUE(file_util::PathExists(full_file_name)); |
| 315 EXPECT_FALSE(file_util::PathExists(dir)); | 307 EXPECT_FALSE(file_util::PathExists(dir)); |
| 316 EXPECT_TRUE(file_util::ContentsEqual( | 308 EXPECT_TRUE(file_util::ContentsEqual( |
| 317 test_dir_.Append(FilePath(kTestDir)).Append(file_name), | 309 test_dir_.Append(FilePath(kTestDir)).Append(FILE_PATH_LITERAL("a.htm")), |
| 318 full_file_name)); | 310 full_file_name)); |
| 319 } | 311 } |
| 320 | 312 |
| 313 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, Cancel) { | |
|
Paweł Hajdan Jr.
2011/08/11 17:26:40
nit: Add comment what this is testing.
achuithb
2011/08/11 23:21:59
Done.
| |
| 314 GURL url; | |
| 315 FilePath full_file_name, dir; | |
| 316 GetPaths("a", &url, &full_file_name, &dir); | |
| 317 scoped_refptr<SavePackage> save_package(new SavePackage(GetCurrentTab(), | |
| 318 SavePackage::SAVE_AS_ONLY_HTML, full_file_name, dir)); | |
| 321 } | 319 } |
| 320 | |
| 321 IN_PROC_BROWSER_TEST_F(SavePageBrowserTest, ExplicitCancel) { | |
| 322 GURL url; | |
| 323 FilePath full_file_name, dir; | |
| 324 GetPaths("a", &url, &full_file_name, &dir); | |
| 325 scoped_refptr<SavePackage> save_package(new SavePackage(GetCurrentTab(), | |
| 326 SavePackage::SAVE_AS_ONLY_HTML, full_file_name, dir)); | |
| 327 save_package->Cancel(true); | |
| 328 } | |
| 329 | |
| 330 } // namespace | |
|
Paweł Hajdan Jr.
2011/08/11 17:26:40
nit: Two spaces between } and //
achuithb
2011/08/11 23:21:59
Done.
| |
| OLD | NEW |