refactor racing use cases
This commit is contained in:
@@ -1,20 +1,28 @@
|
||||
import { describe, it, expect, beforeEach, vi, Mock } from 'vitest';
|
||||
import { GetSponsorsUseCase } from './GetSponsorsUseCase';
|
||||
import { ISponsorRepository } from '../../domain/repositories/ISponsorRepository';
|
||||
import { Sponsor } from '../../domain/entities/Sponsor';
|
||||
import { Sponsor } from '../../domain/entities/sponsor/Sponsor';
|
||||
import type { UseCaseOutputPort } from '@core/shared/application/UseCaseOutputPort';
|
||||
|
||||
describe('GetSponsorsUseCase', () => {
|
||||
let useCase: GetSponsorsUseCase;
|
||||
let sponsorRepository: {
|
||||
findAll: Mock;
|
||||
};
|
||||
let output: {
|
||||
present: Mock;
|
||||
};
|
||||
|
||||
beforeEach(() => {
|
||||
sponsorRepository = {
|
||||
findAll: vi.fn(),
|
||||
};
|
||||
output = {
|
||||
present: vi.fn(),
|
||||
};
|
||||
useCase = new GetSponsorsUseCase(
|
||||
sponsorRepository as unknown as ISponsorRepository,
|
||||
output as unknown as UseCaseOutputPort<any>,
|
||||
);
|
||||
});
|
||||
|
||||
@@ -38,26 +46,8 @@ describe('GetSponsorsUseCase', () => {
|
||||
const result = await useCase.execute();
|
||||
|
||||
expect(result.isOk()).toBe(true);
|
||||
expect(result.unwrap()).toEqual({
|
||||
sponsors: [
|
||||
{
|
||||
id: 'sponsor-1',
|
||||
name: 'Sponsor One',
|
||||
contactEmail: 'one@example.com',
|
||||
websiteUrl: undefined,
|
||||
logoUrl: 'logo1.png',
|
||||
createdAt: expect.any(Date),
|
||||
},
|
||||
{
|
||||
id: 'sponsor-2',
|
||||
name: 'Sponsor Two',
|
||||
contactEmail: 'two@example.com',
|
||||
websiteUrl: undefined,
|
||||
logoUrl: undefined,
|
||||
createdAt: expect.any(Date),
|
||||
},
|
||||
],
|
||||
});
|
||||
expect(result.unwrap()).toBeUndefined();
|
||||
expect(output.present).toHaveBeenCalledWith({ sponsors });
|
||||
});
|
||||
|
||||
it('should return error on repository failure', async () => {
|
||||
@@ -70,5 +60,6 @@ describe('GetSponsorsUseCase', () => {
|
||||
code: 'REPOSITORY_ERROR',
|
||||
message: 'Failed to fetch sponsors',
|
||||
});
|
||||
expect(output.present).not.toHaveBeenCalled();
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user