Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

"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"
);
});