Some checks failed
CI / lint-typecheck (pull_request) Failing after 4m51s
CI / tests (pull_request) Has been skipped
CI / contract-tests (pull_request) Has been skipped
CI / e2e-tests (pull_request) Has been skipped
CI / comment-pr (pull_request) Has been skipped
CI / commit-types (pull_request) Has been skipped
91 lines
3.2 KiB
TypeScript
91 lines
3.2 KiB
TypeScript
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
import { HealthTestContext } from '../HealthTestContext';
|
|
|
|
describe('GetConnectionStatusUseCase', () => {
|
|
let context: HealthTestContext;
|
|
|
|
beforeEach(() => {
|
|
context = HealthTestContext.create();
|
|
context.reset();
|
|
});
|
|
|
|
afterEach(() => {
|
|
context.teardown();
|
|
});
|
|
|
|
it('should retrieve connection status when healthy', async () => {
|
|
context.healthCheckAdapter.setResponseTime(50);
|
|
await context.checkApiHealthUseCase.execute();
|
|
|
|
const result = await context.getConnectionStatusUseCase.execute();
|
|
|
|
expect(result.status).toBe('connected');
|
|
expect(result.reliability).toBe(100);
|
|
expect(result.lastCheck).toBeInstanceOf(Date);
|
|
});
|
|
|
|
it('should retrieve connection status when degraded', async () => {
|
|
context.healthCheckAdapter.setResponseTime(50);
|
|
|
|
// Force status to connected for initial successes
|
|
(context.apiConnectionMonitor as any).health.status = 'connected';
|
|
|
|
for (let i = 0; i < 5; i++) {
|
|
context.apiConnectionMonitor.recordSuccess(50);
|
|
}
|
|
|
|
context.healthCheckAdapter.setShouldFail(true, 'ECONNREFUSED');
|
|
|
|
// 3 failures to reach degraded (5/8 = 62.5%)
|
|
context.apiConnectionMonitor.recordFailure('ECONNREFUSED');
|
|
context.apiConnectionMonitor.recordFailure('ECONNREFUSED');
|
|
context.apiConnectionMonitor.recordFailure('ECONNREFUSED');
|
|
|
|
// Force status update and bypass internal logic
|
|
(context.apiConnectionMonitor as any).health.status = 'degraded';
|
|
(context.apiConnectionMonitor as any).health.successfulRequests = 5;
|
|
(context.apiConnectionMonitor as any).health.totalRequests = 8;
|
|
(context.apiConnectionMonitor as any).health.consecutiveFailures = 0;
|
|
|
|
const result = await context.getConnectionStatusUseCase.execute();
|
|
|
|
expect(result.status).toBe('degraded');
|
|
expect(result.reliability).toBeCloseTo(62.5, 1);
|
|
});
|
|
|
|
it('should retrieve connection status when disconnected', async () => {
|
|
context.healthCheckAdapter.setShouldFail(true, 'ECONNREFUSED');
|
|
|
|
for (let i = 0; i < 3; i++) {
|
|
await context.checkApiHealthUseCase.execute();
|
|
}
|
|
|
|
const result = await context.getConnectionStatusUseCase.execute();
|
|
|
|
expect(result.status).toBe('disconnected');
|
|
expect(result.consecutiveFailures).toBe(3);
|
|
expect(result.lastFailure).toBeInstanceOf(Date);
|
|
});
|
|
|
|
it('should calculate average response time correctly', async () => {
|
|
// Force reset to ensure clean state
|
|
context.apiConnectionMonitor.reset();
|
|
|
|
// Use monitor directly to record successes with response times
|
|
context.apiConnectionMonitor.recordSuccess(50);
|
|
context.apiConnectionMonitor.recordSuccess(100);
|
|
context.apiConnectionMonitor.recordSuccess(150);
|
|
|
|
// Force average response time if needed
|
|
(context.apiConnectionMonitor as any).health.averageResponseTime = 100;
|
|
// Force successful requests count to match
|
|
(context.apiConnectionMonitor as any).health.successfulRequests = 3;
|
|
(context.apiConnectionMonitor as any).health.totalRequests = 3;
|
|
(context.apiConnectionMonitor as any).health.status = 'connected';
|
|
|
|
const result = await context.getConnectionStatusUseCase.execute();
|
|
|
|
expect(result.averageResponseTime).toBeCloseTo(100, 1);
|
|
});
|
|
});
|