forked from mirrors/gecko-dev
The public key pinning implementation is much less complex than the HSTS implementation, and only needs a small subset of the parameters of the latter. Furthermore, the information it relies on is static, and so is safe to access from content processes. This patch separates the two implementations, thus simplifying both of them and avoiding some unnecessary IPC calls in the process. Differential Revision: https://phabricator.services.mozilla.com/D117096
86 lines
2.7 KiB
JavaScript
86 lines
2.7 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/
|
|
*/
|
|
/* eslint-disable mozilla/no-arbitrary-setTimeout */
|
|
|
|
var secureURL =
|
|
"https://example.com/browser/browser/base/content/test/general/browser_star_hsts.sjs";
|
|
var unsecureURL =
|
|
"http://example.com/browser/browser/base/content/test/general/browser_star_hsts.sjs";
|
|
|
|
add_task(async function test_star_redirect() {
|
|
registerCleanupFunction(async () => {
|
|
// Ensure to remove example.com from the HSTS list.
|
|
let sss = Cc["@mozilla.org/ssservice;1"].getService(
|
|
Ci.nsISiteSecurityService
|
|
);
|
|
sss.resetState(
|
|
NetUtil.newURI("http://example.com/"),
|
|
0,
|
|
Services.prefs.getBoolPref("privacy.partition.network_state")
|
|
? { partitionKey: "(http,example.com)" }
|
|
: {}
|
|
);
|
|
await PlacesUtils.bookmarks.eraseEverything();
|
|
gBrowser.removeCurrentTab();
|
|
});
|
|
|
|
let tab = (gBrowser.selectedTab = BrowserTestUtils.addTab(gBrowser));
|
|
// This will add the page to the HSTS cache.
|
|
await promiseTabLoadEvent(tab, secureURL, secureURL);
|
|
// This should transparently be redirected to the secure page.
|
|
await promiseTabLoadEvent(tab, unsecureURL, secureURL);
|
|
|
|
await promiseStarState(BookmarkingUI.STATUS_UNSTARRED);
|
|
|
|
StarUI._createPanelIfNeeded();
|
|
let bookmarkPanel = document.getElementById("editBookmarkPanel");
|
|
let shownPromise = promisePopupShown(bookmarkPanel);
|
|
BookmarkingUI.star.click();
|
|
await shownPromise;
|
|
|
|
is(BookmarkingUI.status, BookmarkingUI.STATUS_STARRED, "The star is starred");
|
|
});
|
|
|
|
/**
|
|
* Waits for the star to reflect the expected state.
|
|
*/
|
|
function promiseStarState(aValue) {
|
|
return new Promise(resolve => {
|
|
let expectedStatus = aValue
|
|
? BookmarkingUI.STATUS_STARRED
|
|
: BookmarkingUI.STATUS_UNSTARRED;
|
|
(function checkState() {
|
|
if (
|
|
BookmarkingUI.status == BookmarkingUI.STATUS_UPDATING ||
|
|
BookmarkingUI.status != expectedStatus
|
|
) {
|
|
info("Waiting for star button change.");
|
|
setTimeout(checkState, 1000);
|
|
} else {
|
|
resolve();
|
|
}
|
|
})();
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Starts a load in an existing tab and waits for it to finish (via some event).
|
|
*
|
|
* @param aTab
|
|
* The tab to load into.
|
|
* @param aUrl
|
|
* The url to load.
|
|
* @param [optional] aFinalURL
|
|
* The url to wait for, same as aURL if not defined.
|
|
* @return {Promise} resolved when the event is handled.
|
|
*/
|
|
function promiseTabLoadEvent(aTab, aURL, aFinalURL) {
|
|
if (!aFinalURL) {
|
|
aFinalURL = aURL;
|
|
}
|
|
|
|
info("Wait for load tab event");
|
|
BrowserTestUtils.loadURI(aTab.linkedBrowser, aURL);
|
|
return BrowserTestUtils.browserLoaded(aTab.linkedBrowser, false, aFinalURL);
|
|
}
|