From 6635353a3f5b718a126396a906dc3032fe93d39e Mon Sep 17 00:00:00 2001 From: zhumeisongsong Date: Wed, 4 Dec 2024 13:24:34 +0900 Subject: [PATCH] =?UTF-8?q?test:=20=F0=9F=A7=AA=20add=20test=20cases?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../get-user-by-email.use-case.spec.ts | 4 +- .../application/src/lib/users.service.spec.ts | 54 +++++++++++-------- 2 files changed, 34 insertions(+), 24 deletions(-) diff --git a/libs/users/application/src/lib/use-cases/get-user-by-email.use-case.spec.ts b/libs/users/application/src/lib/use-cases/get-user-by-email.use-case.spec.ts index ad0da07..85c753e 100644 --- a/libs/users/application/src/lib/use-cases/get-user-by-email.use-case.spec.ts +++ b/libs/users/application/src/lib/use-cases/get-user-by-email.use-case.spec.ts @@ -26,7 +26,7 @@ describe('GetUserByEmailUseCase', () => { const result = await getUserByEmailUseCase.execute('test@example.com'); expect(result).toEqual(mockUser); - expect(usersRepository.findByEmail).toHaveBeenCalledWith('1'); + expect(usersRepository.findByEmail).toHaveBeenCalledWith("test@example.com"); }); it('should return null when user not found', async () => { @@ -35,7 +35,7 @@ describe('GetUserByEmailUseCase', () => { const result = await getUserByEmailUseCase.execute('test@example.com'); expect(result).toBeNull(); - expect(usersRepository.findByEmail).toHaveBeenCalledWith('1'); + expect(usersRepository.findByEmail).toHaveBeenCalledWith("test@example.com"); }); }); }); diff --git a/libs/users/application/src/lib/users.service.spec.ts b/libs/users/application/src/lib/users.service.spec.ts index 93e13a4..adb98d5 100644 --- a/libs/users/application/src/lib/users.service.spec.ts +++ b/libs/users/application/src/lib/users.service.spec.ts @@ -1,12 +1,12 @@ import { Test, TestingModule } from '@nestjs/testing'; -import { User } from '@users/domain'; - import { UsersService } from './users.service'; import { GetUserByIdUseCase } from './use-cases/get-user-by-id.use-case'; +import { GetUserByEmailUseCase } from './use-cases/get-user-by-email.use-case'; describe('UsersService', () => { let service: UsersService; let getUserByIdUseCase: GetUserByIdUseCase; + let getUserByEmailUseCase: GetUserByEmailUseCase; beforeEach(async () => { const module: TestingModule = await Test.createTestingModule({ @@ -18,59 +18,69 @@ describe('UsersService', () => { execute: jest.fn(), }, }, + { + provide: GetUserByEmailUseCase, + useValue: { + execute: jest.fn(), + }, + }, ], }).compile(); service = module.get(UsersService); getUserByIdUseCase = module.get(GetUserByIdUseCase); + getUserByEmailUseCase = module.get(GetUserByEmailUseCase); }); - it('should be defined', () => { - expect(service).toBeDefined(); - }); - - describe('findById', () => { - it('should return a user if found', async () => { - const user: User = { + describe('getUserById', () => { + it('should return user when found', async () => { + const mockUser = { id: '1', email: 'test@example.com', firstName: 'John', lastName: 'Doe', }; - jest.spyOn(getUserByIdUseCase, 'execute').mockResolvedValue(user); + (getUserByIdUseCase.execute as jest.Mock).mockResolvedValue(mockUser); const result = await service.findById('1'); - expect(result).toEqual(user); + + expect(result).toEqual(mockUser); + expect(getUserByIdUseCase.execute).toHaveBeenCalledWith('1'); }); - it('should return null if user not found', async () => { - jest.spyOn(getUserByIdUseCase, 'execute').mockResolvedValue(null); + it('should return null when user not found', async () => { + (getUserByIdUseCase.execute as jest.Mock).mockResolvedValue(null); + + const result = await service.findById('1'); - const result = await service.findById('2'); expect(result).toBeNull(); + expect(getUserByIdUseCase.execute).toHaveBeenCalledWith('1'); }); }); - describe('findByEmail', () => { - it('should return a user if found', async () => { - const user: User = { + describe('getUserByEmail', () => { + it('should return user when found', async () => { + const mockUser = { id: '1', email: 'test@example.com', firstName: 'John', lastName: 'Doe', }; - jest.spyOn(getUserByIdUseCase, 'execute').mockResolvedValue(user); + (getUserByEmailUseCase.execute as jest.Mock).mockResolvedValue(mockUser); const result = await service.findByEmail('test@example.com'); - expect(result).toEqual(user); + + expect(result).toEqual(mockUser); + expect(getUserByEmailUseCase.execute).toHaveBeenCalledWith('test@example.com'); }); - it('should return null if user not found', async () => { - jest.spyOn(getUserByIdUseCase, 'execute').mockResolvedValue(null); + it('should return null when user not found', async () => { + (getUserByEmailUseCase.execute as jest.Mock).mockResolvedValue(null); const result = await service.findByEmail('test@example.com'); + expect(result).toBeNull(); + expect(getUserByEmailUseCase.execute).toHaveBeenCalledWith('test@example.com'); }); }); - });