gecko-dev/toolkit/components/extensions/test/xpcshell/test_ext_downloads.js
Kris Maglione 6faa871152 Bug 1288885: Migrate downloads mochitests to xpcshell. r=aswan
MozReview-Commit-ID: Z67uTNUcqD

--HG--
rename : toolkit/components/extensions/test/mochitest/file_download.html => toolkit/components/extensions/test/xpcshell/data/file_download.html
rename : toolkit/components/extensions/test/mochitest/file_download.txt => toolkit/components/extensions/test/xpcshell/data/file_download.txt
rename : toolkit/components/extensions/test/mochitest/test_ext_downloads.html => toolkit/components/extensions/test/xpcshell/test_ext_downloads.js
rename : toolkit/components/extensions/test/mochitest/test_chrome_ext_downloads_download.html => toolkit/components/extensions/test/xpcshell/test_ext_downloads_download.js
rename : toolkit/components/extensions/test/mochitest/test_chrome_ext_downloads_misc.html => toolkit/components/extensions/test/xpcshell/test_ext_downloads_misc.js
rename : toolkit/components/extensions/test/mochitest/test_chrome_ext_downloads_search.html => toolkit/components/extensions/test/xpcshell/test_ext_downloads_search.js
extra : source : abd51b3d2b52da0669680153e5321b9b843d6cd2
extra : histedit_source : b47606b4c1bc828ed445689f57ff600db69e1ad7
2016-07-22 18:49:50 -07:00

79 lines
2.6 KiB
JavaScript

/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* vim: set sts=2 sw=2 et tw=80: */
"use strict";
add_task(function* test_downloads_api_namespace_and_permissions() {
function backgroundScript() {
browser.test.assertTrue(!!browser.downloads, "`downloads` API is present.");
browser.test.assertTrue(!!browser.downloads.FilenameConflictAction,
"`downloads.FilenameConflictAction` enum is present.");
browser.test.assertTrue(!!browser.downloads.InterruptReason,
"`downloads.InterruptReason` enum is present.");
browser.test.assertTrue(!!browser.downloads.DangerType,
"`downloads.DangerType` enum is present.");
browser.test.assertTrue(!!browser.downloads.State,
"`downloads.State` enum is present.");
browser.test.notifyPass("downloads tests");
}
let extensionData = {
background: backgroundScript,
manifest: {
permissions: ["downloads", "downloads.open", "downloads.shelf"],
},
};
let extension = ExtensionTestUtils.loadExtension(extensionData);
yield extension.startup();
yield extension.awaitFinish("downloads tests");
yield extension.unload();
});
add_task(function* test_downloads_open_permission() {
function backgroundScript() {
browser.test.assertFalse("open" in browser.downloads,
"`downloads.open` permission is required.");
browser.test.notifyPass("downloads tests");
}
let extensionData = {
background: backgroundScript,
manifest: {
permissions: ["downloads"],
},
};
let extension = ExtensionTestUtils.loadExtension(extensionData);
yield extension.startup();
yield extension.awaitFinish("downloads tests");
yield extension.unload();
});
add_task(function* test_downloads_open() {
function backgroundScript() {
browser.downloads.open(10).then(() => {
browser.test.fail("Expected an error");
browser.test.notifyFail("downloads tests");
}, error => {
browser.test.assertEq(error.message, "Invalid download id 10",
"The error is informative.");
browser.test.notifyPass("downloads tests");
});
// TODO: Once downloads.{pause,cancel,resume} lands (bug 1245602) test that this gives a good
// error when called with an incompleted download.
}
let extensionData = {
background: backgroundScript,
manifest: {
permissions: ["downloads", "downloads.open"],
},
};
let extension = ExtensionTestUtils.loadExtension(extensionData);
yield extension.startup();
yield extension.awaitFinish("downloads tests");
yield extension.unload();
});