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
87 lines
3.4 KiB
JSON
87 lines
3.4 KiB
JSON
[
|
|
{
|
|
"id": "F001",
|
|
"description": "Add `.gitignore` rules to ignore local env backup files (e.g. `server/.env.local.bak*`).",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 1"]
|
|
},
|
|
{
|
|
"id": "F002",
|
|
"description": "Add a guard (test or CI check) that fails if known env-backup patterns are tracked by git.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 1"]
|
|
},
|
|
{
|
|
"id": "F003",
|
|
"description": "Harden patch path parsing to reject reserved keys (`__proto__`, `prototype`, `constructor`) for all patch operations.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 2"]
|
|
},
|
|
{
|
|
"id": "F004",
|
|
"description": "Ensure `setNodeProp` and `unsetNodeProp` perform no mutation when a patch path is rejected (safe no-op).",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 2"]
|
|
},
|
|
{
|
|
"id": "F005",
|
|
"description": "Add developer-visible feedback when a patch is rejected (console warning and/or surfaced diagnostic).",
|
|
"implemented": true,
|
|
"prdRefs": ["Observability"]
|
|
},
|
|
{
|
|
"id": "F006",
|
|
"description": "Normalize all supported patch paths to canonical `props.*` targets (accept legacy paths but write only canonical state).",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 3"]
|
|
},
|
|
{
|
|
"id": "F007",
|
|
"description": "Make `node.props` the single source of truth for name/layout/style/metadata (stop separately mutating legacy top-level fields during cutover).",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 3"]
|
|
},
|
|
{
|
|
"id": "F008",
|
|
"description": "Make `node.children` the single source of truth for hierarchy (remove reliance on `childIds` and stop writing it during mutations).",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 3"]
|
|
},
|
|
{
|
|
"id": "F009",
|
|
"description": "Update UI call sites to read node properties via canonical `props` helpers (e.g. `getNodeName`, `getNodeMetadata`) instead of legacy fields.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 3"]
|
|
},
|
|
{
|
|
"id": "F010",
|
|
"description": "Define and implement leaf array `unset` semantics as splice-removal (no `undefined` holes).",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Non-functional Requirements > 2"]
|
|
},
|
|
{
|
|
"id": "F011",
|
|
"description": "Ensure undo/redo restores the exact committed canonical JSON state (no `undefined`/`null` conversion surprises).",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 4"]
|
|
},
|
|
{
|
|
"id": "F012",
|
|
"description": "Ensure continuous interactions use `commit=false` for interim updates and do not spam history snapshots.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Non-functional Requirements > 4"]
|
|
},
|
|
{
|
|
"id": "F013",
|
|
"description": "Validate invoice template AST style identifiers (style class keys, token ids, and styleRef tokenIds) against a safe CSS identifier rule.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 5"]
|
|
},
|
|
{
|
|
"id": "F014",
|
|
"description": "Ensure the invoice template AST renderer does not emit malformed CSS selectors/variables for style identifiers (defense-in-depth).",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements > 5"]
|
|
}
|
|
]
|