databag/app/sdk/__tests__/settings.tests.ts
2024-10-24 21:52:39 -07:00

109 lines
3.2 KiB
TypeScript

import { SettingsModule } from '../src/settings';
import { NoStore } from '../src/store';
import { Crypto } from '../src/crypto';
import { ConsoleLogging } from '../src/logging';
import { defaultConfigEntity } from '../src/entities';
import { Config } from '../src/types';
import { waitFor } from '../__mocks__/waitFor';
const testConfig = JSON.parse(JSON.stringify(defaultConfigEntity));
jest.mock('../src/net/fetchUtil', () => {
const fn = jest.fn().mockImplementation((url: string, options: { method: string, body: string }) => {
if (options.method === 'GET') {
testConfig.storageUsed = 2;
return Promise.resolve({ status: 200, json: () => (testConfig) });
}
if (options.method === 'PUT') {
if (url == 'http://test_url/account/notification?agent=test_token') {
testConfig.pushEnabled = JSON.parse(options.body);
}
if (url == 'http://test_url/account/searchable?agent=test_token') {
testConfig.searchable = JSON.parse(options.body);
}
if (url == 'http://test_url/account/seal?agent=test_token') {
testConfig.seal = JSON.parse(options.body);
}
return Promise.resolve({ state: 200 });
}
});
return {
fetchWithTimeout: fn,
checkResponse: () => {},
}
});
class TestCrypto implements Crypto {
public async pbkdfSalt() {
return { saltHex: 'SALT_HEX' }
}
public async pbkdfKey(saltHex: string, password: string) {
return { aesKeyHex: 'AES_KEY_HEX' }
}
public async aesKey() {
return { aesKeyHex: 'AES_KEY_HEX' };
}
public async aesIv() {
return { ivHex: 'IV_HEX' };
}
public async aesEncrypt(data: string, ivHex: string, aesKeyHex: string) {
return { encryptedDataB64: 'ENCRYPTED_DATA_B64' };
}
public async aesDecrypt(encryptedDataB64: string, ivHex: string, aesKeyHex: string) {
return { data: 'DATA' }
}
public async rsaKey() {
return { publicKeyB64: 'PUBLIC_KEY_B64', privateKeyB64: 'PRIVATE_KEY_B64' };
}
public async rsaEncrypt(data: string, publicKeyB64: string) {
return { encryptedDataB64: 'ENCRYPTED_DATA_B64' }
}
public async rsaDecrypt(encryptedDataB64: string, privateKeyB64: string) {
return { data: 'DATA' }
}
}
class TestStore extends NoStore {
public async getProfileRevision(): Promise<number> {
return 4;
}
}
test('settings module works', async () => {
let config: Config | null = null;
const log = new ConsoleLogging();
const store = new TestStore();
const crypto = new TestCrypto();
const settings = new SettingsModule(log, store, crypto, 'test_guid', 'test_token', 'test_url', false);
settings.addConfigListener((ev: Config) => { config = ev });
settings.setRevision(5);
await waitFor(() => (config?.storageUsed == 2));
settings.enableRegistry();
settings.setRevision(6);
await waitFor(() => Boolean(config?.searchable));
settings.disableRegistry();
settings.setRevision(7);
await waitFor(() => !Boolean(config?.searchable));
settings.enableNotifications();
settings.setRevision(8);
await waitFor(() => Boolean(config?.pushEnabled));
settings.disableNotifications();
settings.setRevision(9);
await waitFor(() => !Boolean(config?.pushEnabled));
settings.setSeal('password');
settings.setRevision(10);
await waitFor(() => Boolean(config?.sealSet));
});