mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-20 16:55:40 +00:00
1a5fdde435
Differential Revision: https://phabricator.services.mozilla.com/D40025 --HG-- extra : moz-landing-system : lando
76 lines
2.8 KiB
JavaScript
76 lines
2.8 KiB
JavaScript
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* 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("identity-icon"),
|
|
"Should see identity icon"
|
|
);
|
|
let identityIconImage = gBrowser.ownerGlobal
|
|
.getComputedStyle(document.getElementById("identity-icon"))
|
|
.getPropertyValue("list-style-image");
|
|
let securityViewBG = gBrowser.ownerGlobal
|
|
.getComputedStyle(
|
|
document
|
|
.getElementById("identity-popup-securityView")
|
|
.getElementsByClassName("identity-popup-security-connection")[0]
|
|
)
|
|
.getPropertyValue("background-image");
|
|
let securityContentBG = gBrowser.ownerGlobal
|
|
.getComputedStyle(
|
|
document
|
|
.getElementById("identity-popup-mainView")
|
|
.getElementsByClassName("identity-popup-security-connection")[0]
|
|
)
|
|
.getPropertyValue("background-image");
|
|
is(
|
|
identityIconImage,
|
|
'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);
|
|
});
|