import { BaseUrlVerifier } from '../../../src/init/BaseUrlVerifier'; import type { Logger } from '../../../src/logging/Logger'; import { getLoggerFor } from '../../../src/logging/LogUtil'; import type { KeyValueStorage } from '../../../src/storage/keyvalue/KeyValueStorage'; jest.mock('../../../src/logging/LogUtil', (): any => { const logger: Logger = { warn: jest.fn() } as any; return { getLoggerFor: (): Logger => logger }; }); describe('A BaseUrlVerifier', (): void => { const logger: jest.Mocked = getLoggerFor(BaseUrlVerifier) as any; const baseUrl1 = 'http://base1.example.com/'; const baseUrl2 = 'http://base2.example.com/'; const storageKey = 'uniqueKey'; let storage: KeyValueStorage; beforeEach(async(): Promise => { storage = new Map() as any; jest.clearAllMocks(); }); it('stores the value if no value was stored yet.', async(): Promise => { const initializer = new BaseUrlVerifier(baseUrl1, storageKey, storage); await expect(initializer.handle()).resolves.toBeUndefined(); expect(logger.warn).toHaveBeenCalledTimes(0); }); it('logs a warning in case the value changes.', async(): Promise => { let initializer = new BaseUrlVerifier(baseUrl1, storageKey, storage); await expect(initializer.handle()).resolves.toBeUndefined(); expect(logger.warn).toHaveBeenCalledTimes(0); initializer = new BaseUrlVerifier(baseUrl2, storageKey, storage); await expect(initializer.handle()).resolves.toBeUndefined(); expect(logger.warn).toHaveBeenCalledTimes(1); }); });