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

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_app is 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_apptickets.add_comment and assert DB comments.
    • All other domains (project/invoice/appointment/etc): replace notifications.send_in_appprojects.create_task and assert DB project_tasks.
    • Shared runner: ee/test-data/workflow-harness/_lib/biz-fixture.cjs
      • Uses workflow_runs.input_json->>'fixtureNotifyUserId' (and optionally fixtureDedupeKey) to wait for the correct run when domain APIs emit their own events (e.g., creating a ticket can also emit TICKET_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.
    • Generator: tools/workflow-harness/generate-biz-counterparts.cjs
  • Local harness env (this worktree):
    • Server: http://localhost:3010 (docker prep_1_0_server_ee)
    • Postgres: localhost:55432 (db server, user postgres, password in secrets/postgres_password)
    • Tenant: d01f7285-da5c-49c4-8eb9-8bf51ee97e2b (from DB tenants.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

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_comment requires comment:manage permission
  • email.send requires email:process permission 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