summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authorrdsmith@chromium.org <rdsmith@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-24 16:11:01 +0000
committerrdsmith@chromium.org <rdsmith@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-24 16:11:01 +0000
commitf2ae53a623e690b694c415223837d25980d3266b (patch)
tree6815049a0115b77058e7e53ce2512212f535edd4 /chrome
parent893d94428f49c139962f20b3085d2d7c01b90c3e (diff)
downloadchromium_src-f2ae53a623e690b694c415223837d25980d3266b.zip
chromium_src-f2ae53a623e690b694c415223837d25980d3266b.tar.gz
chromium_src-f2ae53a623e690b694c415223837d25980d3266b.tar.bz2
Disable downloads from "file:" or "data:" URLs.
BUG=119129 Review URL: http://codereview.chromium.org/9762002 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@128744 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/download/download_browsertest.cc74
-rw-r--r--chrome/test/data/download-anchor-attrib.html2
-rw-r--r--chrome/test/data/extensions/api_test/downloads/test.js20
3 files changed, 81 insertions, 15 deletions
diff --git a/chrome/browser/download/download_browsertest.cc b/chrome/browser/download/download_browsertest.cc
index f3c42a2..a4431bd 100644
--- a/chrome/browser/download/download_browsertest.cc
+++ b/chrome/browser/download/download_browsertest.cc
@@ -14,6 +14,7 @@
#include "base/stl_util.h"
#include "base/stringprintf.h"
#include "base/test/test_file_util.h"
+#include "base/test/thread_test_helper.h"
#include "base/utf_string_conversions.h"
#include "chrome/app/chrome_command_ids.h"
#include "chrome/browser/browser_process.h"
@@ -45,6 +46,7 @@
#include "chrome/common/url_constants.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "chrome/test/base/ui_test_utils.h"
+#include "content/public/browser/browser_thread.h"
#include "content/public/browser/download_item.h"
#include "content/public/browser/download_manager.h"
#include "content/public/browser/download_persistent_store_info.h"
@@ -314,6 +316,12 @@ class DownloadTest : public InProcessBrowserTest {
return test_dir_.Append(file);
}
+ GURL OriginFileUrl(FilePath file) {
+ std::string file_str = test_dir_.Append(file).MaybeAsASCII();
+ DCHECK(!file_str.empty()); // We only expect ASCII paths in tests.
+ return GURL("file://" + file_str);
+ }
+
// Location of the file destination (place to which it is downloaded).
FilePath DestinationFile(Browser* browser, FilePath file) {
return GetDownloadDirectory(browser).Append(file);
@@ -2458,3 +2466,69 @@ IN_PROC_BROWSER_TEST_F(DownloadTest, DownloadDangerousBlobData) {
EXPECT_EQ(1u, observer->NumDownloadsSeenInState(DownloadItem::COMPLETE));
EXPECT_EQ(1u, observer->NumDangerousDownloadsSeen());
}
+
+IN_PROC_BROWSER_TEST_F(DownloadTest, TestFileDataBlocker) {
+ ASSERT_TRUE(InitialSetup(false));
+ FilePath file(FILE_PATH_LITERAL("download-test1.lib"));
+ GURL urls[] = {
+ // file: URL
+ OriginFileUrl(file),
+
+ // data: URL
+ GURL("data:application/octet-stream,abcdefghijklmnop%01%02%03l")
+ };
+
+ for (size_t i = 0; i < arraysize(urls); i++) {
+ // Navigate & block until navigation is done.
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser(), urls[i], CURRENT_TAB,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_NAVIGATION);
+
+ // Do a round trip to the IO thread to increase chances of any download
+ // showing up on the UI thread.
+ // Using DownloadTestFlushObserver is overkill, but it'll do the job.
+ scoped_refptr<DownloadTestFlushObserver> flush_observer(
+ new DownloadTestFlushObserver(
+ DownloadManagerForBrowser(browser())));
+ flush_observer->WaitForFlush();
+
+ // Confirm no downloads
+ std::vector<DownloadItem*> downloads;
+ GetDownloads(browser(), &downloads);
+ EXPECT_EQ(0u, downloads.size());
+
+ DownloadManagerForBrowser(browser())->RemoveAllDownloads();
+
+ // Try the same thing with a direct download. Also check that the
+ // callback gives the right error.
+ WebContents* web_contents = browser()->GetSelectedWebContents();
+ ASSERT_TRUE(web_contents);
+ scoped_refptr<DownloadTestItemCreationObserver> creation_observer(
+ new DownloadTestItemCreationObserver);
+ // Only for cleanup if a download is actually created.
+ DownloadTestObserverTerminal backup_observer(
+ DownloadManagerForBrowser(browser()),
+ 1,
+ false,
+ DownloadTestObserver::ON_DANGEROUS_DOWNLOAD_FAIL);
+
+ DownloadManagerForBrowser(browser())->DownloadUrl(
+ urls[i], GURL(), "", false, -1, content::DownloadSaveInfo(),
+ web_contents, creation_observer->callback());
+
+ creation_observer->WaitForDownloadItemCreation();
+
+ EXPECT_FALSE(creation_observer->succeeded());
+ EXPECT_EQ(net::ERR_DISALLOWED_URL_SCHEME, creation_observer->error());
+ EXPECT_EQ(content::DownloadId::Invalid(), creation_observer->download_id());
+ downloads.clear();
+ GetDownloads(browser(), &downloads);
+ EXPECT_EQ(0u, downloads.size());
+
+ if (creation_observer->succeeded()) {
+ // Wait until the download is done. We don't care how it's finished.
+ backup_observer.WaitForFinished();
+ }
+ DownloadManagerForBrowser(browser())->RemoveAllDownloads();
+ }
+}
diff --git a/chrome/test/data/download-anchor-attrib.html b/chrome/test/data/download-anchor-attrib.html
index 142679e..7faf416 100644
--- a/chrome/test/data/download-anchor-attrib.html
+++ b/chrome/test/data/download-anchor-attrib.html
@@ -1,7 +1,7 @@
<html>
<head><title>Download Test for &lt;a download&gt;</title></head>
<body>
-<a id='red-dot' href="" download='a_red_dot.png'>Download Red Dot!</a>
+<a id='red-dot' href="anchor_download_test.png" download='a_red_dot.png'>Download Red Dot!</a>
<script>
window.setTimeout(function() {
var evt = document.createEvent("MouseEvent");
diff --git a/chrome/test/data/extensions/api_test/downloads/test.js b/chrome/test/data/extensions/api_test/downloads/test.js
index 56cbbc0..6726033 100644
--- a/chrome/test/data/extensions/api_test/downloads/test.js
+++ b/chrome/test/data/extensions/api_test/downloads/test.js
@@ -702,26 +702,18 @@ chrome.test.getConfig(function(testConfig) {
}));
},
- function downloadAllowDataURLs() {
- // Valid data URLs are valid URLs.
- var downloadId = getNextId();
- console.debug(downloadId);
+ function downloadDontAllowDataURLs() {
+ // We block downloading from data URLs.
downloads.download(
{'url': 'data:text/plain,hello'},
- chrome.test.callback(function(id) {
- chrome.test.assertEq(downloadId, id);
- }));
+ chrome.test.callbackFail("net::ERR_DISALLOWED_URL_SCHEME"));
},
- function downloadAllowFileURLs() {
- // Valid file URLs are valid URLs.
- var downloadId = getNextId();
- console.debug(downloadId);
+ function downloadDontAllowFileURLs() {
+ // We block downloading from file URLs.
downloads.download(
{'url': 'file:///'},
- chrome.test.callback(function(id) {
- chrome.test.assertEq(downloadId, id);
- }));
+ chrome.test.callbackFail("net::ERR_DISALLOWED_URL_SCHEME"));
},
// TODO(benjhayden): Set up a test ftp server.