diff options
author | Torne (Richard Coles) <torne@google.com> | 2012-11-14 11:43:16 +0000 |
---|---|---|
committer | Torne (Richard Coles) <torne@google.com> | 2012-11-14 11:43:16 +0000 |
commit | 5821806d5e7f356e8fa4b058a389a808ea183019 (patch) | |
tree | e19f4793aac92e2c0d9a01087019a60d6657d838 /content/browser/download/save_package_browsertest.cc | |
parent | 8e79a8efe247f109aafd917a69e8a392961b3687 (diff) | |
download | chromium_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.cc | 63 |
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 |