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

327 lines
7.6 KiB
JSON

[
{
"id": "T001",
"description": "Migration adds tickets.ticket_origin column successfully in existing DB",
"implemented": true,
"featureIds": [
"F003"
]
},
{
"id": "T002",
"description": "Newly inserted tickets default ticket_origin to internal when not explicitly provided",
"implemented": true,
"featureIds": [
"F003"
]
},
{
"id": "T003",
"description": "Backfill marks tickets with email_metadata as inbound_email",
"implemented": true,
"featureIds": [
"F004"
]
},
{
"id": "T004",
"description": "Backfill marks tickets created by client users as client_portal when no email_metadata",
"implemented": true,
"featureIds": [
"F004"
]
},
{
"id": "T005",
"description": "Backfill marks unresolved legacy tickets as internal",
"implemented": true,
"featureIds": [
"F004"
]
},
{
"id": "T006",
"description": "TicketOrigin typecheck accepts internal/client_portal/inbound_email/api and rejects invalid values",
"implemented": true,
"featureIds": [
"F001",
"F002"
]
},
{
"id": "T010",
"description": "MSP server action create path persists ticket_origin=internal",
"implemented": true,
"featureIds": [
"F006",
"F010"
]
},
{
"id": "T011",
"description": "Client portal create path persists ticket_origin=client_portal",
"implemented": true,
"featureIds": [
"F007",
"F010"
]
},
{
"id": "T012",
"description": "Inbound email create path persists ticket_origin=inbound_email",
"implemented": true,
"featureIds": [
"F008",
"F010"
]
},
{
"id": "T013",
"description": "API create path persists ticket_origin=api",
"implemented": true,
"featureIds": [
"F009",
"F010"
]
},
{
"id": "T014",
"description": "Workflow/automation ticket creation without explicit origin persists internal default",
"implemented": true,
"featureIds": [
"F005",
"F010"
]
},
{
"id": "T020",
"description": "Resolver returns stored ticket_origin when present and valid",
"implemented": true,
"featureIds": [
"F011"
]
},
{
"id": "T021",
"description": "Resolver maps null legacy row with email_metadata to inbound_email",
"implemented": true,
"featureIds": [
"F011"
]
},
{
"id": "T022",
"description": "Resolver maps null legacy row with creator user_type client to client_portal",
"implemented": true,
"featureIds": [
"F011"
]
},
{
"id": "T023",
"description": "Resolver maps null legacy row with no signal to internal",
"implemented": true,
"featureIds": [
"F011"
]
},
{
"id": "T024",
"description": "Resolver handles unknown future origin values without crashing and returns safe fallback classification",
"implemented": true,
"featureIds": [
"F005",
"F011"
]
},
{
"id": "T030",
"description": "MSP getTicketById payload includes normalized ticket_origin for internal ticket",
"implemented": true,
"featureIds": [
"F012"
]
},
{
"id": "T031",
"description": "MSP getTicketById payload includes normalized ticket_origin for client_portal ticket",
"implemented": true,
"featureIds": [
"F012"
]
},
{
"id": "T032",
"description": "MSP getTicketById payload includes normalized ticket_origin for inbound_email ticket",
"implemented": true,
"featureIds": [
"F012"
]
},
{
"id": "T033",
"description": "MSP getTicketById payload includes normalized ticket_origin for api ticket",
"implemented": true,
"featureIds": [
"F012"
]
},
{
"id": "T034",
"description": "Client portal getClientTicketDetails payload includes normalized ticket_origin for internal ticket",
"implemented": true,
"featureIds": [
"F013"
]
},
{
"id": "T035",
"description": "Client portal getClientTicketDetails payload includes normalized ticket_origin for client_portal ticket",
"implemented": true,
"featureIds": [
"F013"
]
},
{
"id": "T036",
"description": "Client portal getClientTicketDetails payload includes normalized ticket_origin for inbound_email ticket",
"implemented": true,
"featureIds": [
"F013"
]
},
{
"id": "T037",
"description": "Client portal getClientTicketDetails payload includes normalized ticket_origin for api ticket",
"implemented": true,
"featureIds": [
"F013"
]
},
{
"id": "T040",
"description": "TicketOriginBadge renders Created Internally label and data attribute for internal",
"implemented": true,
"featureIds": [
"F014"
]
},
{
"id": "T041",
"description": "TicketOriginBadge renders Created via Client Portal label and data attribute for client_portal",
"implemented": true,
"featureIds": [
"F014"
]
},
{
"id": "T042",
"description": "TicketOriginBadge renders Created via Inbound Email label and data attribute for inbound_email",
"implemented": true,
"featureIds": [
"F014"
]
},
{
"id": "T043",
"description": "TicketOriginBadge renders Created via API label and data attribute for api",
"implemented": true,
"featureIds": [
"F014"
]
},
{
"id": "T044",
"description": "TicketOriginBadge renders safe fallback label for unknown future origin value",
"implemented": true,
"featureIds": [
"F005",
"F014"
]
},
{
"id": "T050",
"description": "MSP TicketDetails renders API origin badge when ticket_origin=api",
"implemented": true,
"featureIds": [
"F015"
]
},
{
"id": "T051",
"description": "MSP TicketDetails renders all other origin badges correctly (internal/client_portal/inbound_email)",
"implemented": true,
"featureIds": [
"F015"
]
},
{
"id": "T052",
"description": "Client portal TicketDetails renders API origin badge when ticket_origin=api",
"implemented": true,
"featureIds": [
"F016"
]
},
{
"id": "T053",
"description": "Client portal TicketDetails renders all other origin badges correctly (internal/client_portal/inbound_email)",
"implemented": true,
"featureIds": [
"F016"
]
},
{
"id": "T060",
"description": "English common locale includes ticket origin keys for internal/client_portal/inbound_email/api/other",
"implemented": true,
"featureIds": [
"F017"
]
},
{
"id": "T061",
"description": "English clientPortal locale includes ticket origin keys for internal/client_portal/inbound_email/api/other",
"implemented": true,
"featureIds": [
"F017"
]
},
{
"id": "T070",
"description": "Existing comment ResponseSourceBadge tests continue to pass after ticket-origin changes",
"implemented": true,
"featureIds": [
"F018"
]
},
{
"id": "T071",
"description": "Existing response-state badge behavior remains unchanged in MSP and client portal ticket details",
"implemented": true,
"featureIds": [
"F019"
]
},
{
"id": "T080",
"description": "End-to-end: API-created ticket displays Created via API badge in MSP ticket details",
"implemented": true,
"featureIds": [
"F009",
"F015",
"F020"
]
},
{
"id": "T081",
"description": "End-to-end: API-created ticket displays Created via API badge in client portal ticket details when ticket is visible to the client",
"implemented": true,
"featureIds": [
"F009",
"F016",
"F020"
]
}
]