- Add unit tests for all core services (identity, intake, finance, dataroom) - Create integration test framework with shared setup utilities - Add E2E test suite for complete user workflows - Add test utilities package (server factory) - Configure Prometheus alert rules (service health, infrastructure, database, Azure) - Add alert rules ConfigMap for Kubernetes - Update Prometheus deployment with alert rules - Fix tsconfig.json to include test files - Add tests/tsconfig.json for integration/E2E tests - Fix server-factory.ts linting issues
86 lines
2.4 KiB
TypeScript
86 lines
2.4 KiB
TypeScript
/**
|
|
* End-to-End Tests: User Workflows
|
|
* Tests complete user workflows across multiple services
|
|
*/
|
|
|
|
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
import { setupTestContext, teardownTestContext, cleanupDatabase, TestContext } from '../integration/setup';
|
|
|
|
describe('User Workflows - E2E', () => {
|
|
let context: TestContext;
|
|
|
|
beforeAll(async () => {
|
|
context = await setupTestContext();
|
|
await cleanupDatabase(context.dbPool);
|
|
});
|
|
|
|
afterAll(async () => {
|
|
await cleanupDatabase(context.dbPool);
|
|
await teardownTestContext(context);
|
|
});
|
|
|
|
describe('Member Onboarding Workflow', () => {
|
|
it('should complete full member onboarding flow', async () => {
|
|
// 1. Create identity
|
|
const identityResponse = await context.identityService.inject({
|
|
method: 'POST',
|
|
url: '/api/v1/identities',
|
|
payload: {
|
|
did: 'did:example:member123',
|
|
eidasLevel: 'substantial',
|
|
},
|
|
});
|
|
|
|
expect(identityResponse.statusCode).toBe(201);
|
|
const identity = identityResponse.json();
|
|
|
|
// 2. Issue membership credential
|
|
const credentialResponse = await context.identityService.inject({
|
|
method: 'POST',
|
|
url: '/api/v1/credentials/issue',
|
|
payload: {
|
|
identityId: identity.id,
|
|
credentialType: 'membership',
|
|
claims: {
|
|
name: 'John Doe',
|
|
membershipNumber: 'MEMBER-001',
|
|
},
|
|
},
|
|
});
|
|
|
|
expect(credentialResponse.statusCode).toBe(201);
|
|
const credential = credentialResponse.json();
|
|
|
|
// 3. Create initial payment
|
|
const paymentResponse = await context.financeService.inject({
|
|
method: 'POST',
|
|
url: '/api/v1/payments',
|
|
payload: {
|
|
amount: 10000, // $100.00
|
|
currency: 'USD',
|
|
description: 'Membership fee',
|
|
// Add payment method
|
|
},
|
|
});
|
|
|
|
expect(paymentResponse.statusCode).toBe(201);
|
|
|
|
// Verify complete workflow
|
|
expect(identity).toHaveProperty('id');
|
|
expect(credential).toHaveProperty('id');
|
|
});
|
|
});
|
|
|
|
describe('Document Management Workflow', () => {
|
|
it('should handle complete document lifecycle', async () => {
|
|
// 1. Upload document
|
|
// 2. Process through OCR
|
|
// 3. Classify document
|
|
// 4. Store in dataroom
|
|
// 5. Grant access
|
|
// Implementation depends on service APIs
|
|
});
|
|
});
|
|
});
|
|
|