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
340 lines
8.3 KiB
JSON
340 lines
8.3 KiB
JSON
[
|
|
{
|
|
"id": "T001",
|
|
"description": "Migration creates comments.contact_id as nullable UUID",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F002"
|
|
]
|
|
},
|
|
{
|
|
"id": "T002",
|
|
"description": "Migration adds tenant-scoped FK for comments.contact_id to contacts.contact_name_id",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F003"
|
|
]
|
|
},
|
|
{
|
|
"id": "T003",
|
|
"description": "Migration down path removes contact authorship column/constraints cleanly",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F002",
|
|
"F003"
|
|
]
|
|
},
|
|
{
|
|
"id": "T004",
|
|
"description": "TicketModel.createComment accepts author_type=contact with contact_id and no author_id",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F005"
|
|
]
|
|
},
|
|
{
|
|
"id": "T005",
|
|
"description": "TicketModel.createComment rejects invalid contact_id format",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F005"
|
|
]
|
|
},
|
|
{
|
|
"id": "T006",
|
|
"description": "TicketModel.createComment rejects contact_id that does not belong to tenant",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F006"
|
|
]
|
|
},
|
|
{
|
|
"id": "T007",
|
|
"description": "TicketModel.createComment persists contact_id on inserted comment row",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F007"
|
|
]
|
|
},
|
|
{
|
|
"id": "T008",
|
|
"description": "TicketModel.createComment persists both user_id and contact_id when both are provided",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F007",
|
|
"F014"
|
|
]
|
|
},
|
|
{
|
|
"id": "T009",
|
|
"description": "Contact-authored public comment sets ticket response_state to awaiting_internal",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F008"
|
|
]
|
|
},
|
|
{
|
|
"id": "T010",
|
|
"description": "Contact-authored internal comment does not mutate response_state",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F008"
|
|
]
|
|
},
|
|
{
|
|
"id": "T011",
|
|
"description": "createCommentFromEmail forwards contact_id to TicketModel.createComment",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F009",
|
|
"F010"
|
|
]
|
|
},
|
|
{
|
|
"id": "T012",
|
|
"description": "createCommentFromEmail forwards both author_id and contact_id when both are present",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F010",
|
|
"F014"
|
|
]
|
|
},
|
|
{
|
|
"id": "T013",
|
|
"description": "processInboundEmailInApp new-ticket flow with matched contact/no user sets comment contact_id and omits author_id",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F011"
|
|
]
|
|
},
|
|
{
|
|
"id": "T014",
|
|
"description": "processInboundEmailInApp new-ticket flow with matched contact+user sets both contact_id and author_id",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F011",
|
|
"F014"
|
|
]
|
|
},
|
|
{
|
|
"id": "T015",
|
|
"description": "processInboundEmailInApp unmatched new-ticket sender keeps existing fallback path without contact_id",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F011",
|
|
"F021"
|
|
]
|
|
},
|
|
{
|
|
"id": "T016",
|
|
"description": "processInboundEmailInApp reply-token path resolves sender contact and sets contact_id for contact-only sender",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F012"
|
|
]
|
|
},
|
|
{
|
|
"id": "T017",
|
|
"description": "processInboundEmailInApp reply-token path sets both author_id and contact_id when matched contact has user",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F012",
|
|
"F014"
|
|
]
|
|
},
|
|
{
|
|
"id": "T018",
|
|
"description": "processInboundEmailInApp thread-header path resolves sender contact and sets contact_id for contact-only sender",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F013"
|
|
]
|
|
},
|
|
{
|
|
"id": "T019",
|
|
"description": "processInboundEmailInApp thread-header path without sender contact keeps fallback behavior",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F013",
|
|
"F021"
|
|
]
|
|
},
|
|
{
|
|
"id": "T020",
|
|
"description": "Workflow runtime email action schema accepts contact_id in create-comment input",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F015"
|
|
]
|
|
},
|
|
{
|
|
"id": "T021",
|
|
"description": "Workflow runtime create_initial_comment_from_email forwards contact_id to underlying comment action",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F016"
|
|
]
|
|
},
|
|
{
|
|
"id": "T022",
|
|
"description": "Workflow runtime create_comment_from_email forwards contact_id to shared email action",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F016"
|
|
]
|
|
},
|
|
{
|
|
"id": "T023",
|
|
"description": "MSP ticket consolidated data returns comments containing contact_id for contact-authored comments",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F017"
|
|
]
|
|
},
|
|
{
|
|
"id": "T024",
|
|
"description": "MSP ticket consolidated data includes author resolution data for contact-only commentors",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F017",
|
|
"F019"
|
|
]
|
|
},
|
|
{
|
|
"id": "T025",
|
|
"description": "Client portal ticket details data path includes contact author resolution for contact-authored comments",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F018",
|
|
"F019"
|
|
]
|
|
},
|
|
{
|
|
"id": "T026",
|
|
"description": "Shared author resolution helper prefers user author, then contact author, then unknown fallback",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F019",
|
|
"F021"
|
|
]
|
|
},
|
|
{
|
|
"id": "T027",
|
|
"description": "CommentItem renders contact name (not Unknown User) for contact-authored comment with no user_id",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F020",
|
|
"F021"
|
|
]
|
|
},
|
|
{
|
|
"id": "T028",
|
|
"description": "CommentItem renders contact email for contact-authored comment when available",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F020"
|
|
]
|
|
},
|
|
{
|
|
"id": "T029",
|
|
"description": "CommentItem uses ContactAvatar for contact-authored comment with no user_id",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F020"
|
|
]
|
|
},
|
|
{
|
|
"id": "T030",
|
|
"description": "CommentItem preserves Unknown User fallback when neither user nor contact can be resolved",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F021"
|
|
]
|
|
},
|
|
{
|
|
"id": "T031",
|
|
"description": "CommentItem edit/delete permissions remain unchanged for contact-authored comments",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F020"
|
|
]
|
|
},
|
|
{
|
|
"id": "T032",
|
|
"description": "TicketService.getTicketComments returns contact author fields and nullable created_by for contact-only comments",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F022"
|
|
]
|
|
},
|
|
{
|
|
"id": "T033",
|
|
"description": "Ticket comment API schema validates contact-authored payload shape without requiring created_by UUID",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F022"
|
|
]
|
|
},
|
|
{
|
|
"id": "T034",
|
|
"description": "GET /api/v1/tickets/{id}/comments returns contact-authored comments without response-validation errors",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F022"
|
|
]
|
|
},
|
|
{
|
|
"id": "T035",
|
|
"description": "Ticket email subscriber excludes contact author from recipient fan-out when comment author is contact-only",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F023"
|
|
]
|
|
},
|
|
{
|
|
"id": "T036",
|
|
"description": "Inbound email integration (Google): matched contact without user stores comment with contact_id and client author type",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F024",
|
|
"F025"
|
|
]
|
|
},
|
|
{
|
|
"id": "T037",
|
|
"description": "Inbound email integration (Microsoft): matched contact without user stores comment with contact_id and client author type",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F024",
|
|
"F025"
|
|
]
|
|
},
|
|
{
|
|
"id": "T038",
|
|
"description": "Inbound email reply integration: reply to existing ticket from matched contact without user stores contact-authored comment",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F024",
|
|
"F025"
|
|
]
|
|
},
|
|
{
|
|
"id": "T039",
|
|
"description": "Regression: matched client-user inbound path remains associated with user and continues to pass existing tests",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F014",
|
|
"F025"
|
|
]
|
|
},
|
|
{
|
|
"id": "T040",
|
|
"description": "Regression: unmatched sender path remains functional and still uses unknown fallback when no contact exists",
|
|
"implemented": true,
|
|
"featureIds": [
|
|
"F021",
|
|
"F025"
|
|
]
|
|
}
|
|
]
|