Mypal68/browser/base/content/test/general/browser_addCertException.js
2022-04-16 07:41:55 +03:00

74 lines
2.7 KiB
JavaScript

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
// Test adding a certificate exception by attempting to browse to a site with
// a bad certificate, being redirected to the internal about:certerror page,
// using the button contained therein to load the certificate exception
// dialog, using that to add an exception, and finally successfully visiting
// the site, including showing the right identity box and control center icons.
add_task(async function() {
await BrowserTestUtils.openNewForegroundTab(gBrowser);
await loadBadCertPage("https://expired.example.com");
let { gIdentityHandler } = gBrowser.ownerGlobal;
let promisePanelOpen = BrowserTestUtils.waitForEvent(
gIdentityHandler._identityPopup,
"popupshown"
);
gIdentityHandler._identityBox.click();
await promisePanelOpen;
let promiseViewShown = BrowserTestUtils.waitForEvent(
gIdentityHandler._identityPopup,
"ViewShown"
);
document.getElementById("identity-popup-security-expander").click();
await promiseViewShown;
is_element_visible(
document.getElementById("connection-icon"),
"Should see connection icon"
);
let connectionIconImage = gBrowser.ownerGlobal
.getComputedStyle(document.getElementById("connection-icon"))
.getPropertyValue("list-style-image");
let securityViewBG = gBrowser.ownerGlobal
.getComputedStyle(
document
.getElementById("identity-popup-securityView")
.getElementsByClassName("identity-popup-security-content")[0]
)
.getPropertyValue("background-image");
let securityContentBG = gBrowser.ownerGlobal
.getComputedStyle(
document
.getElementById("identity-popup-mainView")
.getElementsByClassName("identity-popup-security-content")[0]
)
.getPropertyValue("background-image");
is(
connectionIconImage,
'url("chrome://browser/skin/connection-mixed-passive-loaded.svg")',
"Using expected icon image in the identity block"
);
is(
securityViewBG,
'url("chrome://browser/skin/connection-mixed-passive-loaded.svg")',
"Using expected icon image in the Control Center main view"
);
is(
securityContentBG,
'url("chrome://browser/skin/connection-mixed-passive-loaded.svg")',
"Using expected icon image in the Control Center subview"
);
gIdentityHandler._identityPopup.hidden = true;
let certOverrideService = Cc[
"@mozilla.org/security/certoverride;1"
].getService(Ci.nsICertOverrideService);
certOverrideService.clearValidityOverride("expired.example.com", -1);
BrowserTestUtils.removeTab(gBrowser.selectedTab);
});