diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /toolkit/mozapps/extensions/test/browser/browser_webapi_access.js | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip |
Add m-esr52 at 52.6.0
Diffstat (limited to 'toolkit/mozapps/extensions/test/browser/browser_webapi_access.js')
-rw-r--r-- | toolkit/mozapps/extensions/test/browser/browser_webapi_access.js | 127 |
1 files changed, 127 insertions, 0 deletions
diff --git a/toolkit/mozapps/extensions/test/browser/browser_webapi_access.js b/toolkit/mozapps/extensions/test/browser/browser_webapi_access.js new file mode 100644 index 000000000..f4b1dc745 --- /dev/null +++ b/toolkit/mozapps/extensions/test/browser/browser_webapi_access.js @@ -0,0 +1,127 @@ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ + */ + +registerCleanupFunction(() => { + Services.prefs.clearUserPref("extensions.webapi.testing"); +}); + +function check_frame_availability(browser) { + return ContentTask.spawn(browser, null, function*() { + let frame = content.document.getElementById("frame"); + return frame.contentWindow.document.getElementById("result").textContent == "true"; + }); +} + +function check_availability(browser) { + return ContentTask.spawn(browser, null, function*() { + return content.document.getElementById("result").textContent == "true"; + }); +} + +// Test that initially the API isn't available in the test domain +add_task(function* test_not_available() { + yield BrowserTestUtils.withNewTab(`${SECURE_TESTROOT}webapi_checkavailable.html`, + function* test_not_available(browser) { + let available = yield check_availability(browser); + ok(!available, "API should not be available."); + }) +}); + +// Test that with testing on the API is available in the test domain +add_task(function* test_available() { + Services.prefs.setBoolPref("extensions.webapi.testing", true); + + yield BrowserTestUtils.withNewTab(`${SECURE_TESTROOT}webapi_checkavailable.html`, + function* test_not_available(browser) { + let available = yield check_availability(browser); + ok(available, "API should be available."); + }) +}); + +// Test that the API is not available in a bad domain +add_task(function* test_bad_domain() { + yield BrowserTestUtils.withNewTab(`${SECURE_TESTROOT2}webapi_checkavailable.html`, + function* test_not_available(browser) { + let available = yield check_availability(browser); + ok(!available, "API should not be available."); + }) +}); + +// Test that the API is only available in https sites +add_task(function* test_not_available_http() { + yield BrowserTestUtils.withNewTab(`${TESTROOT}webapi_checkavailable.html`, + function* test_not_available(browser) { + let available = yield check_availability(browser); + ok(!available, "API should not be available."); + }) +}); + +// Test that the API is available when in a frame of the test domain +add_task(function* test_available_framed() { + yield BrowserTestUtils.withNewTab(`${SECURE_TESTROOT}webapi_checkframed.html`, + function* test_available(browser) { + let available = yield check_frame_availability(browser); + ok(available, "API should be available."); + }) +}); + +// Test that if the external frame is http then the inner frame doesn't have +// the API +add_task(function* test_not_available_http_framed() { + yield BrowserTestUtils.withNewTab(`${TESTROOT}webapi_checkframed.html`, + function* test_not_available(browser) { + let available = yield check_frame_availability(browser); + ok(!available, "API should not be available."); + }) +}); + +// Test that if the external frame is a bad domain then the inner frame doesn't +// have the API +add_task(function* test_not_available_framed() { + yield BrowserTestUtils.withNewTab(`${SECURE_TESTROOT2}webapi_checkframed.html`, + function* test_not_available(browser) { + let available = yield check_frame_availability(browser); + ok(!available, "API should not be available."); + }) +}); + +// Test that a window navigated to a bad domain doesn't allow access to the API +add_task(function* test_navigated_window() { + yield BrowserTestUtils.withNewTab(`${SECURE_TESTROOT2}webapi_checknavigatedwindow.html`, + function* test_available(browser) { + let tabPromise = BrowserTestUtils.waitForNewTab(gBrowser); + + yield ContentTask.spawn(browser, null, function*() { + yield content.wrappedJSObject.openWindow(); + }); + + // Should be a new tab open + let tab = yield tabPromise; + let loadPromise = BrowserTestUtils.browserLoaded(gBrowser.getBrowserForTab(tab)); + + ContentTask.spawn(browser, null, function*() { + content.wrappedJSObject.navigate(); + }); + + yield loadPromise; + + let available = yield ContentTask.spawn(browser, null, function*() { + return content.wrappedJSObject.check(); + }); + + ok(!available, "API should not be available."); + + gBrowser.removeTab(tab); + }) +}); + +// Check that if a page is embedded in a chrome content UI that it can still +// access the API. +add_task(function* test_chrome_frame() { + yield BrowserTestUtils.withNewTab(`${CHROMEROOT}webapi_checkchromeframe.xul`, + function* test_available(browser) { + let available = yield check_frame_availability(browser); + ok(available, "API should be available."); + }) +}); |