|
| 1 | +import { GetDatasetStorageDriver } from '../../../src/datasets/domain/useCases/GetDatasetStorageDriver' |
| 2 | +import { IDatasetsRepository } from '../../../src/datasets/domain/repositories/IDatasetsRepository' |
| 3 | +import { StorageDriver } from '../../../src/datasets/domain/models/StorageDriver' |
| 4 | +import { ReadError } from '../../../src/core/domain/repositories/ReadError' |
| 5 | + |
| 6 | +describe('GetDatasetStorageDriver (unit)', () => { |
| 7 | + const testStorageDriver: StorageDriver = { |
| 8 | + name: 'local', |
| 9 | + type: 'filesystem', |
| 10 | + label: 'Local Storage', |
| 11 | + directUpload: true, |
| 12 | + directDownload: true, |
| 13 | + uploadOutOfBand: false |
| 14 | + } |
| 15 | + |
| 16 | + test('should return storage driver on repository success', async () => { |
| 17 | + const datasetsRepositoryStub: IDatasetsRepository = {} as IDatasetsRepository |
| 18 | + datasetsRepositoryStub.getDatasetStorageDriver = jest.fn().mockResolvedValue(testStorageDriver) |
| 19 | + const sut = new GetDatasetStorageDriver(datasetsRepositoryStub) |
| 20 | + |
| 21 | + const actual = await sut.execute(1) |
| 22 | + |
| 23 | + expect(actual).toEqual(testStorageDriver) |
| 24 | + expect(actual.name).toBe('local') |
| 25 | + expect(actual.type).toBe('filesystem') |
| 26 | + expect(actual.label).toBe('Local Storage') |
| 27 | + expect(actual.directUpload).toBe(true) |
| 28 | + expect(actual.directDownload).toBe(true) |
| 29 | + expect(actual.uploadOutOfBand).toBe(false) |
| 30 | + }) |
| 31 | + |
| 32 | + test('should return storage driver when using persistent id', async () => { |
| 33 | + const datasetsRepositoryStub: IDatasetsRepository = {} as IDatasetsRepository |
| 34 | + datasetsRepositoryStub.getDatasetStorageDriver = jest.fn().mockResolvedValue(testStorageDriver) |
| 35 | + const sut = new GetDatasetStorageDriver(datasetsRepositoryStub) |
| 36 | + |
| 37 | + const actual = await sut.execute('doi:10.77777/FK2/AAAAAA') |
| 38 | + |
| 39 | + expect(actual).toEqual(testStorageDriver) |
| 40 | + }) |
| 41 | + |
| 42 | + test('should return error result on repository error', async () => { |
| 43 | + const datasetsRepositoryStub: IDatasetsRepository = {} as IDatasetsRepository |
| 44 | + datasetsRepositoryStub.getDatasetStorageDriver = jest |
| 45 | + .fn() |
| 46 | + .mockRejectedValue(new ReadError('[404] Dataset not found')) |
| 47 | + const sut = new GetDatasetStorageDriver(datasetsRepositoryStub) |
| 48 | + |
| 49 | + await expect(sut.execute(1)).rejects.toThrow(ReadError) |
| 50 | + }) |
| 51 | +}) |
0 commit comments