@beyondwork/docx-react-component 1.0.0 → 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +44 -104
- package/package.json +66 -15
- package/src/api/public-types.ts +1 -1
- package/src/compare/diff-engine.ts +530 -0
- package/src/compare/export-redlines.ts +162 -0
- package/src/compare/snapshot.ts +37 -0
- package/src/core/commands/index.ts +1 -1
- package/src/core/state/editor-state.ts +2 -2
- package/src/index.ts +45 -0
- package/src/legal/bookmarks.ts +196 -0
- package/src/legal/cross-references.ts +356 -0
- package/src/legal/defined-terms.ts +203 -0
- package/src/runtime/document-runtime.ts +3 -5
- package/src/runtime/table-commands.ts +4 -1
- package/src/runtime/table-schema.ts +17 -2
- package/src/runtime/virtualized-rendering.ts +258 -0
- package/src/ui/WordReviewEditor.tsx +256 -35
- package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +2 -2
- package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +16 -2
- package/.codex/config.toml +0 -5
- package/.corepack/v1/pnpm/10.30.3/.corepack +0 -1
- package/.corepack/v1/pnpm/10.30.3/LICENSE +0 -22
- package/.corepack/v1/pnpm/10.30.3/README.md +0 -240
- package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp +0 -6
- package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp.cmd +0 -5
- package/.corepack/v1/pnpm/10.30.3/dist/pnpm.cjs +0 -195400
- package/.corepack/v1/pnpm/10.30.3/dist/pnpmrc +0 -2
- package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-arm64-2HJ4WGO6.node +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-x64-3G3H6IW4.node +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-arm64-msvc-Q6BARPPB.node +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-x64-msvc-J2TZHRQI.node +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.bash +0 -31
- package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.fish +0 -22
- package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.ps1 +0 -193
- package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.zsh +0 -27
- package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x64.exe +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x86.exe +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/worker.js +0 -10119
- package/.corepack/v1/pnpm/10.30.3/package.json +0 -192
- package/.cursor/mcp.json +0 -7
- package/.github/workflows/ci.yml +0 -35
- package/.mcp.json +0 -7
- package/.openclaw/workspace-state.json +0 -4
- package/.pnpmrc.json +0 -1
- package/.wave-launch.sh +0 -7
- package/.workspace-marker +0 -1
- package/AGENTS.md +0 -78
- package/CHANGELOG.md +0 -177
- package/DESIGN.md +0 -929
- package/HEARTBEAT.md +0 -7
- package/IDENTITY.md +0 -23
- package/SOUL.md +0 -36
- package/TOOLS.md +0 -40
- package/USER.md +0 -17
- package/docs/README.md +0 -107
- package/docs/agents/wave-cont-eval-role.md +0 -36
- package/docs/agents/wave-cont-qa-role.md +0 -52
- package/docs/agents/wave-deploy-verifier-role.md +0 -34
- package/docs/agents/wave-design-role.md +0 -47
- package/docs/agents/wave-documentation-role.md +0 -34
- package/docs/agents/wave-infra-role.md +0 -34
- package/docs/agents/wave-integration-role.md +0 -37
- package/docs/agents/wave-launcher-role.md +0 -41
- package/docs/agents/wave-orchestrator-role.md +0 -52
- package/docs/agents/wave-planner-role.md +0 -39
- package/docs/agents/wave-security-role.md +0 -40
- package/docs/architecture/docx/README.md +0 -10
- package/docs/architecture/future/README.md +0 -8
- package/docs/architecture/ooxml-upgrade-analysis.md +0 -134
- package/docs/architecture/platform/shared-openxml-editor-platform.md +0 -153
- package/docs/architecture/xlsx/canonical-workbook-model-and-commands.md +0 -187
- package/docs/architecture/xlsx/spreadsheet-editor-frontend-architecture.md +0 -150
- package/docs/comment-redline-overview.md +0 -350
- package/docs/concepts/context7-vs-skills.md +0 -118
- package/docs/concepts/operating-modes.md +0 -91
- package/docs/concepts/runtime-agnostic-orchestration.md +0 -111
- package/docs/concepts/what-is-a-wave.md +0 -217
- package/docs/context7/bundles.json +0 -222
- package/docs/context7/planner-agent/README.md +0 -28
- package/docs/context7/planner-agent/manifest.json +0 -83
- package/docs/context7/planner-agent/papers/cooperbench-why-coding-agents-cannot-be-your-teammates-yet.md +0 -3283
- package/docs/context7/planner-agent/papers/dova-deliberation-first-multi-agent-orchestration-for-autonomous-research-automation.md +0 -1699
- package/docs/context7/planner-agent/papers/dpbench-large-language-models-struggle-with-simultaneous-coordination.md +0 -2251
- package/docs/context7/planner-agent/papers/incremental-planning-to-control-a-blackboard-based-problem-solver.md +0 -1729
- package/docs/context7/planner-agent/papers/silo-bench-a-scalable-environment-for-evaluating-distributed-coordination-in-multi-agent-llm-systems.md +0 -3747
- package/docs/context7/planner-agent/papers/todoevolve-learning-to-architect-agent-planning-systems.md +0 -1675
- package/docs/context7/planner-agent/papers/verified-multi-agent-orchestration-a-plan-execute-verify-replan-framework-for-complex-query-resolution.md +0 -1173
- package/docs/context7/planner-agent/papers/why-do-multi-agent-llm-systems-fail.md +0 -5211
- package/docs/context7/planner-agent/topics/planning-and-orchestration.md +0 -24
- package/docs/evals/arm-templates/README.md +0 -13
- package/docs/evals/arm-templates/full-wave.json +0 -15
- package/docs/evals/arm-templates/single-agent.json +0 -15
- package/docs/evals/benchmark-catalog.json +0 -670
- package/docs/evals/cases/README.md +0 -47
- package/docs/evals/cases/wave-blackboard-inbox-targeting.json +0 -73
- package/docs/evals/cases/wave-contradiction-conflict.json +0 -104
- package/docs/evals/cases/wave-expert-routing-preservation.json +0 -69
- package/docs/evals/cases/wave-hidden-profile-private-evidence.json +0 -81
- package/docs/evals/cases/wave-premature-closure-guard.json +0 -71
- package/docs/evals/cases/wave-silo-cross-agent-state.json +0 -77
- package/docs/evals/cases/wave-simultaneous-lockstep.json +0 -92
- package/docs/evals/external-benchmarks.json +0 -85
- package/docs/evals/external-command-config.sample.json +0 -9
- package/docs/evals/external-command-config.swe-bench-pro.json +0 -8
- package/docs/evals/pilots/README.md +0 -47
- package/docs/evals/pilots/swe-bench-pro-public-full-wave-review-10.json +0 -64
- package/docs/evals/pilots/swe-bench-pro-public-pilot.json +0 -111
- package/docs/evals/wave-benchmark-program.md +0 -302
- package/docs/guides/planner.md +0 -220
- package/docs/guides/recommendations-0.8.9.md +0 -133
- package/docs/guides/signal-wrappers.md +0 -165
- package/docs/guides/terminal-surfaces.md +0 -96
- package/docs/image copy.png +0 -0
- package/docs/image.png +0 -0
- package/docs/images/image.png +0 -0
- package/docs/legal-feedback-architecture.md +0 -498
- package/docs/plans/component-cutover-matrix.json +0 -1072
- package/docs/plans/component-cutover-matrix.md +0 -307
- package/docs/plans/context7-wave-orchestrator.md +0 -155
- package/docs/plans/current-state.md +0 -198
- package/docs/plans/docx/README.md +0 -9
- package/docs/plans/examples/wave-benchmark-improvement.md +0 -108
- package/docs/plans/examples/wave-example-live-proof.md +0 -435
- package/docs/plans/master-plan.md +0 -224
- package/docs/plans/migration.md +0 -538
- package/docs/plans/operations/README.md +0 -7
- package/docs/plans/operations/wave-10-word-certification.md +0 -87
- package/docs/plans/operations/wave-8-railway-staging.md +0 -153
- package/docs/plans/operations/wave-9-manual-certification.md +0 -73
- package/docs/plans/platform/README.md +0 -9
- package/docs/plans/reference/legal-checklist-coverage.md +0 -258
- package/docs/plans/wave-orchestrator.md +0 -423
- package/docs/plans/waves/README.md +0 -75
- package/docs/plans/waves/completed/wave-0.md +0 -195
- package/docs/plans/waves/completed/wave-1.md +0 -379
- package/docs/plans/waves/completed/wave-10.md +0 -670
- package/docs/plans/waves/completed/wave-11.md +0 -335
- package/docs/plans/waves/completed/wave-12.md +0 -417
- package/docs/plans/waves/completed/wave-13.md +0 -316
- package/docs/plans/waves/completed/wave-14.md +0 -319
- package/docs/plans/waves/completed/wave-15.md +0 -321
- package/docs/plans/waves/completed/wave-16.md +0 -316
- package/docs/plans/waves/completed/wave-17.md +0 -331
- package/docs/plans/waves/completed/wave-18.md +0 -328
- package/docs/plans/waves/completed/wave-2.md +0 -438
- package/docs/plans/waves/completed/wave-3.md +0 -435
- package/docs/plans/waves/completed/wave-4.md +0 -430
- package/docs/plans/waves/completed/wave-5.md +0 -430
- package/docs/plans/waves/completed/wave-6.md +0 -430
- package/docs/plans/waves/completed/wave-7.md +0 -526
- package/docs/plans/waves/completed/wave-8.md +0 -596
- package/docs/plans/waves/completed/wave-9.md +0 -552
- package/docs/plans/waves/deferred/README.md +0 -14
- package/docs/plans/waves/deferred/encrypted-intake-contracts.md +0 -282
- package/docs/plans/waves/deferred/legal-feedback-wave-expansion.md +0 -308
- package/docs/plans/waves/deferred/wave-encrypted-intake.md +0 -451
- package/docs/plans/waves/design/README.md +0 -5
- package/docs/plans/waves/design/wave-1-a1.md +0 -309
- package/docs/plans/waves/reviews/README.md +0 -5
- package/docs/plans/waves/reviews/wave-0-cont-qa.md +0 -151
- package/docs/plans/waves/reviews/wave-1-cont-qa.md +0 -46
- package/docs/plans/waves/reviews/wave-10-accessibility-and-design.md +0 -51
- package/docs/plans/waves/reviews/wave-10-cont-qa.md +0 -24
- package/docs/plans/waves/reviews/wave-10-dashboard-proof.md +0 -46
- package/docs/plans/waves/reviews/wave-10-performance-signoff.md +0 -55
- package/docs/plans/waves/reviews/wave-10-regression-proof.md +0 -23
- package/docs/plans/waves/reviews/wave-10-release-audit.md +0 -31
- package/docs/plans/waves/reviews/wave-10-service-proof.md +0 -83
- package/docs/plans/waves/reviews/wave-10-word-certification.md +0 -31
- package/docs/plans/waves/reviews/wave-18-ai-contract-closure.md +0 -277
- package/docs/plans/waves/reviews/wave-18-cont-qa.md +0 -255
- package/docs/plans/waves/reviews/wave-18-parity-proof.md +0 -271
- package/docs/plans/waves/reviews/wave-19-cont-qa.md +0 -59
- package/docs/plans/waves/reviews/wave-2-cont-qa.md +0 -72
- package/docs/plans/waves/reviews/wave-20-cont-qa.md +0 -60
- package/docs/plans/waves/reviews/wave-25-cont-qa.md +0 -48
- package/docs/plans/waves/reviews/wave-28-cont-qa.md +0 -46
- package/docs/plans/waves/reviews/wave-29-cont-qa.md +0 -53
- package/docs/plans/waves/reviews/wave-3-cont-qa.md +0 -53
- package/docs/plans/waves/reviews/wave-3-core-proof.md +0 -77
- package/docs/plans/waves/reviews/wave-3-validator-proof.md +0 -73
- package/docs/plans/waves/reviews/wave-32-cont-qa.md +0 -43
- package/docs/plans/waves/reviews/wave-33-cont-qa.md +0 -526
- package/docs/plans/waves/reviews/wave-34-cont-qa.md +0 -100
- package/docs/plans/waves/reviews/wave-35-cont-qa.md +0 -145
- package/docs/plans/waves/reviews/wave-4-cont-qa.md +0 -47
- package/docs/plans/waves/reviews/wave-4-structure-proof.md +0 -69
- package/docs/plans/waves/reviews/wave-5-comment-proof.md +0 -158
- package/docs/plans/waves/reviews/wave-5-cont-qa.md +0 -68
- package/docs/plans/waves/reviews/wave-6-cont-qa.md +0 -416
- package/docs/plans/waves/reviews/wave-6-redline-proof.md +0 -130
- package/docs/plans/waves/reviews/wave-7-cont-qa.md +0 -82
- package/docs/plans/waves/reviews/wave-7-ooxml-compliance.md +0 -85
- package/docs/plans/waves/reviews/wave-7-preservation-proof.md +0 -119
- package/docs/plans/waves/reviews/wave-7-trust-ux.md +0 -87
- package/docs/plans/waves/reviews/wave-8-accessibility-and-design.md +0 -128
- package/docs/plans/waves/reviews/wave-8-cont-qa.md +0 -92
- package/docs/plans/waves/reviews/wave-8-live-proof.md +0 -140
- package/docs/plans/waves/reviews/wave-8-security.md +0 -47
- package/docs/plans/waves/reviews/wave-9-editor-embedding.md +0 -39
- package/docs/plans/waves/reviews/wave-9-fixture-runner.md +0 -56
- package/docs/plans/waves/reviews/wave-9-live-proof.md +0 -105
- package/docs/plans/waves/reviews/wave-9-usability-and-performance.md +0 -152
- package/docs/plans/waves/specs/README.md +0 -5
- package/docs/plans/waves/specs/wave-1-component-boundaries.md +0 -322
- package/docs/plans/waves/specs/wave-1-ooxml-contracts.md +0 -323
- package/docs/plans/waves/specs/wave-1-review-and-ui-contracts.md +0 -339
- package/docs/plans/waves/specs/wave-1-runtime-contracts.md +0 -509
- package/docs/plans/waves/wave-19.md +0 -341
- package/docs/plans/waves/wave-20.md +0 -308
- package/docs/plans/waves/wave-21.md +0 -289
- package/docs/plans/waves/wave-22.md +0 -221
- package/docs/plans/waves/wave-23.md +0 -295
- package/docs/plans/waves/wave-24.md +0 -286
- package/docs/plans/waves/wave-25.md +0 -313
- package/docs/plans/waves/wave-26.md +0 -300
- package/docs/plans/waves/wave-27.md +0 -299
- package/docs/plans/waves/wave-28.md +0 -368
- package/docs/plans/waves/wave-29.md +0 -303
- package/docs/plans/waves/wave-30.md +0 -307
- package/docs/plans/waves/wave-31.md +0 -231
- package/docs/plans/waves/wave-32.md +0 -152
- package/docs/plans/waves/wave-33.md +0 -147
- package/docs/plans/waves/wave-34.md +0 -148
- package/docs/plans/waves/wave-35.md +0 -141
- package/docs/plans/waves/wave-36.md +0 -146
- package/docs/plans/xlsx/README.md +0 -14
- package/docs/plans/xlsx/xlsx-fixture-corpus-and-certification-plan.md +0 -126
- package/docs/reference/cli-reference.md +0 -600
- package/docs/reference/coordination-and-closure.md +0 -487
- package/docs/reference/deep-research-report (15).md +0 -25
- package/docs/reference/docx/README.md +0 -10
- package/docs/reference/legal-checklist.md +0 -445
- package/docs/reference/live-proof-waves.md +0 -199
- package/docs/reference/ooxml-compliance.md +0 -129
- package/docs/reference/ooxml-feature-parity-matrix.md +0 -172
- package/docs/reference/platform/shared-ooxml-platform-guidance.md +0 -77
- package/docs/reference/prototype-agent-prompt-legal-fidelity.md +0 -155
- package/docs/reference/public-api.md +0 -456
- package/docs/reference/repository-guidance.md +0 -58
- package/docs/reference/runtime-config/README.md +0 -182
- package/docs/reference/runtime-config/claude.md +0 -110
- package/docs/reference/runtime-config/codex.md +0 -82
- package/docs/reference/runtime-config/opencode.md +0 -93
- package/docs/reference/sample-waves.md +0 -105
- package/docs/reference/skills.md +0 -237
- package/docs/reference/templates/AGENTS.md +0 -78
- package/docs/reference/templates/HEARTBEAT.md +0 -7
- package/docs/reference/templates/IDENTITY.md +0 -23
- package/docs/reference/templates/SOUL.md +0 -36
- package/docs/reference/templates/TOOLS.md +0 -40
- package/docs/reference/templates/USER.md +0 -17
- package/docs/reference/wave-control.md +0 -184
- package/docs/reference/wave-planning-lessons.md +0 -167
- package/docs/reference/word-review-editor-frontend-architecture.md +0 -479
- package/docs/reference/word-review-editor-ux-guide.md +0 -253
- package/docs/reference/xlsx/xlsx-ooxml-compliance.md +0 -137
- package/docs/research/agent-context-sources.md +0 -178
- package/docs/research/coordination-failure-review.md +0 -290
- package/docs/research/docx-react-component/Canonical Document Schema Specification for a React-based Word-compatible Editor.md +0 -2317
- package/docs/research/docx-react-component/Feature Compatibility Matrix for a React Word Compatible Legal Editor v1.md +0 -219
- package/docs/research/docx-react-component/React Component Architecture and Front-End Structure Specification for a Word-Compatible Legal Review Editor.md +0 -1112
- package/docs/research/docx-react-component/document_compatibility_and_testing_spec.md +0 -751
- package/docs/research/xlsx/raw/README.md +0 -13
- package/docs/roadmap.md +0 -174
- package/docs/superpowers/plans/2026-03-28-harness-control-bar.md +0 -677
- package/docs/superpowers/specs/2026-03-28-harness-control-bar-design.md +0 -274
- package/docs/xlsx-react/README.md +0 -38
- package/docs/xlsx-react/agent-llm-interaction-layer-docx-xlsx.md +0 -621
- package/docs/xlsx-react/canonical-workbook-model-and-commands.md +0 -948
- package/docs/xlsx-react/shared-openxml-editor-platform-docx-xlsx.md +0 -228
- package/docs/xlsx-react/spreadsheet-editor-component-architecture.md +0 -809
- package/docs/xlsx-react/spreadsheet-editor-frontend-architecture.md +0 -537
- package/docs/xlsx-react/spreadsheet-editor-ux-guide.md +0 -520
- package/docs/xlsx-react/xlsx-editor-research-pack.md +0 -871
- package/docs/xlsx-react/xlsx-fixture-corpus-and-certification-plan.md +0 -436
- package/docs/xlsx-react/xlsx-ooxml-compliance.md +0 -320
- package/examples/README.md +0 -16
- package/memory/MEMORY.md +0 -24
- package/pnpm-workspace.yaml +0 -4
- package/scripts/check-no-authored-js.sh +0 -13
- package/scripts/context7-api-check.sh +0 -65
- package/scripts/context7-export-env.sh +0 -42
- package/scripts/run-context7-mcp.sh +0 -8
- package/scripts/run-workspace-tests.sh +0 -15
- package/scripts/start-wave-10-local.sh +0 -189
- package/scripts/wave-agent-attach.sh +0 -47
- package/scripts/wave-auto-answer.sh +0 -118
- package/scripts/wave-dashboard-attach.sh +0 -13
- package/scripts/wave-launch.sh +0 -273
- package/scripts/wave-overnight-supervisor.sh +0 -145
- package/scripts/wave-status.sh +0 -379
- package/scripts/wave-watch.sh +0 -231
- package/services/README.md +0 -17
- package/services/openxml-validator/Dockerfile +0 -29
- package/services/openxml-validator/OpenXmlValidator.Api.csproj +0 -12
- package/services/openxml-validator/Program.cs +0 -436
- package/services/openxml-validator/README.md +0 -152
- package/services/openxml-validator/railway.json +0 -16
- package/services/react-word-editor/.tmp-a4/src/api/public-types.ts +0 -318
- package/services/react-word-editor/.tmp-a4/src/ui/WordReviewEditor.tsx +0 -1302
- package/services/react-word-editor/.tmp-a4/src/ui/editor-surface/editor-surface.tsx +0 -546
- package/services/react-word-editor/.tmp-a4/test/ui/word-review-editor.test.tsx +0 -146
- package/services/react-word-editor/.tmp-a4-build/src/api/public-types.js +0 -2
- package/services/react-word-editor/.tmp-a4-build/src/ui/WordReviewEditor.js +0 -818
- package/services/react-word-editor/.tmp-a4-build/src/ui/editor-surface/editor-surface.js +0 -229
- package/services/react-word-editor/.tmp-a4-build/test/ui/word-review-editor.test.js +0 -121
- package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.json +0 -21
- package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.tsbuildinfo +0 -1
- package/services/react-word-editor/Dockerfile +0 -26
- package/services/react-word-editor/README.md +0 -254
- package/services/react-word-editor/app/api/certification/route.ts +0 -79
- package/services/react-word-editor/app/api/demo-sessions/route.ts +0 -109
- package/services/react-word-editor/app/api/deploy-health/route.ts +0 -23
- package/services/react-word-editor/app/api/exports/[exportId]/route.ts +0 -34
- package/services/react-word-editor/app/api/exports/route.ts +0 -81
- package/services/react-word-editor/app/api/fixtures/[fixtureId]/run/route.ts +0 -100
- package/services/react-word-editor/app/api/health/route.ts +0 -70
- package/services/react-word-editor/app/api/runs/[runId]/route.ts +0 -36
- package/services/react-word-editor/app/api/scenarios/[scenarioId]/run/route.ts +0 -85
- package/services/react-word-editor/app/api/sessions/[sessionId]/route.ts +0 -199
- package/services/react-word-editor/app/api/sessions/[sessionId]/source/route.ts +0 -45
- package/services/react-word-editor/app/api/uploads/route.ts +0 -70
- package/services/react-word-editor/app/api/validate/route.ts +0 -310
- package/services/react-word-editor/app/certification/[runId]/page.tsx +0 -14
- package/services/react-word-editor/app/certification/page.tsx +0 -32
- package/services/react-word-editor/app/dashboard/page.tsx +0 -7
- package/services/react-word-editor/app/demo/page.tsx +0 -30
- package/services/react-word-editor/app/demo/prototype-client.tsx +0 -1080
- package/services/react-word-editor/app/editor/[sessionId]/page.tsx +0 -33
- package/services/react-word-editor/app/fixtures/page.tsx +0 -7
- package/services/react-word-editor/app/globals.css +0 -121
- package/services/react-word-editor/app/layout.tsx +0 -32
- package/services/react-word-editor/app/page.tsx +0 -30
- package/services/react-word-editor/app/runs/[runId]/page.tsx +0 -34
- package/services/react-word-editor/app/wave-10-word-review/page.tsx +0 -7
- package/services/react-word-editor/components/harness-control-bar.tsx +0 -289
- package/services/react-word-editor/components/harness-editor-session-client.tsx +0 -1214
- package/services/react-word-editor/components/harness-workspace-page.tsx +0 -715
- package/services/react-word-editor/components/reduced-motion-toggle.tsx +0 -79
- package/services/react-word-editor/components/workspace-certification-panel.tsx +0 -307
- package/services/react-word-editor/lib/certification-bundle.ts +0 -796
- package/services/react-word-editor/lib/certification-store.ts +0 -661
- package/services/react-word-editor/lib/demo-fixtures.test.mjs +0 -195
- package/services/react-word-editor/lib/demo-fixtures.ts +0 -1519
- package/services/react-word-editor/lib/editor-session-summary.test.mjs +0 -68
- package/services/react-word-editor/lib/editor-session-summary.ts +0 -14
- package/services/react-word-editor/lib/editor-session.ts +0 -228
- package/services/react-word-editor/lib/exports-route.test.mjs +0 -32
- package/services/react-word-editor/lib/harness-client.ts +0 -347
- package/services/react-word-editor/lib/harness-config.json +0 -30
- package/services/react-word-editor/lib/harness-config.test.mjs +0 -31
- package/services/react-word-editor/lib/harness-config.ts +0 -21
- package/services/react-word-editor/lib/harness-editor-datastore.test.mjs +0 -220
- package/services/react-word-editor/lib/harness-editor-datastore.ts +0 -161
- package/services/react-word-editor/lib/private-mode.test.mjs +0 -42
- package/services/react-word-editor/lib/private-mode.ts +0 -61
- package/services/react-word-editor/lib/regression-report.test.mjs +0 -352
- package/services/react-word-editor/lib/regression-report.ts +0 -896
- package/services/react-word-editor/lib/run-artifacts.ts +0 -934
- package/services/react-word-editor/lib/run-history.ts +0 -755
- package/services/react-word-editor/lib/scenario-artifacts.test.mjs +0 -41
- package/services/react-word-editor/lib/scenario-artifacts.ts +0 -44
- package/services/react-word-editor/lib/storage.ts +0 -953
- package/services/react-word-editor/lib/validator-client.test.mjs +0 -54
- package/services/react-word-editor/lib/validator-client.ts +0 -95
- package/services/react-word-editor/lib/workspace-navigation.ts +0 -79
- package/services/react-word-editor/middleware.ts +0 -35
- package/services/react-word-editor/next-env.d.ts +0 -6
- package/services/react-word-editor/next.config.mjs +0 -15
- package/services/react-word-editor/package.json +0 -38
- package/services/react-word-editor/postcss.config.mjs +0 -8
- package/services/react-word-editor/railway.json +0 -21
- package/services/react-word-editor/scripts/wave-10-certification.mjs +0 -101
- package/services/react-word-editor/scripts/wave-9-live-usability-pilot.mjs +0 -911
- package/services/react-word-editor/tsconfig.json +0 -39
- package/services/react-word-editor/tsconfig.tsbuildinfo +0 -1
- package/skills/README.md +0 -48
- package/skills/domain-docx-compatibility/SKILL.md +0 -44
- package/skills/domain-docx-compatibility/skill.json +0 -19
- package/skills/domain-editor-architecture/SKILL.md +0 -49
- package/skills/domain-editor-architecture/skill.json +0 -19
- package/skills/domain-legal-review/SKILL.md +0 -39
- package/skills/domain-legal-review/skill.json +0 -19
- package/skills/provider-aws/SKILL.md +0 -117
- package/skills/provider-aws/adapters/claude.md +0 -1
- package/skills/provider-aws/adapters/codex.md +0 -1
- package/skills/provider-aws/references/service-verification.md +0 -39
- package/skills/provider-aws/skill.json +0 -54
- package/skills/provider-custom-deploy/SKILL.md +0 -64
- package/skills/provider-custom-deploy/skill.json +0 -50
- package/skills/provider-docker-compose/SKILL.md +0 -96
- package/skills/provider-docker-compose/adapters/local.md +0 -1
- package/skills/provider-docker-compose/skill.json +0 -53
- package/skills/provider-github-release/SKILL.md +0 -121
- package/skills/provider-github-release/adapters/claude.md +0 -1
- package/skills/provider-github-release/adapters/codex.md +0 -1
- package/skills/provider-github-release/skill.json +0 -55
- package/skills/provider-kubernetes/SKILL.md +0 -143
- package/skills/provider-kubernetes/adapters/claude.md +0 -1
- package/skills/provider-kubernetes/adapters/codex.md +0 -1
- package/skills/provider-kubernetes/references/kubectl-patterns.md +0 -58
- package/skills/provider-kubernetes/skill.json +0 -52
- package/skills/provider-railway/SKILL.md +0 -123
- package/skills/provider-railway/adapters/claude.md +0 -1
- package/skills/provider-railway/adapters/codex.md +0 -1
- package/skills/provider-railway/adapters/local.md +0 -1
- package/skills/provider-railway/adapters/opencode.md +0 -1
- package/skills/provider-railway/references/verification-commands.md +0 -39
- package/skills/provider-railway/skill.json +0 -71
- package/skills/provider-ssh-manual/SKILL.md +0 -97
- package/skills/provider-ssh-manual/skill.json +0 -54
- package/skills/repo-coding-rules/SKILL.md +0 -55
- package/skills/repo-coding-rules/skill.json +0 -34
- package/skills/role-cont-eval/SKILL.md +0 -91
- package/skills/role-cont-eval/adapters/codex.md +0 -1
- package/skills/role-cont-eval/skill.json +0 -36
- package/skills/role-cont-qa/SKILL.md +0 -100
- package/skills/role-cont-qa/adapters/claude.md +0 -1
- package/skills/role-cont-qa/skill.json +0 -36
- package/skills/role-deploy/SKILL.md +0 -97
- package/skills/role-deploy/skill.json +0 -36
- package/skills/role-design/SKILL.md +0 -50
- package/skills/role-design/skill.json +0 -36
- package/skills/role-documentation/SKILL.md +0 -76
- package/skills/role-documentation/skill.json +0 -36
- package/skills/role-implementation/SKILL.md +0 -45
- package/skills/role-implementation/skill.json +0 -36
- package/skills/role-infra/SKILL.md +0 -81
- package/skills/role-infra/skill.json +0 -36
- package/skills/role-integration/SKILL.md +0 -91
- package/skills/role-integration/skill.json +0 -36
- package/skills/role-planner/SKILL.md +0 -39
- package/skills/role-planner/skill.json +0 -21
- package/skills/role-research/SKILL.md +0 -65
- package/skills/role-research/skill.json +0 -36
- package/skills/role-security/SKILL.md +0 -60
- package/skills/role-security/skill.json +0 -36
- package/skills/runtime-claude/SKILL.md +0 -66
- package/skills/runtime-claude/skill.json +0 -36
- package/skills/runtime-codex/SKILL.md +0 -58
- package/skills/runtime-codex/skill.json +0 -36
- package/skills/runtime-local/SKILL.md +0 -46
- package/skills/runtime-local/skill.json +0 -36
- package/skills/runtime-opencode/SKILL.md +0 -58
- package/skills/runtime-opencode/skill.json +0 -36
- package/skills/signal-hygiene/SKILL.md +0 -51
- package/skills/signal-hygiene/skill.json +0 -20
- package/skills/tui-design/SKILL.md +0 -77
- package/skills/tui-design/references/tui-design.md +0 -259
- package/skills/tui-design/skill.json +0 -36
- package/skills/wave-core/SKILL.md +0 -141
- package/skills/wave-core/references/marker-syntax.md +0 -70
- package/skills/wave-core/skill.json +0 -35
- package/test/README.md +0 -16
- package/test/core/formatting-commands.test.ts +0 -285
- package/test/core/image-commands.test.ts +0 -298
- package/test/core/mapping.test.ts +0 -186
- package/test/core/text-commands.test.ts +0 -176
- package/test/fixtures/docx/F01-basic-contract.docx +0 -0
- package/test/fixtures/docx/F01-basic-contract.md +0 -33
- package/test/fixtures/docx/F02-headings-styles.docx +0 -0
- package/test/fixtures/docx/F02-headings-styles.md +0 -33
- package/test/fixtures/docx/F03-legal-outline-numbering.docx +0 -0
- package/test/fixtures/docx/F03-legal-outline-numbering.md +0 -34
- package/test/fixtures/docx/F04-restart-numbering-schedules.docx +0 -0
- package/test/fixtures/docx/F04-restart-numbering-schedules.md +0 -33
- package/test/fixtures/docx/F05-table-heavy-agreement.docx +0 -0
- package/test/fixtures/docx/F05-table-heavy-agreement.md +0 -34
- package/test/fixtures/docx/F06-merged-cells-signature-table.docx +0 -0
- package/test/fixtures/docx/F06-merged-cells-signature-table.md +0 -34
- package/test/fixtures/docx/F07-inline-images-exhibit.docx +0 -0
- package/test/fixtures/docx/F07-inline-images-exhibit.md +0 -34
- package/test/fixtures/docx/F08-hyperlinks.docx +0 -0
- package/test/fixtures/docx/F08-hyperlinks.md +0 -33
- package/test/fixtures/docx/F09-comments-single-paragraph.docx +0 -0
- package/test/fixtures/docx/F09-comments-single-paragraph.md +0 -33
- package/test/fixtures/docx/F10-threaded-comments-resolve.docx +0 -0
- package/test/fixtures/docx/F10-threaded-comments-resolve.md +0 -33
- package/test/fixtures/docx/F11-redlines-basic.docx +0 -0
- package/test/fixtures/docx/F11-redlines-basic.md +0 -33
- package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.docx +0 -0
- package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.md +0 -33
- package/test/fixtures/docx/F13-comments-on-deleted-text.docx +0 -0
- package/test/fixtures/docx/F13-comments-on-deleted-text.md +0 -33
- package/test/fixtures/docx/F14-revisions-in-tables-and-lists.docx +0 -0
- package/test/fixtures/docx/F14-revisions-in-tables-and-lists.md +0 -33
- package/test/fixtures/docx/F15-sections-headers-footers.docx +0 -0
- package/test/fixtures/docx/F15-sections-headers-footers.md +0 -33
- package/test/fixtures/docx/F16-footnotes-endnotes.docx +0 -0
- package/test/fixtures/docx/F16-footnotes-endnotes.md +0 -33
- package/test/fixtures/docx/F17-fields-and-toc.docx +0 -0
- package/test/fixtures/docx/F17-fields-and-toc.md +0 -33
- package/test/fixtures/docx/F18-content-controls-template.docx +0 -0
- package/test/fixtures/docx/F18-content-controls-template.md +0 -33
- package/test/fixtures/docx/F19-custom-xml-doc-assembly.docx +0 -0
- package/test/fixtures/docx/F19-custom-xml-doc-assembly.md +0 -35
- package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.docx +0 -0
- package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.md +0 -33
- package/test/fixtures/docx/F21-malformed-broken-docx.docx +0 -0
- package/test/fixtures/docx/F21-malformed-broken-docx.md +0 -33
- package/test/fixtures/docx/README.md +0 -74
- package/test/fixtures/docx/certification-manifest.json +0 -104
- package/test/fixtures/docx/fixtures.manifest.json +0 -196
- package/test/fixtures/encrypted-docx/README.md +0 -27
- package/test/fixtures/encrypted-docx/certification-manifest.json +0 -9
- package/test/fixtures/encrypted-docx/fixtures.manifest.json +0 -47
- package/test/fixtures/scenarios/docx/README.md +0 -25
- package/test/fixtures/scenarios/docx/S01-sow-template.docx +0 -0
- package/test/fixtures/scenarios/docx/S01-sow-template.md +0 -30
- package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.docx +0 -0
- package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.md +0 -32
- package/test/fixtures/scenarios/docx/scenario-manifest.json +0 -53
- package/test/formats/xlsx/io/xlsx-import.test.ts +0 -766
- package/test/formats/xlsx/model/workbook.test.ts +0 -669
- package/test/helpers/dom-setup.ts +0 -124
- package/test/io/comment-roundtrip.test.ts +0 -272
- package/test/io/complex-content-roundtrip.test.ts +0 -632
- package/test/io/docx-compatibility-regression.test.ts +0 -199
- package/test/io/docx-session.test.ts +0 -1495
- package/test/io/footnotes-roundtrip.test.ts +0 -318
- package/test/io/headers-footers-roundtrip.test.ts +0 -547
- package/test/io/numbering-roundtrip.test.ts +0 -234
- package/test/io/package-reader.test.ts +0 -199
- package/test/io/paragraph-properties-roundtrip.test.ts +0 -129
- package/test/io/preserved-package-roundtrip.test.ts +0 -365
- package/test/io/property-completeness.test.ts +0 -292
- package/test/io/revision-roundtrip.test.ts +0 -347
- package/test/io/structural-blocks.test.ts +0 -202
- package/test/io/table-media-roundtrip.test.ts +0 -448
- package/test/io/table-properties-roundtrip.test.ts +0 -569
- package/test/io/table-roundtrip.test.ts +0 -302
- package/test/io/text-roundtrip.test.ts +0 -344
- package/test/model/canonical-document.test.ts +0 -285
- package/test/preservation/opaque-fragment-store.test.ts +0 -121
- package/test/preservation/package-preservation.test.ts +0 -395
- package/test/preservation/store.test.ts +0 -84
- package/test/review/comment-remapping.test.ts +0 -220
- package/test/review/comment-store.test.ts +0 -180
- package/test/review/move-revisions.test.ts +0 -143
- package/test/review/property-change-revisions.test.ts +0 -225
- package/test/review/revision-actions.test.ts +0 -330
- package/test/review/revision-store.test.ts +0 -193
- package/test/runtime/session-capabilities.test.ts +0 -260
- package/test/runtime/table-commands.test.ts +0 -356
- package/test/runtime/table-schema.test.ts +0 -221
- package/test/runtime/tracked-changes-toggle.test.ts +0 -107
- package/test/ui/comment-review-surface.test.tsx +0 -114
- package/test/ui/reduced-motion-toggle.test.tsx +0 -137
- package/test/ui/word-review-editor.imported-scenarios.test.tsx +0 -169
- package/test/ui/word-review-editor.interaction.test.tsx +0 -1198
- package/test/ui/word-review-editor.test.js +0 -188
- package/test/ui/word-review-editor.test.tsx +0 -280
- package/test/ui-tailwind/search-plugin.test.ts +0 -286
- package/test/validation/compatibility-engine.test.ts +0 -336
- package/test/validation/compatibility-report.test.ts +0 -189
- package/test/validation/low-priority-word-surfaces.test.ts +0 -282
- package/test/validation/malformed-doc.test.ts +0 -113
- package/test-results/.last-run.json +0 -4
- package/wave.config.json +0 -406
|
@@ -1,254 +0,0 @@
|
|
|
1
|
-
# React Word Editor Harness
|
|
2
|
-
|
|
3
|
-
This service is the internal Railway harness for the editor.
|
|
4
|
-
|
|
5
|
-
## Purpose
|
|
6
|
-
|
|
7
|
-
The harness exists to make it easy to:
|
|
8
|
-
|
|
9
|
-
- upload `.docx` documents
|
|
10
|
-
- browse the permanent fixture corpus and representative scenario artifacts
|
|
11
|
-
- launch an embedded `WordReviewEditor` session
|
|
12
|
-
- export generated `.docx` files
|
|
13
|
-
- inspect compatibility reports
|
|
14
|
-
- send exports to the internal Open XML validator
|
|
15
|
-
|
|
16
|
-
This is an internal test surface, not the customer-facing product.
|
|
17
|
-
|
|
18
|
-
## Runtime Shape
|
|
19
|
-
|
|
20
|
-
- framework: Next.js App Router
|
|
21
|
-
- deploy target: Railway
|
|
22
|
-
- persistence: volume-backed file storage with a manifest index
|
|
23
|
-
- validation dependency: internal `openxml-validator` service over Railway private networking
|
|
24
|
-
- operator posture: internal-only QA and certification harness, not a public app surface
|
|
25
|
-
|
|
26
|
-
## Expected Environment
|
|
27
|
-
|
|
28
|
-
- `PORT`
|
|
29
|
-
- `HARNESS_PRIVATE_MODE`
|
|
30
|
-
- `OPENXML_VALIDATOR_BASE_URL`
|
|
31
|
-
- `OPENXML_VALIDATOR_AUTH_TOKEN`
|
|
32
|
-
- `HARNESS_STORAGE_DIR`
|
|
33
|
-
|
|
34
|
-
`HARNESS_PRIVATE_MODE` must be set to `enabled` before the harness serves routes. When it is
|
|
35
|
-
unset, middleware returns a structured `503` JSON response with `error`, `detail`, and `hint`
|
|
36
|
-
fields instead of exposing the internal QA surface.
|
|
37
|
-
|
|
38
|
-
Railway should health-check `GET /api/deploy-health` rather than `/` so public fail-closed
|
|
39
|
-
deploys can stay healthy without reopening the harness.
|
|
40
|
-
|
|
41
|
-
`HARNESS_STORAGE_DIR` should point at the mounted Railway volume path in staging. If it is
|
|
42
|
-
unset, the harness falls back to the local repo `.tmp` path and reports that fallback through
|
|
43
|
-
`GET /api/health`.
|
|
44
|
-
|
|
45
|
-
For Railway private networking, `OPENXML_VALIDATOR_BASE_URL` should include the
|
|
46
|
-
internal hostname and the validator port:
|
|
47
|
-
|
|
48
|
-
```text
|
|
49
|
-
http://openxml-validator.railway.internal:8080
|
|
50
|
-
```
|
|
51
|
-
|
|
52
|
-
If Railway private networking is unavailable, point `OPENXML_VALIDATOR_BASE_URL` at the
|
|
53
|
-
validator's public domain instead and set `OPENXML_VALIDATOR_AUTH_TOKEN` to the same shared
|
|
54
|
-
secret configured as `VALIDATOR_AUTH_TOKEN` on the validator service.
|
|
55
|
-
|
|
56
|
-
## Internal Routes
|
|
57
|
-
|
|
58
|
-
- `/`
|
|
59
|
-
- `/fixtures`
|
|
60
|
-
- `/dashboard`
|
|
61
|
-
- `/certification`
|
|
62
|
-
- `/certification/[runId]`
|
|
63
|
-
- `/editor/[sessionId]`
|
|
64
|
-
- `/runs/[runId]`
|
|
65
|
-
- `/demo`
|
|
66
|
-
- `GET /api/deploy-health`
|
|
67
|
-
- `GET /api/health`
|
|
68
|
-
- `POST /api/fixtures/[fixtureId]/run`
|
|
69
|
-
- `POST /api/scenarios/[scenarioId]/run`
|
|
70
|
-
- `POST /api/uploads`
|
|
71
|
-
- `POST /api/exports`
|
|
72
|
-
- `POST /api/validate`
|
|
73
|
-
- `GET /api/runs/[runId]`
|
|
74
|
-
|
|
75
|
-
The browser must never call the private validator host directly. Validation is always bridged
|
|
76
|
-
through the harness server.
|
|
77
|
-
|
|
78
|
-
`GET /api/deploy-health` is the one public-safe probe route. It returns a minimal `200` payload
|
|
79
|
-
for Railway health checks without exposing storage, validator, or operator workflow data.
|
|
80
|
-
|
|
81
|
-
`GET /api/health` intentionally redacts the absolute storage path and private validator hostname.
|
|
82
|
-
It reports only the storage mode, persistence model, manifest index version, aggregate counts and
|
|
83
|
-
byte totals, retention assumptions, and either a validator health payload or a configuration/error
|
|
84
|
-
summary.
|
|
85
|
-
|
|
86
|
-
## Railway Monorepo Deploy Rule
|
|
87
|
-
|
|
88
|
-
This harness lives inside a shared pnpm workspace, so Railway must not treat
|
|
89
|
-
`services/react-word-editor/` as an isolated root directory.
|
|
90
|
-
|
|
91
|
-
Use one of these Railway configurations instead:
|
|
92
|
-
|
|
93
|
-
- point the service at `services/react-word-editor/Dockerfile`
|
|
94
|
-
- or set the service's custom config file path to
|
|
95
|
-
`/services/react-word-editor/railway.json`
|
|
96
|
-
|
|
97
|
-
The repo-owned config file pins the Dockerfile path, watch paths, and deploy
|
|
98
|
-
health settings for the harness service.
|
|
99
|
-
|
|
100
|
-
## Storage Model
|
|
101
|
-
|
|
102
|
-
Wave 8 uses one file-backed internal record model across:
|
|
103
|
-
|
|
104
|
-
- source records for the frozen fixture corpus, scenario artifacts, and operator uploads
|
|
105
|
-
- session records for launched editor sessions
|
|
106
|
-
- export records for saved `.docx` artifacts
|
|
107
|
-
- validation-run records for stored Open XML validator results
|
|
108
|
-
|
|
109
|
-
The default local storage directory is:
|
|
110
|
-
|
|
111
|
-
```text
|
|
112
|
-
services/react-word-editor/.tmp/react-word-editor-harness
|
|
113
|
-
```
|
|
114
|
-
|
|
115
|
-
Set `HARNESS_STORAGE_DIR` to a Railway volume mount in staging.
|
|
116
|
-
|
|
117
|
-
The storage index is durable JSON at `<storage>/index.json` and is written atomically through a
|
|
118
|
-
same-directory temp file rename so uploads, session launches, export persistence, and validation
|
|
119
|
-
snapshots do not depend on process memory.
|
|
120
|
-
|
|
121
|
-
## Upload, Export, And Retention Assumptions
|
|
122
|
-
|
|
123
|
-
- accepted source type: `.docx` only
|
|
124
|
-
- accepted upload/export MIME types: `application/vnd.openxmlformats-officedocument.wordprocessingml.document`, `application/octet-stream`, or blank browser file metadata paired with a `.docx` filename
|
|
125
|
-
- upload cap: `20 MiB`
|
|
126
|
-
- exports retained in the local manifest until the harness exceeds `100` saved export artifacts
|
|
127
|
-
- validation reports retained until the harness exceeds `200` stored validation snapshots
|
|
128
|
-
- fixture and scenario source records stay repo-backed and are never copied into the storage volume
|
|
129
|
-
|
|
130
|
-
The retention behavior is deliberately conservative in Wave 8:
|
|
131
|
-
|
|
132
|
-
- uploads remain durable so sessions keep their source packages
|
|
133
|
-
- old exports and validation reports may be trimmed only after the stored limits are exceeded
|
|
134
|
-
- the storage volume is still an internal operator surface, so staging runbooks must record retention checks explicitly
|
|
135
|
-
|
|
136
|
-
`GET /api/health` now returns the storage mode derived from `HARNESS_STORAGE_DIR` versus the
|
|
137
|
-
fallback local path, the manifest index version, aggregate artifact counts and bytes, and the
|
|
138
|
-
exact upload/retention assumptions used by `/api/uploads`, `/api/exports`, and `/api/validate`.
|
|
139
|
-
|
|
140
|
-
Operationally, the harness still assumes manual retention review on the mounted volume:
|
|
141
|
-
|
|
142
|
-
- uploads stay durable so active sessions retain their source package bytes
|
|
143
|
-
- sessions are indexed durably but not garbage-collected by age
|
|
144
|
-
- old exports and validation snapshots are trimmed only when their configured limits are exceeded
|
|
145
|
-
- fixture and scenario sources remain repo-backed and should not be copied into the volume
|
|
146
|
-
|
|
147
|
-
## Shared Review Workspace
|
|
148
|
-
|
|
149
|
-
The harness now uses one review UX across launch and session routes.
|
|
150
|
-
|
|
151
|
-
- launcher route: `/demo`
|
|
152
|
-
- mounted session route: `/editor/[sessionId]`
|
|
153
|
-
- launcher source: `app/demo/page.tsx`
|
|
154
|
-
- mounted host source: `components/harness-editor-session-client.tsx`
|
|
155
|
-
- workspace shell: `src/ui-tailwind/tw-review-workspace.tsx`
|
|
156
|
-
- shared UI helpers: `src/ui/shared/revision-filters.ts`, `src/ui/headless/comment-decoration-model.ts`, `src/ui/headless/revision-decoration-model.ts`
|
|
157
|
-
- guide: `docs/reference/word-review-editor-ux-guide.md`
|
|
158
|
-
- session brokering API: `app/api/demo-sessions/route.ts`
|
|
159
|
-
- mounted session persistence API: `app/api/sessions/[sessionId]/route.ts`
|
|
160
|
-
|
|
161
|
-
`/demo` is no longer a separate prototype editor. It is the internal launcher for the same
|
|
162
|
-
prototype-designed `WordReviewEditor` shell that the mounted runtime uses after a session opens.
|
|
163
|
-
|
|
164
|
-
The host harness may add upload, validation, and QA metadata above the editor, but the
|
|
165
|
-
workspace itself remains the canonical live shell with:
|
|
166
|
-
|
|
167
|
-
- compact toolbar
|
|
168
|
-
- centered document stage
|
|
169
|
-
- floating contextual toolbar
|
|
170
|
-
- unified `Comments`, `Changes`, and `Health` rail
|
|
171
|
-
- minimal bottom status strip
|
|
172
|
-
|
|
173
|
-
The mounted editor now loads from the saved session snapshot when one exists,
|
|
174
|
-
autosaves through `/api/sessions/[sessionId]`, and persists toolbar exports
|
|
175
|
-
through that same session route before validation or certification surfaces read
|
|
176
|
-
the resulting export record.
|
|
177
|
-
|
|
178
|
-
Future-wave affordances may stay visible as disabled controls, but the mounted editor remains the
|
|
179
|
-
truth surface for what is live today.
|
|
180
|
-
|
|
181
|
-
## Scenario Artifacts
|
|
182
|
-
|
|
183
|
-
The harness should treat `test/fixtures/scenarios/docx/` as a separate source set from the frozen F01-F21 fixture corpus.
|
|
184
|
-
|
|
185
|
-
- scenario artifacts are representative acceptance docs, not release-gate fixtures
|
|
186
|
-
- source documents may already carry SDK findings, so the harness must store source-vs-export validator deltas
|
|
187
|
-
- Word reopen and preserve-only survival still decide whether a scenario run passes
|
|
188
|
-
|
|
189
|
-
## Wave 10 QA Surfaces
|
|
190
|
-
|
|
191
|
-
Wave 10 adds three internal QA surfaces on top of the existing fixture and editor routes:
|
|
192
|
-
|
|
193
|
-
- `/dashboard`
|
|
194
|
-
- reads the durable Wave 10 bundle and keeps regression, freshness, validator, signoff, and run-history state in one operator view
|
|
195
|
-
- `/certification`
|
|
196
|
-
- captures manual Word desktop and Word web notes against exact validation runs or export ids
|
|
197
|
-
- `/certification/[runId]`
|
|
198
|
-
- shows the full release-gate corpus plus representative scenarios, anchored to a concrete Wave 10 source run or validator run
|
|
199
|
-
|
|
200
|
-
The automation routes `POST /api/fixtures/[fixtureId]/run` and `POST /api/scenarios/[scenarioId]/run` now persist Wave-aware proof context, execution outcome, classification, and compatibility summary for certification reporting.
|
|
201
|
-
|
|
202
|
-
`GET /api/runs/[runId]` now returns derived Wave 10 diagnostics alongside the stored validator model so the dashboard and certification bundle can link back to exact run history.
|
|
203
|
-
|
|
204
|
-
## Wave 8 Closure Status
|
|
205
|
-
|
|
206
|
-
The repo now contains:
|
|
207
|
-
|
|
208
|
-
- a dedicated workspace package for the harness
|
|
209
|
-
- a Next.js App Router shell under `app/`
|
|
210
|
-
- a file-backed storage layer under `lib/storage.ts`
|
|
211
|
-
- a server-only validator bridge under `lib/validator-client.ts`
|
|
212
|
-
- operator pages for fixtures, sessions, and stored runs
|
|
213
|
-
- real upload, export, health, and validate routes
|
|
214
|
-
- an embedded `WordReviewEditor` session path that loads actual package bytes
|
|
215
|
-
- a deployment `Dockerfile`
|
|
216
|
-
- environment contract notes for Railway-oriented deployment
|
|
217
|
-
- `lib/harness-config.json` as a durable harness inventory artifact
|
|
218
|
-
- `lib/harness-config.test.mjs` as unit proof for the build-order and panel contract
|
|
219
|
-
|
|
220
|
-
The Wave 8 hardening changes are now in source, but authoritative closure is blocked pending a
|
|
221
|
-
fresh private-mode Railway redeploy and proof recapture. The older public early-access bundle under
|
|
222
|
-
`.tmp/wave-8-railway-pilot/` is historical evidence only and must not be used as the current closure line.
|
|
223
|
-
|
|
224
|
-
Historical artifact bundle includes:
|
|
225
|
-
|
|
226
|
-
- live harness health on `docx-react-component-early-access.up.railway.app`
|
|
227
|
-
- live validator health and restart evidence for `openxml-validator`
|
|
228
|
-
- one mounted `F11` `.docx -> add comment -> review action -> export -> validate` run with
|
|
229
|
-
linked export and validation artifacts
|
|
230
|
-
|
|
231
|
-
Before Wave 9 pilot claims can stand again, Wave 8 must be rerun on the private-mode deploy posture.
|
|
232
|
-
|
|
233
|
-
## Fleet-Ready Gaps
|
|
234
|
-
|
|
235
|
-
Wave 10 keeps this surface as an internal QA harness rather than promoting it into a multi-tenant
|
|
236
|
-
service tier.
|
|
237
|
-
|
|
238
|
-
The current Wave 10 bundle is fresh and explicit, but still blocked:
|
|
239
|
-
|
|
240
|
-
- `F09` and `F13` are validator-clean again in the stored machine-backed bundle
|
|
241
|
-
- `S02` remains in scope as an explicit fail-closed scenario, not as a required exportable review path
|
|
242
|
-
- required Word desktop and Word web notes are still pending for `F01`, `F03`, `F05`, `F09`, `F11`, `F12`, `F15`, `F20`, and `S01`
|
|
243
|
-
- accessibility, DESIGN, and performance review docs have been refreshed on the current worktree
|
|
244
|
-
- the stored Wave 10 bundle still needs a current-commit rerun before it can serve as the proof base for Wave 11 release-readiness work
|
|
245
|
-
|
|
246
|
-
Current assumptions and blockers:
|
|
247
|
-
|
|
248
|
-
- access posture is still environment-gated/internal-deploy based rather than identity-backed
|
|
249
|
-
- retention is count-based and manually reviewed; there is no operator-managed archival or expiry
|
|
250
|
-
workflow for uploads, sessions, exports, and validator reports
|
|
251
|
-
- storage durability depends on the mounted Railway volume and manifest rename semantics; there is
|
|
252
|
-
no secondary replica or external database mirror
|
|
253
|
-
- validator availability is a single private dependency through `OPENXML_VALIDATOR_BASE_URL`; there
|
|
254
|
-
is no retry queue or asynchronous validation pipeline yet
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
getCertificationDashboardModel,
|
|
3
|
-
getCertificationStoreSnapshot,
|
|
4
|
-
isCertificationStoreError,
|
|
5
|
-
parseAndCreateManualCertification,
|
|
6
|
-
} from "../../../lib/certification-store";
|
|
7
|
-
import { getHarnessStorageAssumptions } from "../../../lib/storage";
|
|
8
|
-
|
|
9
|
-
export const dynamic = "force-dynamic";
|
|
10
|
-
|
|
11
|
-
export async function GET() {
|
|
12
|
-
const model = await getCertificationDashboardModel();
|
|
13
|
-
|
|
14
|
-
return Response.json(
|
|
15
|
-
{
|
|
16
|
-
summary: model.summary,
|
|
17
|
-
recentCertifications: model.recentCertifications,
|
|
18
|
-
validationCandidates: model.validationCandidates,
|
|
19
|
-
exportCandidates: model.exportCandidates,
|
|
20
|
-
certificationStore: model.storage,
|
|
21
|
-
storage: getHarnessStorageAssumptions(),
|
|
22
|
-
},
|
|
23
|
-
{
|
|
24
|
-
headers: {
|
|
25
|
-
"cache-control": "no-store",
|
|
26
|
-
},
|
|
27
|
-
},
|
|
28
|
-
);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
export async function POST(request: Request) {
|
|
32
|
-
try {
|
|
33
|
-
const contentType = request.headers.get("content-type") || "";
|
|
34
|
-
const body = contentType.startsWith("application/json")
|
|
35
|
-
? ((await request.json()) as Record<string, string | undefined>)
|
|
36
|
-
: Object.fromEntries((await request.formData()).entries()) as Record<string, string | undefined>;
|
|
37
|
-
|
|
38
|
-
const certification = await parseAndCreateManualCertification({
|
|
39
|
-
operator: typeof body.operator === "string" ? body.operator : undefined,
|
|
40
|
-
surface: typeof body.surface === "string" ? body.surface : undefined,
|
|
41
|
-
outcome: typeof body.outcome === "string" ? body.outcome : undefined,
|
|
42
|
-
summary: typeof body.summary === "string" ? body.summary : undefined,
|
|
43
|
-
notes: typeof body.notes === "string" ? body.notes : undefined,
|
|
44
|
-
observedAt: typeof body.observedAt === "string" ? body.observedAt : undefined,
|
|
45
|
-
targetType: typeof body.targetType === "string" ? body.targetType : undefined,
|
|
46
|
-
targetId: typeof body.targetId === "string" ? body.targetId : undefined,
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
return Response.json(
|
|
50
|
-
{
|
|
51
|
-
certification,
|
|
52
|
-
certificationStore: getCertificationStoreSnapshot(),
|
|
53
|
-
storage: getHarnessStorageAssumptions(),
|
|
54
|
-
},
|
|
55
|
-
{
|
|
56
|
-
status: 201,
|
|
57
|
-
headers: {
|
|
58
|
-
"cache-control": "no-store",
|
|
59
|
-
},
|
|
60
|
-
},
|
|
61
|
-
);
|
|
62
|
-
} catch (error) {
|
|
63
|
-
return Response.json(
|
|
64
|
-
{
|
|
65
|
-
error: isCertificationStoreError(error) ? error.code : "certification_failed",
|
|
66
|
-
detail:
|
|
67
|
-
error instanceof Error ? error.message : "Manual certification capture failed.",
|
|
68
|
-
certificationStore: getCertificationStoreSnapshot(),
|
|
69
|
-
storage: getHarnessStorageAssumptions(),
|
|
70
|
-
},
|
|
71
|
-
{
|
|
72
|
-
status: isCertificationStoreError(error) ? error.status : 400,
|
|
73
|
-
headers: {
|
|
74
|
-
"cache-control": "no-store",
|
|
75
|
-
},
|
|
76
|
-
},
|
|
77
|
-
);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
createHarnessSession,
|
|
3
|
-
createHarnessUploadSource,
|
|
4
|
-
DOCX_MIME_TYPE,
|
|
5
|
-
HARNESS_MAX_UPLOAD_BYTES,
|
|
6
|
-
isHarnessStorageError,
|
|
7
|
-
} from "../../../lib/storage";
|
|
8
|
-
import { getHarnessDashboardModel } from "../../../lib/harness-client";
|
|
9
|
-
|
|
10
|
-
export const dynamic = "force-dynamic";
|
|
11
|
-
|
|
12
|
-
function jsonNoStore(body: unknown, init?: ResponseInit): Response {
|
|
13
|
-
return Response.json(body, {
|
|
14
|
-
...init,
|
|
15
|
-
headers: {
|
|
16
|
-
"cache-control": "no-store",
|
|
17
|
-
...(init?.headers ?? {}),
|
|
18
|
-
},
|
|
19
|
-
});
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export async function GET() {
|
|
23
|
-
const model = await getHarnessDashboardModel();
|
|
24
|
-
|
|
25
|
-
return jsonNoStore({
|
|
26
|
-
sources: model.browseableSources,
|
|
27
|
-
recentSessions: model.recentSessions,
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
export async function POST(request: Request) {
|
|
32
|
-
try {
|
|
33
|
-
const contentType = request.headers.get("content-type") || "";
|
|
34
|
-
|
|
35
|
-
if (contentType.startsWith("application/json")) {
|
|
36
|
-
const body = (await request.json()) as {
|
|
37
|
-
sourceId?: string;
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
if (typeof body.sourceId !== "string" || body.sourceId.length === 0) {
|
|
41
|
-
return jsonNoStore(
|
|
42
|
-
{
|
|
43
|
-
error: "missing_source_id",
|
|
44
|
-
detail: "Creating a demo session from JSON requires a sourceId.",
|
|
45
|
-
},
|
|
46
|
-
{ status: 400 },
|
|
47
|
-
);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
const session = await createHarnessSession(body.sourceId);
|
|
51
|
-
return jsonNoStore({ session }, { status: 201 });
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
const formData = await request.formData();
|
|
55
|
-
const sourceId = formData.get("sourceId");
|
|
56
|
-
const file = formData.get("file");
|
|
57
|
-
|
|
58
|
-
if (typeof sourceId === "string" && sourceId.length > 0) {
|
|
59
|
-
const session = await createHarnessSession(sourceId);
|
|
60
|
-
return jsonNoStore({ session }, { status: 201 });
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
if (!(file instanceof File)) {
|
|
64
|
-
return jsonNoStore(
|
|
65
|
-
{
|
|
66
|
-
error: "missing_source",
|
|
67
|
-
detail: "Creating a demo session requires a sourceId or uploaded .docx file.",
|
|
68
|
-
},
|
|
69
|
-
{ status: 400 },
|
|
70
|
-
);
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
const uploadBytes = new Uint8Array(await file.arrayBuffer());
|
|
74
|
-
|
|
75
|
-
if (uploadBytes.byteLength > HARNESS_MAX_UPLOAD_BYTES) {
|
|
76
|
-
return jsonNoStore(
|
|
77
|
-
{
|
|
78
|
-
error: "upload_too_large",
|
|
79
|
-
detail: `Uploads must be ${HARNESS_MAX_UPLOAD_BYTES} bytes or smaller.`,
|
|
80
|
-
},
|
|
81
|
-
{ status: 413 },
|
|
82
|
-
);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
const source = await createHarnessUploadSource({
|
|
86
|
-
fileName: file.name,
|
|
87
|
-
mimeType: file.type || DOCX_MIME_TYPE,
|
|
88
|
-
bytes: uploadBytes,
|
|
89
|
-
});
|
|
90
|
-
const session = await createHarnessSession(source.sourceId);
|
|
91
|
-
|
|
92
|
-
return jsonNoStore(
|
|
93
|
-
{
|
|
94
|
-
session,
|
|
95
|
-
source,
|
|
96
|
-
},
|
|
97
|
-
{ status: 201 },
|
|
98
|
-
);
|
|
99
|
-
} catch (error) {
|
|
100
|
-
return jsonNoStore(
|
|
101
|
-
{
|
|
102
|
-
error: isHarnessStorageError(error) ? error.code : "demo_session_failed",
|
|
103
|
-
detail:
|
|
104
|
-
error instanceof Error ? error.message : "Could not create the demo session.",
|
|
105
|
-
},
|
|
106
|
-
{ status: isHarnessStorageError(error) ? error.status : 400 },
|
|
107
|
-
);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { isHarnessPrivateModeEnabled } from "../../../lib/private-mode";
|
|
2
|
-
|
|
3
|
-
export const dynamic = "force-dynamic";
|
|
4
|
-
|
|
5
|
-
export function GET() {
|
|
6
|
-
const privateModeEnabled = isHarnessPrivateModeEnabled();
|
|
7
|
-
|
|
8
|
-
return Response.json(
|
|
9
|
-
{
|
|
10
|
-
service: "react-word-editor-harness",
|
|
11
|
-
status: "ok",
|
|
12
|
-
harnessAccess: privateModeEnabled ? "enabled" : "disabled",
|
|
13
|
-
detail: privateModeEnabled
|
|
14
|
-
? "The internal QA harness is enabled for this deployment."
|
|
15
|
-
: "The internal QA harness is disabled for this deployment.",
|
|
16
|
-
},
|
|
17
|
-
{
|
|
18
|
-
headers: {
|
|
19
|
-
"cache-control": "no-store",
|
|
20
|
-
},
|
|
21
|
-
},
|
|
22
|
-
);
|
|
23
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { getHarnessExport, readHarnessExportBytes } from "../../../../lib/storage";
|
|
2
|
-
|
|
3
|
-
export async function GET(
|
|
4
|
-
_request: Request,
|
|
5
|
-
context: {
|
|
6
|
-
params: Promise<{
|
|
7
|
-
exportId: string;
|
|
8
|
-
}>;
|
|
9
|
-
},
|
|
10
|
-
) {
|
|
11
|
-
const { exportId } = await context.params;
|
|
12
|
-
const record = await getHarnessExport(exportId);
|
|
13
|
-
|
|
14
|
-
if (!record) {
|
|
15
|
-
return Response.json(
|
|
16
|
-
{
|
|
17
|
-
error: "unknown_export",
|
|
18
|
-
detail: `Export ${exportId} does not exist.`,
|
|
19
|
-
},
|
|
20
|
-
{ status: 404 },
|
|
21
|
-
);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
const bytes = await readHarnessExportBytes(exportId);
|
|
25
|
-
|
|
26
|
-
return new Response(Buffer.from(bytes), {
|
|
27
|
-
status: 200,
|
|
28
|
-
headers: {
|
|
29
|
-
"content-type": record.mimeType,
|
|
30
|
-
"content-disposition": `attachment; filename="${record.fileName}"`,
|
|
31
|
-
"cache-control": "no-store",
|
|
32
|
-
},
|
|
33
|
-
});
|
|
34
|
-
}
|
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
DOCX_MIME_TYPE,
|
|
3
|
-
HARNESS_MAX_UPLOAD_BYTES,
|
|
4
|
-
getHarnessStorageAssumptions,
|
|
5
|
-
isHarnessStorageError,
|
|
6
|
-
saveHarnessExport,
|
|
7
|
-
} from "../../../lib/storage.ts";
|
|
8
|
-
import {
|
|
9
|
-
assertContentLengthWithinLimit,
|
|
10
|
-
isHarnessRouteError,
|
|
11
|
-
} from "../../../lib/private-mode.ts";
|
|
12
|
-
|
|
13
|
-
export async function POST(request: Request) {
|
|
14
|
-
try {
|
|
15
|
-
assertContentLengthWithinLimit(request, HARNESS_MAX_UPLOAD_BYTES);
|
|
16
|
-
const formData = await request.formData();
|
|
17
|
-
const sessionId = formData.get("sessionId");
|
|
18
|
-
const file = formData.get("file");
|
|
19
|
-
const reason = formData.get("reason");
|
|
20
|
-
|
|
21
|
-
if (typeof sessionId !== "string" || sessionId.length === 0) {
|
|
22
|
-
return Response.json(
|
|
23
|
-
{
|
|
24
|
-
error: "missing_session",
|
|
25
|
-
detail: "Export persistence requires a `sessionId` field.",
|
|
26
|
-
storage: getHarnessStorageAssumptions(),
|
|
27
|
-
},
|
|
28
|
-
{ status: 400, headers: { "cache-control": "no-store" } },
|
|
29
|
-
);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
if (!(file instanceof File)) {
|
|
33
|
-
return Response.json(
|
|
34
|
-
{
|
|
35
|
-
error: "missing_file",
|
|
36
|
-
detail: "Export persistence requires a `file` field.",
|
|
37
|
-
storage: getHarnessStorageAssumptions(),
|
|
38
|
-
},
|
|
39
|
-
{ status: 400, headers: { "cache-control": "no-store" } },
|
|
40
|
-
);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
const bytes = new Uint8Array(await file.arrayBuffer());
|
|
44
|
-
const exportRecord = await saveHarnessExport({
|
|
45
|
-
sessionId,
|
|
46
|
-
fileName: file.name,
|
|
47
|
-
mimeType: file.type || DOCX_MIME_TYPE,
|
|
48
|
-
bytes,
|
|
49
|
-
reason: typeof reason === "string" && reason.length > 0 ? reason : undefined,
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
return Response.json({
|
|
53
|
-
exportRecord,
|
|
54
|
-
storage: getHarnessStorageAssumptions(),
|
|
55
|
-
}, {
|
|
56
|
-
headers: {
|
|
57
|
-
"cache-control": "no-store",
|
|
58
|
-
},
|
|
59
|
-
});
|
|
60
|
-
} catch (error) {
|
|
61
|
-
return Response.json(
|
|
62
|
-
{
|
|
63
|
-
error:
|
|
64
|
-
isHarnessStorageError(error) || isHarnessRouteError(error)
|
|
65
|
-
? error.code
|
|
66
|
-
: "export_persist_failed",
|
|
67
|
-
detail: error instanceof Error ? error.message : "Could not persist the export artifact.",
|
|
68
|
-
storage: getHarnessStorageAssumptions(),
|
|
69
|
-
},
|
|
70
|
-
{
|
|
71
|
-
status:
|
|
72
|
-
isHarnessStorageError(error) || isHarnessRouteError(error)
|
|
73
|
-
? error.status
|
|
74
|
-
: 400,
|
|
75
|
-
headers: {
|
|
76
|
-
"cache-control": "no-store",
|
|
77
|
-
},
|
|
78
|
-
},
|
|
79
|
-
);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
getHarnessStorageAssumptions,
|
|
3
|
-
getHarnessSource,
|
|
4
|
-
isHarnessStorageError,
|
|
5
|
-
} from "../../../../../lib/storage";
|
|
6
|
-
import { executeAutomatedSourceRun } from "../../../../../lib/run-artifacts";
|
|
7
|
-
import { loadWave10CertificationManifest } from "../../../../../lib/regression-report";
|
|
8
|
-
|
|
9
|
-
export async function POST(
|
|
10
|
-
request: Request,
|
|
11
|
-
context: {
|
|
12
|
-
params: Promise<{
|
|
13
|
-
fixtureId: string;
|
|
14
|
-
}>;
|
|
15
|
-
},
|
|
16
|
-
) {
|
|
17
|
-
try {
|
|
18
|
-
const { fixtureId } = await context.params;
|
|
19
|
-
const normalizedFixtureId = fixtureId.toUpperCase();
|
|
20
|
-
const body = (await request.json().catch(() => ({}))) as {
|
|
21
|
-
exportFileName?: string;
|
|
22
|
-
reason?: string;
|
|
23
|
-
runId?: string;
|
|
24
|
-
proofWave?: number;
|
|
25
|
-
bundleId?: string;
|
|
26
|
-
};
|
|
27
|
-
const sourceId = `fixture:${normalizedFixtureId}`;
|
|
28
|
-
const [manifest, source] = await Promise.all([
|
|
29
|
-
loadWave10CertificationManifest(),
|
|
30
|
-
getHarnessSource(sourceId),
|
|
31
|
-
]);
|
|
32
|
-
|
|
33
|
-
if (
|
|
34
|
-
!source ||
|
|
35
|
-
source.sourceKind !== "fixture" ||
|
|
36
|
-
!manifest.releaseGateFixtures.includes(normalizedFixtureId)
|
|
37
|
-
) {
|
|
38
|
-
return Response.json(
|
|
39
|
-
{
|
|
40
|
-
error: "unknown_fixture",
|
|
41
|
-
detail: `Fixture ${normalizedFixtureId} does not exist in the frozen Wave 10 release-gate corpus.`,
|
|
42
|
-
storage: getHarnessStorageAssumptions(),
|
|
43
|
-
},
|
|
44
|
-
{ status: 404, headers: { "cache-control": "no-store" } },
|
|
45
|
-
);
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
const result = await executeAutomatedSourceRun({
|
|
49
|
-
sourceId,
|
|
50
|
-
trigger: "fixture-route",
|
|
51
|
-
requestedRunId: body.runId,
|
|
52
|
-
exportReason: body.reason,
|
|
53
|
-
exportFileName: body.exportFileName,
|
|
54
|
-
proofWave: body.proofWave,
|
|
55
|
-
bundleId: body.bundleId,
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
return Response.json(
|
|
59
|
-
{
|
|
60
|
-
runId: result.runStory.runId,
|
|
61
|
-
proofContext: result.runStory.proofContext,
|
|
62
|
-
classification: source.featureClassFocus,
|
|
63
|
-
releaseGate: {
|
|
64
|
-
fixtureId: normalizedFixtureId,
|
|
65
|
-
corpus: "frozen-v1",
|
|
66
|
-
harnessPath: manifest.automationRoute,
|
|
67
|
-
manualReviewRequired: manifest.manualReviewFixtures.includes(normalizedFixtureId),
|
|
68
|
-
},
|
|
69
|
-
executionOutcome: result.executionOutcome,
|
|
70
|
-
compatibilitySummary: result.compatibilitySummary,
|
|
71
|
-
source: result.source,
|
|
72
|
-
session: result.session,
|
|
73
|
-
exportRecord: result.exportRecord,
|
|
74
|
-
validationRun: result.validationRun,
|
|
75
|
-
report: result.report,
|
|
76
|
-
runStory: result.runStory,
|
|
77
|
-
storage: getHarnessStorageAssumptions(),
|
|
78
|
-
},
|
|
79
|
-
{
|
|
80
|
-
headers: {
|
|
81
|
-
"cache-control": "no-store",
|
|
82
|
-
},
|
|
83
|
-
},
|
|
84
|
-
);
|
|
85
|
-
} catch (error) {
|
|
86
|
-
return Response.json(
|
|
87
|
-
{
|
|
88
|
-
error: isHarnessStorageError(error) ? error.code : "fixture_run_failed",
|
|
89
|
-
detail: error instanceof Error ? error.message : "Fixture run failed.",
|
|
90
|
-
storage: getHarnessStorageAssumptions(),
|
|
91
|
-
},
|
|
92
|
-
{
|
|
93
|
-
status: isHarnessStorageError(error) ? error.status : 400,
|
|
94
|
-
headers: {
|
|
95
|
-
"cache-control": "no-store",
|
|
96
|
-
},
|
|
97
|
-
},
|
|
98
|
-
);
|
|
99
|
-
}
|
|
100
|
-
}
|