Files
gridpilot.gg/core/identity/application/use-cases/LogoutUseCase.test.ts
2026-01-08 15:34:51 +01:00

52 lines
1.5 KiB
TypeScript

import { describe, it, expect, vi, type Mock } from 'vitest';
import { LogoutUseCase } from './LogoutUseCase';
import type { IdentitySessionPort } from '../ports/IdentitySessionPort';
import type { Logger } from '@core/shared/application';
import { Result } from '@core/shared/application/Result';
describe('LogoutUseCase', () => {
let sessionPort: {
clearSession: Mock;
};
let logger: Logger & { error: Mock };
let useCase: LogoutUseCase;
beforeEach(() => {
sessionPort = {
clearSession: vi.fn(),
};
logger = {
debug: vi.fn(),
info: vi.fn(),
warn: vi.fn(),
error: vi.fn(),
} as unknown as Logger & { error: Mock };
useCase = new LogoutUseCase(
sessionPort as unknown as IdentitySessionPort,
logger,
);
});
it('successfully clears session and returns success', async () => {
sessionPort.clearSession.mockResolvedValue(undefined);
const result = await useCase.execute();
expect(result.isOk()).toBe(true);
const logoutResult = result.unwrap();
expect(logoutResult.success).toBe(true);
expect(sessionPort.clearSession).toHaveBeenCalledTimes(1);
});
it('returns error when session clear fails', async () => {
sessionPort.clearSession.mockRejectedValue(new Error('Session clear failed'));
const result = await useCase.execute();
expect(result.isErr()).toBe(true);
expect(result.unwrapErr().code).toBe('REPOSITORY_ERROR');
expect(logger.error).toHaveBeenCalled();
});
});