Files
gridpilot.gg/core/racing/application/use-cases/IsDriverRegisteredForRaceUseCase.test.ts
2025-12-21 00:43:42 +01:00

100 lines
3.4 KiB
TypeScript

import { describe, it, expect, beforeEach, vi, Mock } from 'vitest';
import {
IsDriverRegisteredForRaceUseCase,
type IsDriverRegisteredForRaceInput,
type IsDriverRegisteredForRaceResult,
type IsDriverRegisteredForRaceErrorCode,
} from './IsDriverRegisteredForRaceUseCase';
import { IRaceRegistrationRepository } from '../../domain/repositories/IRaceRegistrationRepository';
import type { Logger, UseCaseOutputPort } from '@core/shared/application';
import type { ApplicationErrorCode } from '@core/shared/errors/ApplicationErrorCode';
describe('IsDriverRegisteredForRaceUseCase', () => {
let useCase: IsDriverRegisteredForRaceUseCase;
let registrationRepository: {
isRegistered: Mock;
};
let logger: {
debug: Mock;
info: Mock;
warn: Mock;
error: Mock;
};
let output: UseCaseOutputPort<IsDriverRegisteredForRaceResult> & {
present: Mock;
};
beforeEach(() => {
registrationRepository = {
isRegistered: vi.fn(),
};
logger = {
debug: vi.fn(),
info: vi.fn(),
warn: vi.fn(),
error: vi.fn(),
};
output = {
present: vi.fn(),
} as unknown as UseCaseOutputPort<IsDriverRegisteredForRaceResult> & { present: Mock };
useCase = new IsDriverRegisteredForRaceUseCase(
registrationRepository as unknown as IRaceRegistrationRepository,
logger as unknown as Logger,
output as UseCaseOutputPort<IsDriverRegisteredForRaceResult>,
);
});
it('should return true when driver is registered', async () => {
const params: IsDriverRegisteredForRaceInput = { raceId: 'race-1', driverId: 'driver-1' };
registrationRepository.isRegistered.mockResolvedValue(true);
const result = await useCase.execute(params);
expect(result.isOk()).toBe(true);
expect(result.unwrap()).toBeUndefined();
expect(output.present).toHaveBeenCalledTimes(1);
const [[presented]] = (output.present as Mock).mock.calls as [[IsDriverRegisteredForRaceResult]];
expect(presented).toEqual({
raceId: params.raceId,
driverId: params.driverId,
isRegistered: true,
});
});
it('should return false when driver is not registered', async () => {
const params: IsDriverRegisteredForRaceInput = { raceId: 'race-1', driverId: 'driver-1' };
registrationRepository.isRegistered.mockResolvedValue(false);
const result = await useCase.execute(params);
expect(result.isOk()).toBe(true);
expect(result.unwrap()).toBeUndefined();
expect(output.present).toHaveBeenCalledTimes(1);
const [[presented]] = (output.present as Mock).mock.calls as [[IsDriverRegisteredForRaceResult]];
expect(presented).toEqual({
raceId: params.raceId,
driverId: params.driverId,
isRegistered: false,
});
});
it('should return error on repository failure', async () => {
const params: IsDriverRegisteredForRaceInput = { raceId: 'race-1', driverId: 'driver-1' };
const error = new Error('Repository error');
registrationRepository.isRegistered.mockRejectedValue(error);
const result = await useCase.execute(params);
expect(result.isErr()).toBe(true);
const errorResult = result.unwrapErr() as ApplicationErrorCode<
IsDriverRegisteredForRaceErrorCode,
{ message: string }
>;
expect(errorResult.code).toBe('REPOSITORY_ERROR');
expect(errorResult.details?.message).toBe('Repository error');
expect(output.present).not.toHaveBeenCalled();
});
});