136 lines
3.8 KiB
JavaScript
136 lines
3.8 KiB
JavaScript
"use strict";
|
|
|
|
const profileDir = do_get_profile();
|
|
|
|
const { ContextualIdentityService } = ChromeUtils.importESModule(
|
|
"resource://gre/modules/ContextualIdentityService.sys.mjs"
|
|
);
|
|
|
|
const TEST_STORE_FILE_PATH = PathUtils.join(
|
|
profileDir.path,
|
|
"test-containers.json"
|
|
);
|
|
|
|
// Test the containers JSON file migrations.
|
|
add_task(async function migratedFile() {
|
|
// Let's create a file that has to be migrated.
|
|
const oldFileData = {
|
|
version: 2,
|
|
lastUserContextId: 6,
|
|
identities: [
|
|
{
|
|
userContextId: 1,
|
|
public: true,
|
|
icon: "fingerprint",
|
|
color: "blue",
|
|
l10nID: "userContextPersonal.label",
|
|
accessKey: "userContextPersonal.accesskey",
|
|
},
|
|
{
|
|
userContextId: 2,
|
|
public: true,
|
|
icon: "briefcase",
|
|
color: "orange",
|
|
l10nID: "userContextWork.label",
|
|
accessKey: "userContextWork.accesskey",
|
|
},
|
|
{
|
|
userContextId: 3,
|
|
public: true,
|
|
icon: "dollar",
|
|
color: "green",
|
|
l10nID: "userContextBanking.label",
|
|
accessKey: "userContextBanking.accesskey",
|
|
},
|
|
{
|
|
userContextId: 4,
|
|
public: true,
|
|
icon: "cart",
|
|
color: "pink",
|
|
l10nID: "userContextShopping.label",
|
|
accessKey: "userContextShopping.accesskey",
|
|
},
|
|
{
|
|
userContextId: 5,
|
|
public: false,
|
|
icon: "",
|
|
color: "",
|
|
name: "userContextIdInternal.thumbnail",
|
|
accessKey: "",
|
|
},
|
|
{
|
|
userContextId: 6,
|
|
public: true,
|
|
icon: "cart",
|
|
color: "ping",
|
|
name: "Custom user-created identity",
|
|
},
|
|
],
|
|
};
|
|
|
|
await IOUtils.writeJSON(TEST_STORE_FILE_PATH, oldFileData, {
|
|
tmpPath: TEST_STORE_FILE_PATH + ".tmp",
|
|
});
|
|
|
|
let cis =
|
|
ContextualIdentityService.createNewInstanceForTesting(TEST_STORE_FILE_PATH);
|
|
ok(!!cis, "We have our instance of ContextualIdentityService");
|
|
|
|
// Check that the custom user-created identity exists.
|
|
|
|
const expectedPublicLength = oldFileData.identities.filter(
|
|
identity => identity.public
|
|
).length;
|
|
const publicIdentities = cis.getPublicIdentities();
|
|
const oldLastIdentity =
|
|
oldFileData.identities[oldFileData.identities.length - 1];
|
|
const customUserCreatedIdentity = publicIdentities
|
|
.filter(identity => identity.name === oldLastIdentity.name)
|
|
.pop();
|
|
|
|
equal(
|
|
publicIdentities.length,
|
|
expectedPublicLength,
|
|
"We should have the expected number of public identities"
|
|
);
|
|
ok(!!customUserCreatedIdentity, "Got the custom user-created identity");
|
|
|
|
Assert.deepEqual(
|
|
cis.getPublicUserContextIds(),
|
|
cis.getPublicIdentities().map(identity => identity.userContextId),
|
|
"getPublicUserContextIds has matching user context IDs"
|
|
);
|
|
|
|
// Check that the reserved userContextIdInternal.webextStorageLocal identity exists.
|
|
|
|
const webextStorageLocalPrivateId =
|
|
ContextualIdentityService._defaultIdentities
|
|
.filter(
|
|
identity => identity.name === "userContextIdInternal.webextStorageLocal"
|
|
)
|
|
.pop().userContextId;
|
|
|
|
const privWebExtStorageLocal = cis.getPrivateIdentity(
|
|
"userContextIdInternal.webextStorageLocal"
|
|
);
|
|
equal(
|
|
privWebExtStorageLocal && privWebExtStorageLocal.userContextId,
|
|
webextStorageLocalPrivateId,
|
|
"We should have the default userContextIdInternal.webextStorageLocal private identity"
|
|
);
|
|
|
|
// Check that all StringBundle references are replaced by Fluent references.
|
|
|
|
equal(
|
|
cis
|
|
.getPublicIdentities()
|
|
.filter(identity => identity.l10nID || identity.accessKey).length,
|
|
0,
|
|
"No StringBundle l10nID or accessKey should be set"
|
|
);
|
|
equal(
|
|
cis.getPublicIdentities().filter(identity => identity.l10nId).length,
|
|
oldFileData.identities.filter(identity => identity.l10nID).length,
|
|
"All StringBundle references should be replaced by Fluent references"
|
|
);
|
|
});
|