refactor use cases

This commit is contained in:
2026-01-08 15:34:51 +01:00
parent d984ab24a8
commit 52e9a2f6a7
362 changed files with 5192 additions and 8409 deletions

View File

@@ -2,11 +2,9 @@ import { describe, it, expect, vi, type Mock } from 'vitest';
import { CreatePrizeUseCase, type CreatePrizeInput } from './CreatePrizeUseCase';
import type { IPrizeRepository } from '../../domain/repositories/IPrizeRepository';
import { PrizeType, type Prize } from '../../domain/entities/Prize';
import type { UseCaseOutputPort } from '@core/shared/application/UseCaseOutputPort';
describe('CreatePrizeUseCase', () => {
let prizeRepository: { findByPosition: Mock; create: Mock };
let output: { present: Mock };
let useCase: CreatePrizeUseCase;
beforeEach(() => {
@@ -15,13 +13,8 @@ describe('CreatePrizeUseCase', () => {
create: vi.fn(),
};
output = {
present: vi.fn(),
};
useCase = new CreatePrizeUseCase(
prizeRepository as unknown as IPrizeRepository,
output as unknown as UseCaseOutputPort<unknown>,
);
});
@@ -54,10 +47,9 @@ describe('CreatePrizeUseCase', () => {
expect(result.isErr()).toBe(true);
expect(result.unwrapErr().code).toBe('PRIZE_ALREADY_EXISTS');
expect(prizeRepository.create).not.toHaveBeenCalled();
expect(output.present).not.toHaveBeenCalled();
});
it('creates prize and presents created prize', async () => {
it('creates prize and returns created prize', async () => {
prizeRepository.findByPosition.mockResolvedValue(null);
prizeRepository.create.mockImplementation(async (p: Prize) => p);
@@ -90,13 +82,14 @@ describe('CreatePrizeUseCase', () => {
description: 'Top prize',
});
expect(output.present).toHaveBeenCalledWith({
prize: expect.objectContaining({
const value = result.value;
expect(value.prize).toEqual(
expect.objectContaining({
leagueId: 'league-1',
seasonId: 'season-1',
position: 1,
awarded: false,
}),
});
);
});
});