Files
gridpilot.gg/tests/integration/health/use-cases/get-connection-status.integration.test.ts
Marc Mintel a0f41f242f
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
integration tests
2026-01-23 00:46:34 +01:00

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);
});
});