import { Mock } from 'ts-mockery'; import { CsvJson } from 'csvjson'; import { ServersImporter } from '../../../src/servers/services/ServersImporter'; import { RegularServer } from '../../../src/servers/data'; describe('ServersImporter', () => { const servers: RegularServer[] = [Mock.all(), Mock.all()]; const toObject = jest.fn().mockReturnValue(servers); const csvjsonMock = Mock.of({ toObject }); const readAsText = jest.fn(); const fileReaderMock = Mock.of({ readAsText, addEventListener: (_eventName: string, listener: (e: ProgressEvent) => void) => listener( Mock.of>({ target: { result: '' } }), ), }); const importer = new ServersImporter(csvjsonMock, () => fileReaderMock); beforeEach(jest.clearAllMocks); describe('importServersFromFile', () => { it('rejects with error if no file was provided', async () => { await expect(importer.importServersFromFile()).rejects.toEqual( new Error('No file provided'), ); }); it('rejects with error if parsing the file fails', async () => { const expectedError = new Error('Error parsing file'); toObject.mockImplementation(() => { throw expectedError; }); await expect(importer.importServersFromFile(Mock.of({ type: 'text/html' }))).rejects.toEqual(expectedError); }); it.each([ [{}], [undefined], [[{ foo: 'bar' }]], [ [ { url: 1, apiKey: 1, name: 1, }, ], ], [ [ { url: 'foo', apiKey: 'foo', name: 'foo', }, { bar: 'foo' }, ], ], ])('rejects with error if provided file does not parse to valid list of servers', async (parsedObject) => { toObject.mockReturnValue(parsedObject); await expect(importer.importServersFromFile(Mock.of({ type: 'text/html' }))).rejects.toEqual( new Error('Provided file does not have the right format.'), ); }); it('reads file when a CSV containing valid servers is provided', async () => { const expectedServers = [ { url: 'foo', apiKey: 'foo', name: 'foo', }, { url: 'bar', apiKey: 'bar', name: 'bar', }, ]; toObject.mockReturnValue(expectedServers); const result = await importer.importServersFromFile(Mock.all()); expect(result).toEqual(expectedServers); expect(readAsText).toHaveBeenCalledTimes(1); expect(toObject).toHaveBeenCalledTimes(1); }); }); });