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
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz Source: /opt/alga-psa on psa.joliet.tech
7.3 KiB
7.3 KiB
Scratchpad
Status
- Complete: All notification-only fixtures have business counterparts (144/144)
Summary by Domain (needed-biz-tests.json)
| Domain | To Create |
|---|---|
| ticket | 71 |
| project | 28 |
| invoice | 10 |
| appointment | 9 |
| payment | 4 |
| contract | 4 |
| schedule | 4 |
| technician | 4 |
| other | 10 |
| Total | 144 |
Progress Tracker
Phase 1: High-Value Domains
Ticket Domain (71 fixtures)
- Batch 1: ticket-approval-* through ticket-created-assign-contact-owner
- Batch 2: ticket-created-assign-idempotent-real through ticket-created-chain-assign-comment-email
- Batch 3: ticket-created-client-missing-create-note through ticket-created-email-with-retry
- Batch 4: ticket-created-error-creates-comment through ticket-created-log-initial-time
- Batch 5: ticket-created-missing-fields-comment through ticket-created-set-custom-fields
- Batch 6: ticket-created-set-sla-fields through ticket-merged-add-comment
- Batch 7: ticket-message-added-send-response through ticket-updated-status-add-comment
- Completed commits:
- Batch 1 (commit f230b76e4): 10 fixtures (ticket-approval-* through ticket-created-assign-contact-owner)
- Batch 2 (commit 761473599): 10 fixtures (ticket-created-assign-idempotent-real through ticket-created-chain-assign-comment-email)
- Batch 3 (commit 2862304a7): 10 fixtures (ticket-created-client-missing-create-note through ticket-created-email-with-retry)
- Batch 4 (commit 36f8787d7): 10 fixtures (ticket-created-error-creates-comment through ticket-created-log-initial-time)
- Batch 5 (commit 5052a466e): 10 fixtures (ticket-created-missing-fields-comment through ticket-created-set-custom-fields)
- Batch 6 (commit eb184c5b8): 10 fixtures (ticket-created-set-sla-fields through ticket-merged-add-comment)
- Batch 7 (commit 7cce41cb4): 11 fixtures (ticket-message-added-send-response through ticket-updated-status-add-comment)
Project Domain (28 fixtures)
- Batch 1: project-approval-* through project-created-create-ticket
- Batch 2: project-created-* through project-task-completed-callworkflow-next
- Batch 3: project-task-* through project-updated-send-email
- Completed commits:
- Batch 1 (commit 9f1f7a68f): 10 fixtures
- Batch 2 (commit afc446abd): 10 fixtures
- Batch 3 (commit a801edcf5): 8 fixtures
Invoice Domain (10 fixtures)
- Batch 1: All invoice-* (commit fbf3534e8)
Appointment Domain (9 fixtures)
- Batch 1: All appointment-* (commit bce5c865f)
Phase 2: Remaining Domains
- payment-* (4) (commit c6c209ebb)
- contract-* (4) (commit 5e9291fdf)
- schedule-* (4) (commit a5e2b109d)
- technician-* (4) (commit cbfd38642)
- other (10) (commit 622fa750a)
Notes / Decisions
- Strict definition: "business-relevant" means calling domain-modifying actions, not just notifications
notifications.send_in_appis NOT business-relevant - it only creates internal notifications- Current coverage: only 14% of fixtures exercise real business actions
- Counterparts should preserve the control flow pattern of the original (foreach, tryCatch, etc.)
- Counterparts should assert actual DB state changes, not just workflow run success
- Implementation approach (batch generator):
- Ticket domain counterparts: replace
notifications.send_in_app→tickets.add_commentand assert DBcomments. - All other domains (project/invoice/appointment/etc): replace
notifications.send_in_app→projects.create_taskand assert DBproject_tasks. - Shared runner:
ee/test-data/workflow-harness/_lib/biz-fixture.cjs- Uses
workflow_runs.input_json->>'fixtureNotifyUserId'(and optionallyfixtureDedupeKey) to wait for the correct run when domain APIs emit their own events (e.g., creating a ticket can also emitTICKET_CREATED). - Reuses an existing ticket/project and cleans up only marker-matched rows (comments/tasks) to avoid FK cleanup races when domain APIs emit real events that trigger workflows.
- Uses
- Generator:
tools/workflow-harness/generate-biz-counterparts.cjs
- Ticket domain counterparts: replace
- Local harness env (this worktree):
- Server: http://localhost:3010 (docker
prep_1_0_server_ee) - Postgres: localhost:55432 (db
server, userpostgres, password insecrets/postgres_password) - Tenant:
d01f7285-da5c-49c4-8eb9-8bf51ee97e2b(from DBtenants.tenant) - API keys in DB (
api_keys) include:workflow harness (auto-generated)(active)workflow harness (generated by iteration loop)(active)
- Known workflow action IDs already used in fixtures:
tickets.add_comment,tickets.assign,tickets.update_fields,projects.create_task,crm.create_activity_note,scheduling.assign_user,email.send,tickets.find,notifications.send_in_app
- Server: http://localhost:3010 (docker
Existing Business-Relevant Fixtures (Reference)
These 24 fixtures already call domain-modifying actions:
Ticket (16):
- ticket-assigned-acknowledge (tickets.add_comment, email.send)
- ticket-created-assign-invalid-fails (tickets.assign)
- ticket-created-assign-trycatch (tickets.add_comment, tickets.assign)
- ticket-created-auto-assign-by-priority (tickets.add_comment, tickets.assign)
- ticket-created-create-project-task (projects.create_task)
- ticket-created-outage-escalate (tickets.update_fields)
- ticket-created-triage-comment (tickets.add_comment)
- ticket-escalated-crm-note (crm.create_activity_note)
- ticket-priority-changed-audit-comment (tickets.add_comment)
- ticket-queue-after-hours-email (email.send)
- ticket-reopened-notify-tech (tickets.add_comment)
- ticket-status-waiting-on-customer-reminder (email.send)
- ticket-tags-billing-route (tickets.update_fields)
- ticket-unassigned-return-to-triage (tickets.update_fields)
Project (1):
- project-created-kickoff-tasks (projects.create_task)
Invoice (1):
- invoice-generated-review-task (projects.create_task)
Appointment (1):
- appointment-created-assign-notify (scheduling.assign_user)
Contract (1):
- contract-created-onboarding-task (projects.create_task, crm.create_activity_note)
Schedule (1):
- schedule-block-created (projects.create_task)
Email (1):
- email-inbound-received-ticket-comment (tickets.add_comment)
Commands / Runbook
# List all notification-only fixtures for a domain
grep -l '"notifications.send_in_app"' ee/test-data/workflow-harness/ticket-*/bundle.json | wc -l
# Scaffold a new fixture
node tools/workflow-harness/scaffold.cjs --name <name> --event <EVENT> --schema <schema>
# Run a fixture
node tools/workflow-harness/run.cjs \
--test ee/test-data/workflow-harness/<fixture> \
--base-url http://localhost:3010 \
--tenant <uuid> \
--cookie-file <path> \
--pg-url <postgres-url> \
--force --debug
# List available actions
grep -rh '"actionId"' ee/test-data/workflow-harness/*/bundle.json | \
sed 's/.*"actionId": "\([^"]*\)".*/\1/' | sort -u
Gotchas
- Some actions require specific permissions (check 47_permissions.cjs seed)
tickets.add_commentrequirescomment:managepermissionemail.sendrequiresemail:processpermission and tenant_email_settings- Cleanup should use HTTP delete with DB fallback for FK constraint issues
- Some fixtures reference
tickets.find(...).attributes.*; ensure JSONata assigns default JSON-serializable values if fixture attributes aren't present. - JSONata escaping: use
\"not\\\"inside expressions