summaryrefslogtreecommitdiff
path: root/content/browser/download/save_package_browsertest.cc
diff options
context:
space:
mode:
authorTorne (Richard Coles) <torne@google.com>2012-11-14 11:43:16 +0000
committerTorne (Richard Coles) <torne@google.com>2012-11-14 11:43:16 +0000
commit5821806d5e7f356e8fa4b058a389a808ea183019 (patch)
treee19f4793aac92e2c0d9a01087019a60d6657d838 /content/browser/download/save_package_browsertest.cc
parent8e79a8efe247f109aafd917a69e8a392961b3687 (diff)
downloadchromium_org-5821806d5e7f356e8fa4b058a389a808ea183019.tar.gz
Merge from Chromium at DEPS revision r167172
This commit was generated by merge_to_master.py. Change-Id: Ib8d56fd5ae39a2d7e8c91dcd76cc6d13f25f2aab
Diffstat (limited to 'content/browser/download/save_package_browsertest.cc')
-rw-r--r--content/browser/download/save_package_browsertest.cc63
1 files changed, 63 insertions, 0 deletions
diff --git a/content/browser/download/save_package_browsertest.cc b/content/browser/download/save_package_browsertest.cc
new file mode 100644
index 0000000000..021f583c06
--- /dev/null
+++ b/content/browser/download/save_package_browsertest.cc
@@ -0,0 +1,63 @@
+// Copyright (c) 2011 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 "base/scoped_temp_dir.h"
+#include "content/browser/download/save_package.h"
+#include "content/shell/shell.h"
+#include "content/test/content_browser_test.h"
+#include "content/test/content_browser_test_utils.h"
+
+namespace content {
+
+const char kTestFile[] = "files/simple_page.html";
+
+class SavePackageBrowserTest : public ContentBrowserTest {
+ protected:
+ void SetUp() OVERRIDE {
+ ASSERT_TRUE(save_dir_.CreateUniqueTempDir());
+ ContentBrowserTest::SetUp();
+ }
+
+ // Returns full paths of destination file and directory.
+ void GetDestinationPaths(const std::string& prefix,
+ FilePath* full_file_name,
+ FilePath* dir) {
+ *full_file_name = save_dir_.path().AppendASCII(prefix + ".htm");
+ *dir = save_dir_.path().AppendASCII(prefix + "_files");
+ }
+
+ // Temporary directory we will save pages to.
+ ScopedTempDir save_dir_;
+};
+
+// Create a SavePackage and delete it without calling Init.
+// SavePackage dtor has various asserts/checks that should not fire.
+IN_PROC_BROWSER_TEST_F(SavePackageBrowserTest, ImplicitCancel) {
+ ASSERT_TRUE(test_server()->Start());
+ GURL url = test_server()->GetURL(kTestFile);
+ NavigateToURL(shell(), url);
+ FilePath full_file_name, dir;
+ GetDestinationPaths("a", &full_file_name, &dir);
+ scoped_refptr<SavePackage> save_package(new SavePackage(
+ shell()->web_contents(), SAVE_PAGE_TYPE_AS_ONLY_HTML, full_file_name,
+ dir));
+ ASSERT_TRUE(test_server()->Stop());
+}
+
+// Create a SavePackage, call Cancel, then delete it.
+// SavePackage dtor has various asserts/checks that should not fire.
+IN_PROC_BROWSER_TEST_F(SavePackageBrowserTest, ExplicitCancel) {
+ ASSERT_TRUE(test_server()->Start());
+ GURL url = test_server()->GetURL(kTestFile);
+ NavigateToURL(shell(), url);
+ FilePath full_file_name, dir;
+ GetDestinationPaths("a", &full_file_name, &dir);
+ scoped_refptr<SavePackage> save_package(new SavePackage(
+ shell()->web_contents(), SAVE_PAGE_TYPE_AS_ONLY_HTML, full_file_name,
+ dir));
+ save_package->Cancel(true);
+ ASSERT_TRUE(test_server()->Stop());
+}
+
+} // namespace content