PSA/shared/workflow/streams/domainEventBuilders/__tests__/integrationSyncEventBuilders.test.ts
Hermes 284313f908
Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Initial import of AlgaPSA codebase from PSA server
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz

Source: /opt/alga-psa on psa.joliet.tech
2026-06-22 16:12:17 -05:00

78 lines
2.4 KiB
TypeScript

import { describe, expect, it } from 'vitest';
import { buildWorkflowPayload } from '../../workflowEventPublishHelpers';
import {
integrationSyncCompletedEventPayloadSchema,
integrationSyncFailedEventPayloadSchema,
integrationSyncStartedEventPayloadSchema,
} from '../../../runtime/schemas/integrationEventSchemas';
import {
buildIntegrationSyncCompletedPayload,
buildIntegrationSyncFailedPayload,
buildIntegrationSyncStartedPayload,
} from '../integrationSyncEventBuilders';
describe('integrationSyncEventBuilders', () => {
const tenantId = '7e8a6f60-7a47-4f20-b2ac-5b77a3b5c9fd';
const integrationId = 'b0a523cf-6bba-4a37-b71d-2d6d3d82edc2';
const syncId = 'sync_01';
const ctx = {
tenantId,
occurredAt: '2026-01-24T00:00:00.000Z',
actor: { actorType: 'SYSTEM' as const },
};
it('builds INTEGRATION_SYNC_STARTED payloads compatible with schema', () => {
const payload = buildWorkflowPayload(
buildIntegrationSyncStartedPayload({
integrationId,
provider: 'ninjaone',
syncId,
scope: 'rmm:full',
startedAt: '2026-01-24T00:00:00.000Z',
}),
ctx
);
expect(integrationSyncStartedEventPayloadSchema.safeParse(payload).success).toBe(true);
});
it('builds INTEGRATION_SYNC_COMPLETED payloads compatible with schema', () => {
const payload = buildWorkflowPayload(
buildIntegrationSyncCompletedPayload({
integrationId,
provider: 'ninjaone',
syncId,
startedAt: '2026-01-24T00:00:00.000Z',
completedAt: '2026-01-24T00:01:30.000Z',
durationMs: 90_000,
summary: { created: 1, updated: 2, deleted: 3, skipped: 4 },
warnings: ['one non-fatal warning'],
}),
ctx
);
expect(integrationSyncCompletedEventPayloadSchema.safeParse(payload).success).toBe(true);
});
it('builds INTEGRATION_SYNC_FAILED payloads compatible with schema', () => {
const payload = buildWorkflowPayload(
buildIntegrationSyncFailedPayload({
integrationId,
provider: 'ninjaone',
syncId,
startedAt: '2026-01-24T00:00:00.000Z',
failedAt: '2026-01-24T00:00:10.000Z',
durationMs: 10_000,
errorCode: 'NINJAONE_API_ERROR',
errorMessage: 'Something went wrong',
retryable: true,
}),
ctx
);
expect(integrationSyncFailedEventPayloadSchema.safeParse(payload).success).toBe(true);
});
});