Backed out changeset 2c46bcd325bb (bug 1633710) for Browser-chrome failures in extensions/test/xpinstall/browser_datauri.js. CLOSED TREE

This commit is contained in:
Dorel Luca 2020-07-01 18:12:19 +03:00
parent 255c22186f
commit 1e4fff31e4
12 changed files with 45 additions and 24 deletions

View File

@ -813,7 +813,7 @@ var ThirdPartyCookies = {
for (let perm of Services.perms.all) {
if (
perm.type == "cookie" &&
Services.eTLD.hasRootDomain(host, perm.principal.host)
Services.eTLD.hasRootDomain(host, perm.principal.URI.host)
) {
Services.perms.removePermission(perm);
}

View File

@ -7629,7 +7629,7 @@ var CanvasPermissionPromptHelper = {
let options = {
checkbox,
name: principal.host,
name: principal.URI.host,
learnMoreURL:
Services.urlFormatter.formatURLPref("app.support.baseURL") +
"fingerprint-permission",

View File

@ -51,7 +51,7 @@ add_task(async function test_toplevel_frame_permission() {
browser
);
is(
notification.options.principal.host,
notification.options.principal.URI.host,
"example.com",
"Should use top host for permission prompt!"
);

View File

@ -48,7 +48,7 @@ function waitForUnregister(host) {
return new Promise(resolve => {
let listener = {
onUnregister: registration => {
if (registration.principal.host != host) {
if (registration.principal.URI.host != host) {
return;
}
swm.removeListener(listener);
@ -72,7 +72,7 @@ async function createData(host) {
function moveOriginInTime(principals, endDate, host) {
for (let i = 0; i < principals.length; ++i) {
let principal = principals.queryElementAt(i, Ci.nsIPrincipal);
if (principal.host == host) {
if (principal.URI.host == host) {
sas.moveOriginInTime(principal, endDate - fiveHours);
return true;
}
@ -116,7 +116,10 @@ add_task(async function testWithRange() {
let found = 0;
for (let i = 0; i < principals.length; ++i) {
let principal = principals.queryElementAt(i, Ci.nsIPrincipal);
if (principal.host == "example.org" || principal.host == "example.com") {
if (
principal.URI.host == "example.org" ||
principal.URI.host == "example.com"
) {
found++;
}
}

View File

@ -232,7 +232,7 @@ async function addTestData(data) {
let principal = Services.scriptSecurityManager.createContentPrincipalFromOrigin(
site.origin
);
hosts.push(principal.host);
hosts.push(principal.URI.host);
}
return hosts;

View File

@ -485,7 +485,7 @@ var SiteDataManager = {
if (perm.principal.schemeIs("file")) {
Services.perms.removePermission(perm);
}
} else if (Services.eTLD.hasRootDomain(perm.principal.host, host)) {
} else if (Services.eTLD.hasRootDomain(perm.principal.URI.host, host)) {
Services.perms.removePermission(perm);
}
}

View File

@ -431,14 +431,14 @@ const QuotaCleaner = {
Services.obs.notifyObservers(
null,
"extension:purge-localStorage",
aPrincipal.host
aPrincipal.URI.host
);
// Clear sessionStorage
Services.obs.notifyObservers(
null,
"browser:purge-sessionStorage",
aPrincipal.host
aPrincipal.URI.host
);
// ServiceWorkers: they must be removed before cleaning QuotaManager.
@ -501,7 +501,7 @@ const QuotaCleaner = {
);
let host;
try {
host = principal.host;
host = principal.URI.host;
} catch (e) {
// There is no host for the given principal.
continue;
@ -698,7 +698,7 @@ const StorageAccessCleaner = {
let toBeRemoved = false;
try {
toBeRemoved = Services.eTLD.hasRootDomain(
perm.principal.host,
perm.principal.URI.host,
aHost
);
} catch (ex) {
@ -816,7 +816,10 @@ const PermissionsCleaner = {
for (let perm of Services.perms.all) {
let toBeRemoved;
try {
toBeRemoved = Services.eTLD.hasRootDomain(perm.principal.host, aHost);
toBeRemoved = Services.eTLD.hasRootDomain(
perm.principal.URI.host,
aHost
);
} catch (ex) {
continue;
}
@ -1143,7 +1146,7 @@ ClearDataService.prototype = Object.freeze({
// is to delete by host.
if (aCleaner.deleteByHost) {
return aCleaner.deleteByHost(
aPrincipal.host,
aPrincipal.URI.host,
aPrincipal.originAttributes
);
}

View File

@ -50,7 +50,7 @@ this.ServiceWorkerCleanUp = {
i,
Ci.nsIServiceWorkerRegistrationInfo
);
if (sw.principal.host == aHost) {
if (sw.principal.URI.host == aHost) {
promises.push(unregisterServiceWorker(sw));
}
}

View File

@ -91,7 +91,7 @@ var SiteDataTestUtils = {
origin
);
Services.cookies.add(
principal.host,
principal.URI.host,
principal.URI.pathQueryRef,
name,
value,
@ -190,7 +190,7 @@ var SiteDataTestUtils = {
principal.originAttributes,
cookie.originAttributes
) &&
cookie.host.includes(principal.host)
cookie.host.includes(principal.URI.host)
) {
return true;
}
@ -295,7 +295,7 @@ var SiteDataTestUtils = {
return new Promise(resolve => {
let listener = {
onRegister: registration => {
if (registration.principal.host != url.host) {
if (registration.principal.URI.host != url.host) {
return;
}
swm.removeListener(listener);
@ -322,7 +322,7 @@ var SiteDataTestUtils = {
return new Promise(resolve => {
let listener = {
onUnregister: registration => {
if (registration.principal.host != url.host) {
if (registration.principal.URI.host != url.host) {
return;
}
swm.removeListener(listener);

View File

@ -39,8 +39,15 @@ amContentHandler.prototype = {
const { triggeringPrincipal } = loadInfo;
let browsingContext = loadInfo.targetBrowsingContext;
let sourceHost = triggeringPrincipal.host;
let sourceURL = triggeringPrincipal.URI?.spec;
let sourceHost;
let sourceURL;
try {
sourceURL = triggeringPrincipal.URI.spec;
sourceHost = triggeringPrincipal.URI.host;
} catch (err) {
// Ignore errors when retrieving the host for the principal (e.g. null principals raise
// an NS_ERROR_FAILURE when principal.URI.host is accessed).
}
let install = {
uri: uri.spec,

View File

@ -151,8 +151,16 @@ InstallTrigger.prototype = {
}
}
let sourceHost = this._principal.host;
let sourceURL = this._principal.URI?.spec;
let sourceHost;
let sourceURL;
try {
sourceHost = this._principal.URI.host;
sourceURL = this._principal.URI.spec;
} catch (err) {
// Ignore errors when retrieving the host for the principal (e.g. null principals raise
// an NS_ERROR_FAILURE when principal.URI.host is accessed).
}
let installData = {
uri: url.spec,

View File

@ -256,7 +256,7 @@ class WebAPI extends APIObject {
// Provide the host from which the amWebAPI is being called
// (so that we can detect if the API is being used from the disco pane,
// AMO, testpilot or another unknown webpage).
sourceHost: triggeringPrincipal.host,
sourceHost: triggeringPrincipal.URI && triggeringPrincipal.URI.host,
sourceURL: triggeringPrincipal.URI && triggeringPrincipal.URI.spec,
};
return this._apiTask("createInstall", [installOptions], installInfo => {