-
Notifications
You must be signed in to change notification settings - Fork 11
Expand file tree
/
Copy pathGetFileVersionSummaries.test.ts
More file actions
44 lines (40 loc) · 1.67 KB
/
Copy pathGetFileVersionSummaries.test.ts
File metadata and controls
44 lines (40 loc) · 1.67 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import { IFilesRepository } from '../../../src/files/domain/repositories/IFilesRepository'
import { ReadError } from '../../../src'
import { GetFileVersionSummaries } from '../../../src/files/domain/useCases/GetFileVersionSummaries'
import { FileVersionSummaryInfo } from '../../../src/files/domain/models/FileVersionSummaryInfo'
describe('execute', () => {
test('should return file on repository success when passing numeric id', async () => {
const filesRepositoryStub: IFilesRepository = {} as IFilesRepository
const fileVersionSummaries: FileVersionSummaryInfo[] = [
{
datasetVersion: '1.0',
versionNumber: 1,
versionMinorNumber: 0,
contributors: 'John Doe',
publishedDate: '2023-01-01',
fileDifferenceSummary: {
FileMetadata: [
{
name: 'file.txt',
action: 'Added'
}
]
},
isDraft: false,
isDeaccessioned: false,
isReleased: false,
datafileId: 1
}
]
filesRepositoryStub.getFileVersionSummaries = jest.fn().mockResolvedValue(fileVersionSummaries)
const sut = new GetFileVersionSummaries(filesRepositoryStub)
const actualFileVersionSummaries = await sut.execute(1)
expect(actualFileVersionSummaries).toEqual(fileVersionSummaries)
})
test('should return error result on repository error', async () => {
const filesRepositoryStub: IFilesRepository = {} as IFilesRepository
filesRepositoryStub.getFileVersionSummaries = jest.fn().mockRejectedValue(new ReadError())
const sut = new GetFileVersionSummaries(filesRepositoryStub)
await expect(sut.execute(1)).rejects.toThrow(ReadError)
})
})