blob: 8ddb8f6996350d50775a40b27afaa2b9bfbf2590 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
const { CreditCard } = ChromeUtils.import(
"resource://gre/modules/CreditCard.jsm"
);
const { OSKeyStore } = ChromeUtils.import(
"resource://gre/modules/OSKeyStore.jsm"
);
const { OSKeyStoreTestUtils } = ChromeUtils.import(
"resource://testing-common/OSKeyStoreTestUtils.jsm"
);
let oldGetters = {};
let gFakeLoggedIn = true;
add_task(function setup() {
OSKeyStoreTestUtils.setup();
oldGetters.isLoggedIn = Object.getOwnPropertyDescriptor(
OSKeyStore,
"isLoggedIn"
).get;
OSKeyStore.__defineGetter__("isLoggedIn", () => gFakeLoggedIn);
registerCleanupFunction(async () => {
OSKeyStore.__defineGetter__("isLoggedIn", oldGetters.isLoggedIn);
await OSKeyStoreTestUtils.cleanup();
// CreditCard.jsm, OSKeyStore.jsm, and OSKeyStoreTestUtils.jsm are imported
// into the global scope -- the window -- above. If they're not deleted,
// they outlive the test and are reported as a leak.
delete window.OSKeyStore;
delete window.CreditCard;
delete window.OSKeyStoreTestUtils;
});
});
add_task(async function test_getLabel_withOSKeyStore() {
ok(
OSKeyStore.isLoggedIn,
"Confirm that OSKeyStore is faked and thinks it is logged in"
);
const ccNumber = "4111111111111111";
const encryptedNumber = await OSKeyStore.encrypt(ccNumber);
const decryptedNumber = await OSKeyStore.decrypt(encryptedNumber);
is(decryptedNumber, ccNumber, "Decrypted CC number should match original");
const name = "Foxkeh";
const label = CreditCard.getLabel({ name: "Foxkeh", number: ccNumber });
is(label, `**** 1111, ${name}`, "Label matches");
});
|