diff options
author | rdsmith@chromium.org <rdsmith@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-03-24 16:11:01 +0000 |
---|---|---|
committer | rdsmith@chromium.org <rdsmith@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-03-24 16:11:01 +0000 |
commit | f2ae53a623e690b694c415223837d25980d3266b (patch) | |
tree | 6815049a0115b77058e7e53ce2512212f535edd4 /chrome | |
parent | 893d94428f49c139962f20b3085d2d7c01b90c3e (diff) | |
download | chromium_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.cc | 74 | ||||
-rw-r--r-- | chrome/test/data/download-anchor-attrib.html | 2 | ||||
-rw-r--r-- | chrome/test/data/extensions/api_test/downloads/test.js | 20 |
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 <a download></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. |