|
1 | 1 | import { Test, TestingModule } from '@nestjs/testing'; |
2 | 2 | import { createMock } from '@golevelup/ts-jest'; |
3 | 3 | import { FolderUseCases, SortParamsFolder } from './folder.usecase'; |
4 | | -import { |
5 | | - SequelizeFolderRepository, |
6 | | - FolderRepository, |
7 | | -} from './folder.repository'; |
| 4 | +import { SequelizeFolderRepository } from './folder.repository'; |
8 | 5 | import { |
9 | 6 | BadRequestException, |
10 | 7 | ConflictException, |
@@ -40,7 +37,7 @@ const user = newUser(); |
40 | 37 |
|
41 | 38 | describe('FolderUseCases', () => { |
42 | 39 | let service: FolderUseCases; |
43 | | - let folderRepository: FolderRepository; |
| 40 | + let folderRepository: SequelizeFolderRepository; |
44 | 41 | let cryptoService: CryptoService; |
45 | 42 | let sharingService: SharingService; |
46 | 43 | let fileUsecases: FileUseCases; |
@@ -86,7 +83,9 @@ describe('FolderUseCases', () => { |
86 | 83 | .compile(); |
87 | 84 |
|
88 | 85 | service = module.get<FolderUseCases>(FolderUseCases); |
89 | | - folderRepository = module.get<FolderRepository>(SequelizeFolderRepository); |
| 86 | + folderRepository = module.get<SequelizeFolderRepository>( |
| 87 | + SequelizeFolderRepository, |
| 88 | + ); |
90 | 89 | cryptoService = module.get<CryptoService>(CryptoService); |
91 | 90 | sharingService = module.get<SharingService>(SharingService); |
92 | 91 | fileUsecases = module.get<FileUseCases>(FileUseCases); |
@@ -2066,4 +2065,44 @@ describe('FolderUseCases', () => { |
2066 | 2065 | expect(result).toEqual(folders); |
2067 | 2066 | }); |
2068 | 2067 | }); |
| 2068 | + describe('createFolderDevice', () => { |
| 2069 | + it('When plain name is not given, then it should throw an error', async () => { |
| 2070 | + const mockFolderData: Partial<FolderAttributes> = { |
| 2071 | + bucket: 'mock bucket', |
| 2072 | + }; |
| 2073 | + await expect( |
| 2074 | + service.createFolderDevice(userMocked, mockFolderData), |
| 2075 | + ).rejects.toThrow(BadRequestException); |
| 2076 | + expect(folderRepository.createFolder).not.toHaveBeenCalled(); |
| 2077 | + }); |
| 2078 | + |
| 2079 | + it('When bucket is not given, then it should throw an error', async () => { |
| 2080 | + const mockFolderData: Partial<FolderAttributes> = { |
| 2081 | + plainName: 'mock plain name', |
| 2082 | + }; |
| 2083 | + |
| 2084 | + await expect( |
| 2085 | + service.createFolderDevice(userMocked, mockFolderData), |
| 2086 | + ).rejects.toThrow(BadRequestException); |
| 2087 | + expect(folderRepository.createFolder).not.toHaveBeenCalled(); |
| 2088 | + }); |
| 2089 | + |
| 2090 | + it('When both plain name and bucket are given, then it should create a folder', async () => { |
| 2091 | + const mockFolder = newFolder(); |
| 2092 | + const mockFolderData: Partial<FolderAttributes> = { |
| 2093 | + plainName: 'mock plain name', |
| 2094 | + bucket: 'mock bucket', |
| 2095 | + }; |
| 2096 | + jest |
| 2097 | + .spyOn(folderRepository, 'createFolder') |
| 2098 | + .mockResolvedValue(mockFolder); |
| 2099 | + const result = await service.createFolderDevice( |
| 2100 | + userMocked, |
| 2101 | + mockFolderData, |
| 2102 | + ); |
| 2103 | + |
| 2104 | + expect(result).toBe(mockFolder); |
| 2105 | + expect(folderRepository.createFolder).toHaveBeenCalledTimes(1); |
| 2106 | + }); |
| 2107 | + }); |
2069 | 2108 | }); |
0 commit comments