38ab92da5d
Co-authored-by: Scott Nonnenberg <scott@signal.org>
188 lines
4.6 KiB
JavaScript
188 lines
4.6 KiB
JavaScript
// Copyright 2017-2020 Signal Messenger, LLC
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
/* global libsignal */
|
|
|
|
describe('AccountManager', () => {
|
|
let accountManager;
|
|
|
|
beforeEach(() => {
|
|
accountManager = new window.textsecure.AccountManager();
|
|
});
|
|
|
|
describe('#cleanSignedPreKeys', () => {
|
|
let originalProtocolStorage;
|
|
let signedPreKeys;
|
|
const DAY = 1000 * 60 * 60 * 24;
|
|
|
|
beforeEach(async () => {
|
|
const identityKey = await libsignal.KeyHelper.generateIdentityKeyPair();
|
|
|
|
originalProtocolStorage = window.textsecure.storage.protocol;
|
|
window.textsecure.storage.protocol = {
|
|
getIdentityKeyPair() {
|
|
return identityKey;
|
|
},
|
|
loadSignedPreKeys() {
|
|
return Promise.resolve(signedPreKeys);
|
|
},
|
|
};
|
|
});
|
|
afterEach(() => {
|
|
window.textsecure.storage.protocol = originalProtocolStorage;
|
|
});
|
|
|
|
describe('encrypted device name', () => {
|
|
it('roundtrips', async () => {
|
|
const deviceName = 'v2.5.0 on Ubunto 20.04';
|
|
const encrypted = await accountManager.encryptDeviceName(deviceName);
|
|
assert.strictEqual(typeof encrypted, 'string');
|
|
const decrypted = await accountManager.decryptDeviceName(encrypted);
|
|
|
|
assert.strictEqual(decrypted, deviceName);
|
|
});
|
|
|
|
it('handles null deviceName', async () => {
|
|
const encrypted = await accountManager.encryptDeviceName(null);
|
|
assert.strictEqual(encrypted, null);
|
|
});
|
|
});
|
|
|
|
it('keeps three confirmed keys even if over a month old', () => {
|
|
const now = Date.now();
|
|
signedPreKeys = [
|
|
{
|
|
keyId: 1,
|
|
created_at: now - DAY * 32,
|
|
confirmed: true,
|
|
},
|
|
{
|
|
keyId: 2,
|
|
created_at: now - DAY * 34,
|
|
confirmed: true,
|
|
},
|
|
{
|
|
keyId: 3,
|
|
created_at: now - DAY * 38,
|
|
confirmed: true,
|
|
},
|
|
];
|
|
|
|
// should be no calls to store.removeSignedPreKey, would cause crash
|
|
return accountManager.cleanSignedPreKeys();
|
|
});
|
|
|
|
it('eliminates confirmed keys over a month old, if more than three', async () => {
|
|
const now = Date.now();
|
|
signedPreKeys = [
|
|
{
|
|
keyId: 1,
|
|
created_at: now - DAY * 32,
|
|
confirmed: true,
|
|
},
|
|
{
|
|
keyId: 2,
|
|
created_at: now - DAY * 31,
|
|
confirmed: true,
|
|
},
|
|
{
|
|
keyId: 3,
|
|
created_at: now - DAY * 24,
|
|
confirmed: true,
|
|
},
|
|
{
|
|
keyId: 4,
|
|
created_at: now - DAY * 38,
|
|
confirmed: true,
|
|
},
|
|
{
|
|
keyId: 5,
|
|
created_at: now - DAY,
|
|
confirmed: true,
|
|
},
|
|
];
|
|
|
|
let count = 0;
|
|
window.textsecure.storage.protocol.removeSignedPreKey = keyId => {
|
|
if (keyId !== 1 && keyId !== 4) {
|
|
throw new Error(`Wrong keys were eliminated! ${keyId}`);
|
|
}
|
|
|
|
count += 1;
|
|
};
|
|
|
|
await accountManager.cleanSignedPreKeys();
|
|
assert.strictEqual(count, 2);
|
|
});
|
|
|
|
it('keeps at least three unconfirmed keys if no confirmed', async () => {
|
|
const now = Date.now();
|
|
signedPreKeys = [
|
|
{
|
|
keyId: 1,
|
|
created_at: now - DAY * 32,
|
|
},
|
|
{
|
|
keyId: 2,
|
|
created_at: now - DAY * 44,
|
|
},
|
|
{
|
|
keyId: 3,
|
|
created_at: now - DAY * 36,
|
|
},
|
|
{
|
|
keyId: 4,
|
|
created_at: now - DAY * 20,
|
|
},
|
|
];
|
|
|
|
let count = 0;
|
|
window.textsecure.storage.protocol.removeSignedPreKey = keyId => {
|
|
if (keyId !== 2) {
|
|
throw new Error(`Wrong keys were eliminated! ${keyId}`);
|
|
}
|
|
|
|
count += 1;
|
|
};
|
|
|
|
await accountManager.cleanSignedPreKeys();
|
|
assert.strictEqual(count, 1);
|
|
});
|
|
|
|
it('if some confirmed keys, keeps unconfirmed to addd up to three total', async () => {
|
|
const now = Date.now();
|
|
signedPreKeys = [
|
|
{
|
|
keyId: 1,
|
|
created_at: now - DAY * 32,
|
|
confirmed: true,
|
|
},
|
|
{
|
|
keyId: 2,
|
|
created_at: now - DAY * 44,
|
|
confirmed: true,
|
|
},
|
|
{
|
|
keyId: 3,
|
|
created_at: now - DAY * 36,
|
|
},
|
|
{
|
|
keyId: 4,
|
|
created_at: now - DAY * 20,
|
|
},
|
|
];
|
|
|
|
let count = 0;
|
|
window.textsecure.storage.protocol.removeSignedPreKey = keyId => {
|
|
if (keyId !== 3) {
|
|
throw new Error(`Wrong keys were eliminated! ${keyId}`);
|
|
}
|
|
|
|
count += 1;
|
|
};
|
|
|
|
await accountManager.cleanSignedPreKeys();
|
|
assert.strictEqual(count, 1);
|
|
});
|
|
});
|
|
});
|