openspecui 0.0.0
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/.gitmodules +3 -0
- package/CHAT.md +3 -0
- package/package.json +12 -0
- package/references/openspec/.changeset/README.md +6 -0
- package/references/openspec/.changeset/config.json +12 -0
- package/references/openspec/.coderabbit.yaml +11 -0
- package/references/openspec/.devcontainer/README.md +92 -0
- package/references/openspec/.devcontainer/devcontainer.json +68 -0
- package/references/openspec/.github/CODEOWNERS +2 -0
- package/references/openspec/.github/workflows/ci.yml +222 -0
- package/references/openspec/.github/workflows/release-prepare.yml +50 -0
- package/references/openspec/AGENTS.md +18 -0
- package/references/openspec/CHANGELOG.md +205 -0
- package/references/openspec/LICENSE +22 -0
- package/references/openspec/README.md +374 -0
- package/references/openspec/assets/openspec_dashboard.png +0 -0
- package/references/openspec/assets/openspec_pixel_dark.svg +89 -0
- package/references/openspec/assets/openspec_pixel_light.svg +89 -0
- package/references/openspec/bin/openspec.js +3 -0
- package/references/openspec/build.js +31 -0
- package/references/openspec/openspec/AGENTS.md +454 -0
- package/references/openspec/openspec/changes/IMPLEMENTATION_ORDER.md +68 -0
- package/references/openspec/openspec/changes/add-antigravity-support/proposal.md +11 -0
- package/references/openspec/openspec/changes/add-antigravity-support/specs/cli-init/spec.md +9 -0
- package/references/openspec/openspec/changes/add-antigravity-support/specs/cli-update/spec.md +8 -0
- package/references/openspec/openspec/changes/add-antigravity-support/tasks.md +12 -0
- package/references/openspec/openspec/changes/add-scaffold-command/proposal.md +11 -0
- package/references/openspec/openspec/changes/add-scaffold-command/specs/cli-scaffold/spec.md +36 -0
- package/references/openspec/openspec/changes/add-scaffold-command/tasks.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-01-11-add-update-command/design.md +86 -0
- package/references/openspec/openspec/changes/archive/2025-01-11-add-update-command/proposal.md +29 -0
- package/references/openspec/openspec/changes/archive/2025-01-11-add-update-command/specs/cli-update/spec.md +59 -0
- package/references/openspec/openspec/changes/archive/2025-01-11-add-update-command/tasks.md +20 -0
- package/references/openspec/openspec/changes/archive/2025-01-13-add-list-command/proposal.md +20 -0
- package/references/openspec/openspec/changes/archive/2025-01-13-add-list-command/specs/cli-list/spec.md +69 -0
- package/references/openspec/openspec/changes/archive/2025-01-13-add-list-command/tasks.md +26 -0
- package/references/openspec/openspec/changes/archive/2025-08-05-initialize-typescript-project/design.md +64 -0
- package/references/openspec/openspec/changes/archive/2025-08-05-initialize-typescript-project/proposal.md +18 -0
- package/references/openspec/openspec/changes/archive/2025-08-05-initialize-typescript-project/tasks.md +25 -0
- package/references/openspec/openspec/changes/archive/2025-08-06-add-init-command/design.md +104 -0
- package/references/openspec/openspec/changes/archive/2025-08-06-add-init-command/proposal.md +30 -0
- package/references/openspec/openspec/changes/archive/2025-08-06-add-init-command/specs/cli-init/spec.md +148 -0
- package/references/openspec/openspec/changes/archive/2025-08-06-add-init-command/tasks.md +38 -0
- package/references/openspec/openspec/changes/archive/2025-08-06-adopt-future-state-storage/proposal.md +24 -0
- package/references/openspec/openspec/changes/archive/2025-08-06-adopt-future-state-storage/specs/openspec-conventions/spec.md +120 -0
- package/references/openspec/openspec/changes/archive/2025-08-06-adopt-future-state-storage/tasks.md +38 -0
- package/references/openspec/openspec/changes/archive/2025-08-11-add-complexity-guidelines/proposal.md +13 -0
- package/references/openspec/openspec/changes/archive/2025-08-11-add-complexity-guidelines/specs/openspec-docs/README.md +472 -0
- package/references/openspec/openspec/changes/archive/2025-08-11-add-complexity-guidelines/tasks.md +9 -0
- package/references/openspec/openspec/changes/archive/2025-08-13-add-archive-command/proposal.md +15 -0
- package/references/openspec/openspec/changes/archive/2025-08-13-add-archive-command/specs/cli-archive/spec.md +111 -0
- package/references/openspec/openspec/changes/archive/2025-08-13-add-archive-command/tasks.md +44 -0
- package/references/openspec/openspec/changes/archive/2025-08-13-add-diff-command/proposal.md +19 -0
- package/references/openspec/openspec/changes/archive/2025-08-13-add-diff-command/specs/cli-diff/spec.md +77 -0
- package/references/openspec/openspec/changes/archive/2025-08-13-add-diff-command/tasks.md +23 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-change-commands/design.md +56 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-change-commands/proposal.md +17 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-change-commands/specs/cli-change/spec.md +48 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-change-commands/specs/cli-list/spec.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-change-commands/tasks.md +34 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-interactive-show-command/proposal.md +20 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-interactive-show-command/specs/cli-change/spec.md +23 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-interactive-show-command/specs/cli-show/spec.md +83 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-interactive-show-command/specs/cli-spec/spec.md +23 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-interactive-show-command/tasks.md +142 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-skip-specs-archive-option/proposal.md +13 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-skip-specs-archive-option/specs/cli-archive/spec.md +191 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-skip-specs-archive-option/tasks.md +57 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-spec-commands/design.md +45 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-spec-commands/proposal.md +19 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-spec-commands/specs/cli-spec/spec.md +43 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-spec-commands/tasks.md +22 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-zod-validation/design.md +104 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-zod-validation/proposal.md +22 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-zod-validation/specs/cli-archive/spec.md +18 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-zod-validation/specs/cli-diff/spec.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-add-zod-validation/tasks.md +59 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-delta-based-changes/proposal.md +93 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-delta-based-changes/specs/cli-archive/spec.md +48 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-delta-based-changes/specs/cli-diff/spec.md +45 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-delta-based-changes/specs/openspec-conventions/spec.md +101 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-delta-based-changes/tasks.md +55 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-verb-noun-cli-structure/design.md +19 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-verb-noun-cli-structure/proposal.md +67 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-verb-noun-cli-structure/specs/cli-list/spec.md +57 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-verb-noun-cli-structure/specs/openspec-conventions/spec.md +23 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-adopt-verb-noun-cli-structure/tasks.md +27 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-bulk-validation-interactive-selection/proposal.md +20 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-bulk-validation-interactive-selection/specs/cli-change/spec.md +22 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-bulk-validation-interactive-selection/specs/cli-spec/spec.md +23 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-bulk-validation-interactive-selection/specs/cli-validate/spec.md +149 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-bulk-validation-interactive-selection/tasks.md +81 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-fix-update-tool-selection/proposal.md +40 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-fix-update-tool-selection/specs/cli-update/spec.md +23 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-fix-update-tool-selection/tasks.md +21 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-improve-validate-error-messages/proposal.md +25 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-improve-validate-error-messages/specs/cli-validate/spec.md +55 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-improve-validate-error-messages/tasks.md +21 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-structured-spec-format/proposal.md +36 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-structured-spec-format/specs/openspec-conventions/spec.md +192 -0
- package/references/openspec/openspec/changes/archive/2025-08-19-structured-spec-format/tasks.md +19 -0
- package/references/openspec/openspec/changes/archive/2025-09-12-add-view-dashboard-command/proposal.md +38 -0
- package/references/openspec/openspec/changes/archive/2025-09-12-add-view-dashboard-command/specs/cli-view/spec.md +109 -0
- package/references/openspec/openspec/changes/archive/2025-09-12-add-view-dashboard-command/tasks.md +47 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-agents-md-config/proposal.md +28 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-agents-md-config/specs/cli-init/spec.md +71 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-agents-md-config/specs/cli-update/spec.md +41 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-agents-md-config/tasks.md +17 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-multi-agent-init/proposal.md +35 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-multi-agent-init/specs/cli-init/spec.md +45 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-multi-agent-init/tasks.md +16 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-slash-command-support/proposal.md +119 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-slash-command-support/specs/cli-init/spec.md +21 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-slash-command-support/specs/cli-update/spec.md +22 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-add-slash-command-support/tasks.md +20 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-improve-cli-e2e-plan/proposal.md +19 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-improve-cli-e2e-plan/tasks.md +9 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-improve-deterministic-tests/proposal.md +78 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-improve-deterministic-tests/tasks.md +25 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-improve-init-onboarding/proposal.md +13 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-improve-init-onboarding/specs/cli-init/spec.md +92 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-improve-init-onboarding/tasks.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-remove-diff-command/proposal.md +81 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-remove-diff-command/tasks.md +37 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-sort-active-changes-by-progress/proposal.md +25 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-sort-active-changes-by-progress/specs/cli-view/spec.md +9 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-sort-active-changes-by-progress/tasks.md +8 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-agent-file-name/proposal.md +29 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-agent-file-name/specs/cli-init/spec.md +40 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-agent-file-name/specs/cli-update/spec.md +22 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-agent-file-name/specs/openspec-conventions/spec.md +27 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-agent-file-name/tasks.md +22 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-agent-instructions/design.md +130 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-agent-instructions/proposal.md +117 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-agent-instructions/tasks.md +69 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-markdown-parser-crlf/proposal.md +19 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-markdown-parser-crlf/specs/cli-validate/spec.md +9 -0
- package/references/openspec/openspec/changes/archive/2025-09-29-update-markdown-parser-crlf/tasks.md +11 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-codex-slash-command-support/proposal.md +25 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-codex-slash-command-support/specs/cli-init/spec.md +56 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-codex-slash-command-support/specs/cli-update/spec.md +41 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-codex-slash-command-support/tasks.md +19 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-github-copilot-prompts/proposal.md +25 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-github-copilot-prompts/specs/cli-init/spec.md +48 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-github-copilot-prompts/specs/cli-update/spec.md +48 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-github-copilot-prompts/tasks.md +30 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-kilocode-workflows/proposal.md +17 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-kilocode-workflows/specs/cli-init/spec.md +43 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-kilocode-workflows/specs/cli-update/spec.md +27 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-kilocode-workflows/tasks.md +15 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-non-interactive-init-options/proposal.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-non-interactive-init-options/specs/cli-init/spec.md +39 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-non-interactive-init-options/tasks.md +17 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-windsurf-workflows/proposal.md +17 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-windsurf-workflows/specs/cli-init/spec.md +42 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-windsurf-workflows/specs/cli-update/spec.md +27 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-add-windsurf-workflows/tasks.md +17 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-enhance-validation-error-messages/proposal.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-enhance-validation-error-messages/specs/cli-validate/spec.md +39 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-enhance-validation-error-messages/tasks.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-improve-agent-instruction-usability/proposal.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-improve-agent-instruction-usability/specs/docs-agent-instructions/spec.md +33 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-improve-agent-instruction-usability/tasks.md +11 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-slim-root-agents-file/proposal.md +13 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-slim-root-agents-file/tasks.md +15 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-cli-init-enter-selection/proposal.md +14 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-cli-init-enter-selection/specs/cli-init/spec.md +10 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-cli-init-enter-selection/tasks.md +8 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-cli-init-root-agents/proposal.md +15 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-cli-init-root-agents/specs/cli-init/spec.md +32 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-cli-init-root-agents/specs/cli-update/spec.md +10 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-cli-init-root-agents/tasks.md +11 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-release-automation/proposal.md +49 -0
- package/references/openspec/openspec/changes/archive/2025-10-14-update-release-automation/tasks.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-archive-command-arguments/proposal.md +17 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-archive-command-arguments/specs/cli-update/spec.md +32 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-archive-command-arguments/tasks.md +15 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-cline-support/proposal.md +15 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-cline-support/specs/cli-init/spec.md +97 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-cline-support/tasks.md +19 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-crush-support/proposal.md +13 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-crush-support/specs/cli-init/spec.md +67 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-crush-support/tasks.md +7 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-factory-slash-commands/proposal.md +12 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-factory-slash-commands/specs/cli-init/spec.md +54 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-factory-slash-commands/specs/cli-update/spec.md +54 -0
- package/references/openspec/openspec/changes/archive/2025-10-22-add-factory-slash-commands/tasks.md +11 -0
- package/references/openspec/openspec/changes/fix-cline-workflows-implementation/proposal.md +13 -0
- package/references/openspec/openspec/changes/fix-cline-workflows-implementation/specs/cli-init/spec.md +11 -0
- package/references/openspec/openspec/changes/fix-cline-workflows-implementation/tasks.md +13 -0
- package/references/openspec/openspec/changes/make-validation-scope-aware/proposal.md +12 -0
- package/references/openspec/openspec/changes/make-validation-scope-aware/specs/cli-validate/spec.md +25 -0
- package/references/openspec/openspec/changes/make-validation-scope-aware/tasks.md +16 -0
- package/references/openspec/openspec/project.md +53 -0
- package/references/openspec/openspec/specs/cli-archive/spec.md +210 -0
- package/references/openspec/openspec/specs/cli-change/spec.md +91 -0
- package/references/openspec/openspec/specs/cli-init/spec.md +311 -0
- package/references/openspec/openspec/specs/cli-list/spec.md +103 -0
- package/references/openspec/openspec/specs/cli-show/spec.md +85 -0
- package/references/openspec/openspec/specs/cli-spec/spec.md +87 -0
- package/references/openspec/openspec/specs/cli-update/spec.md +190 -0
- package/references/openspec/openspec/specs/cli-validate/spec.md +218 -0
- package/references/openspec/openspec/specs/cli-view/spec.md +105 -0
- package/references/openspec/openspec/specs/docs-agent-instructions/spec.md +38 -0
- package/references/openspec/openspec/specs/openspec-conventions/spec.md +474 -0
- package/references/openspec/openspec-parallel-merge-plan.md +98 -0
- package/references/openspec/package.json +73 -0
- package/references/openspec/pnpm-lock.yaml +2324 -0
- package/references/openspec/scripts/pack-version-check.mjs +111 -0
- package/references/openspec/src/cli/index.ts +253 -0
- package/references/openspec/src/commands/change.ts +291 -0
- package/references/openspec/src/commands/show.ts +139 -0
- package/references/openspec/src/commands/spec.ts +250 -0
- package/references/openspec/src/commands/validate.ts +305 -0
- package/references/openspec/src/core/archive.ts +606 -0
- package/references/openspec/src/core/config.ts +41 -0
- package/references/openspec/src/core/configurators/agents.ts +23 -0
- package/references/openspec/src/core/configurators/base.ts +6 -0
- package/references/openspec/src/core/configurators/claude.ts +23 -0
- package/references/openspec/src/core/configurators/cline.ts +23 -0
- package/references/openspec/src/core/configurators/codebuddy.ts +24 -0
- package/references/openspec/src/core/configurators/costrict.ts +23 -0
- package/references/openspec/src/core/configurators/iflow.ts +23 -0
- package/references/openspec/src/core/configurators/qoder.ts +53 -0
- package/references/openspec/src/core/configurators/qwen.ts +47 -0
- package/references/openspec/src/core/configurators/registry.ts +49 -0
- package/references/openspec/src/core/configurators/slash/amazon-q.ts +51 -0
- package/references/openspec/src/core/configurators/slash/antigravity.ts +28 -0
- package/references/openspec/src/core/configurators/slash/auggie.ts +37 -0
- package/references/openspec/src/core/configurators/slash/base.ts +95 -0
- package/references/openspec/src/core/configurators/slash/claude.ts +42 -0
- package/references/openspec/src/core/configurators/slash/cline.ts +27 -0
- package/references/openspec/src/core/configurators/slash/codebuddy.ts +43 -0
- package/references/openspec/src/core/configurators/slash/codex.ts +126 -0
- package/references/openspec/src/core/configurators/slash/costrict.ts +36 -0
- package/references/openspec/src/core/configurators/slash/crush.ts +42 -0
- package/references/openspec/src/core/configurators/slash/cursor.ts +42 -0
- package/references/openspec/src/core/configurators/slash/factory.ts +41 -0
- package/references/openspec/src/core/configurators/slash/gemini.ts +27 -0
- package/references/openspec/src/core/configurators/slash/github-copilot.ts +39 -0
- package/references/openspec/src/core/configurators/slash/iflow.ts +42 -0
- package/references/openspec/src/core/configurators/slash/kilocode.ts +21 -0
- package/references/openspec/src/core/configurators/slash/opencode.ts +83 -0
- package/references/openspec/src/core/configurators/slash/qoder.ts +84 -0
- package/references/openspec/src/core/configurators/slash/qwen.ts +55 -0
- package/references/openspec/src/core/configurators/slash/registry.ts +81 -0
- package/references/openspec/src/core/configurators/slash/roocode.ts +27 -0
- package/references/openspec/src/core/configurators/slash/toml-base.ts +66 -0
- package/references/openspec/src/core/configurators/slash/windsurf.ts +27 -0
- package/references/openspec/src/core/converters/json-converter.ts +61 -0
- package/references/openspec/src/core/index.ts +2 -0
- package/references/openspec/src/core/init.ts +986 -0
- package/references/openspec/src/core/list.ts +104 -0
- package/references/openspec/src/core/parsers/change-parser.ts +234 -0
- package/references/openspec/src/core/parsers/markdown-parser.ts +237 -0
- package/references/openspec/src/core/parsers/requirement-blocks.ts +234 -0
- package/references/openspec/src/core/schemas/base.schema.ts +20 -0
- package/references/openspec/src/core/schemas/change.schema.ts +42 -0
- package/references/openspec/src/core/schemas/index.ts +20 -0
- package/references/openspec/src/core/schemas/spec.schema.ts +17 -0
- package/references/openspec/src/core/styles/palette.ts +8 -0
- package/references/openspec/src/core/templates/agents-root-stub.ts +16 -0
- package/references/openspec/src/core/templates/agents-template.ts +457 -0
- package/references/openspec/src/core/templates/claude-template.ts +1 -0
- package/references/openspec/src/core/templates/cline-template.ts +1 -0
- package/references/openspec/src/core/templates/costrict-template.ts +1 -0
- package/references/openspec/src/core/templates/index.ts +50 -0
- package/references/openspec/src/core/templates/project-template.ts +38 -0
- package/references/openspec/src/core/templates/slash-command-templates.ts +60 -0
- package/references/openspec/src/core/update.ts +129 -0
- package/references/openspec/src/core/validation/constants.ts +48 -0
- package/references/openspec/src/core/validation/types.ts +19 -0
- package/references/openspec/src/core/validation/validator.ts +448 -0
- package/references/openspec/src/core/view.ts +189 -0
- package/references/openspec/src/index.ts +2 -0
- package/references/openspec/src/utils/file-system.ts +187 -0
- package/references/openspec/src/utils/index.ts +2 -0
- package/references/openspec/src/utils/interactive.ts +7 -0
- package/references/openspec/src/utils/item-discovery.ts +45 -0
- package/references/openspec/src/utils/match.ts +26 -0
- package/references/openspec/src/utils/task-progress.ts +43 -0
- package/references/openspec/test/cli-e2e/basic.test.ts +156 -0
- package/references/openspec/test/commands/change.interactive-show.test.ts +45 -0
- package/references/openspec/test/commands/change.interactive-validate.test.ts +48 -0
- package/references/openspec/test/commands/show.test.ts +123 -0
- package/references/openspec/test/commands/spec.interactive-show.test.ts +44 -0
- package/references/openspec/test/commands/spec.interactive-validate.test.ts +44 -0
- package/references/openspec/test/commands/spec.test.ts +324 -0
- package/references/openspec/test/commands/validate.enriched-output.test.ts +49 -0
- package/references/openspec/test/commands/validate.test.ts +133 -0
- package/references/openspec/test/core/archive.test.ts +680 -0
- package/references/openspec/test/core/commands/change-command.list.test.ts +76 -0
- package/references/openspec/test/core/commands/change-command.show-validate.test.ts +111 -0
- package/references/openspec/test/core/converters/json-converter.test.ts +184 -0
- package/references/openspec/test/core/init.test.ts +1710 -0
- package/references/openspec/test/core/list.test.ts +165 -0
- package/references/openspec/test/core/parsers/change-parser.test.ts +52 -0
- package/references/openspec/test/core/parsers/markdown-parser.test.ts +291 -0
- package/references/openspec/test/core/update.test.ts +1642 -0
- package/references/openspec/test/core/validation.enriched-messages.test.ts +74 -0
- package/references/openspec/test/core/validation.test.ts +489 -0
- package/references/openspec/test/core/view.test.ts +79 -0
- package/references/openspec/test/fixtures/tmp-init/openspec/changes/c1/proposal.md +7 -0
- package/references/openspec/test/fixtures/tmp-init/openspec/changes/c1/specs/alpha/spec.md +8 -0
- package/references/openspec/test/fixtures/tmp-init/openspec/specs/alpha/spec.md +12 -0
- package/references/openspec/test/helpers/run-cli.ts +139 -0
- package/references/openspec/test/utils/file-system.test.ts +211 -0
- package/references/openspec/test/utils/marker-updates.test.ts +287 -0
- package/references/openspec/tsconfig.json +21 -0
- package/references/openspec/vitest.config.ts +25 -0
- package/references/openspec/vitest.setup.ts +6 -0
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
2
|
+
import { ChangeCommand } from '../../../src/commands/change.js';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { promises as fs } from 'fs';
|
|
5
|
+
import os from 'os';
|
|
6
|
+
|
|
7
|
+
describe('ChangeCommand.list', () => {
|
|
8
|
+
let cmd: ChangeCommand;
|
|
9
|
+
let tempRoot: string;
|
|
10
|
+
let originalCwd: string;
|
|
11
|
+
|
|
12
|
+
beforeAll(async () => {
|
|
13
|
+
cmd = new ChangeCommand();
|
|
14
|
+
originalCwd = process.cwd();
|
|
15
|
+
tempRoot = path.join(os.tmpdir(), `openspec-change-command-list-${Date.now()}`);
|
|
16
|
+
const changeDir = path.join(tempRoot, 'openspec', 'changes', 'demo');
|
|
17
|
+
await fs.mkdir(changeDir, { recursive: true });
|
|
18
|
+
const proposal = `# Change: Demo\n\n## Why\nTest list.\n\n## What Changes\n- **auth:** Add requirement`;
|
|
19
|
+
await fs.writeFile(path.join(changeDir, 'proposal.md'), proposal, 'utf-8');
|
|
20
|
+
await fs.writeFile(path.join(changeDir, 'tasks.md'), '- [x] Task 1\n- [ ] Task 2\n', 'utf-8');
|
|
21
|
+
process.chdir(tempRoot);
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
afterAll(async () => {
|
|
25
|
+
process.chdir(originalCwd);
|
|
26
|
+
await fs.rm(tempRoot, { recursive: true, force: true });
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it('returns JSON with expected shape', async () => {
|
|
30
|
+
// Capture console output
|
|
31
|
+
const logs: string[] = [];
|
|
32
|
+
const origLog = console.log;
|
|
33
|
+
try {
|
|
34
|
+
console.log = (msg?: any, ...args: any[]) => {
|
|
35
|
+
logs.push([msg, ...args].filter(Boolean).join(' '));
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
await cmd.list({ json: true });
|
|
39
|
+
|
|
40
|
+
const output = logs.join('\n');
|
|
41
|
+
const parsed = JSON.parse(output);
|
|
42
|
+
expect(Array.isArray(parsed)).toBe(true);
|
|
43
|
+
if (parsed.length > 0) {
|
|
44
|
+
const item = parsed[0];
|
|
45
|
+
expect(item).toHaveProperty('id');
|
|
46
|
+
expect(item).toHaveProperty('title');
|
|
47
|
+
expect(item).toHaveProperty('deltaCount');
|
|
48
|
+
expect(item).toHaveProperty('taskStatus');
|
|
49
|
+
expect(item.taskStatus).toHaveProperty('total');
|
|
50
|
+
expect(item.taskStatus).toHaveProperty('completed');
|
|
51
|
+
}
|
|
52
|
+
} finally {
|
|
53
|
+
console.log = origLog;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it('prints IDs by default and details with --long', async () => {
|
|
58
|
+
const logs: string[] = [];
|
|
59
|
+
const origLog = console.log;
|
|
60
|
+
try {
|
|
61
|
+
console.log = (msg?: any, ...args: any[]) => {
|
|
62
|
+
logs.push([msg, ...args].filter(Boolean).join(' '));
|
|
63
|
+
};
|
|
64
|
+
await cmd.list({});
|
|
65
|
+
const idsOnly = logs.join('\n');
|
|
66
|
+
expect(idsOnly).toMatch(/\w+/);
|
|
67
|
+
logs.length = 0;
|
|
68
|
+
await cmd.list({ long: true });
|
|
69
|
+
const longOut = logs.join('\n');
|
|
70
|
+
expect(longOut).toMatch(/:\s/);
|
|
71
|
+
expect(longOut).toMatch(/\[deltas\s\d+\]/);
|
|
72
|
+
} finally {
|
|
73
|
+
console.log = origLog;
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
});
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
2
|
+
import { ChangeCommand } from '../../../src/commands/change.js';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { promises as fs } from 'fs';
|
|
5
|
+
import os from 'os';
|
|
6
|
+
|
|
7
|
+
describe('ChangeCommand.show/validate', () => {
|
|
8
|
+
let cmd: ChangeCommand;
|
|
9
|
+
let changeName: string;
|
|
10
|
+
let tempRoot: string;
|
|
11
|
+
let originalCwd: string;
|
|
12
|
+
|
|
13
|
+
beforeAll(async () => {
|
|
14
|
+
cmd = new ChangeCommand();
|
|
15
|
+
originalCwd = process.cwd();
|
|
16
|
+
tempRoot = path.join(os.tmpdir(), `openspec-change-command-${Date.now()}`);
|
|
17
|
+
const changesDir = path.join(tempRoot, 'openspec', 'changes', 'sample-change');
|
|
18
|
+
await fs.mkdir(changesDir, { recursive: true });
|
|
19
|
+
const proposal = `# Change: Sample Change\n\n## Why\nConsistency in tests.\n\n## What Changes\n- **auth:** Add requirement`;
|
|
20
|
+
await fs.writeFile(path.join(changesDir, 'proposal.md'), proposal, 'utf-8');
|
|
21
|
+
process.chdir(tempRoot);
|
|
22
|
+
changeName = 'sample-change';
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
afterAll(async () => {
|
|
26
|
+
process.chdir(originalCwd);
|
|
27
|
+
await fs.rm(tempRoot, { recursive: true, force: true });
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
it('show --json prints JSON including deltas', async () => {
|
|
31
|
+
const logs: string[] = [];
|
|
32
|
+
const origLog = console.log;
|
|
33
|
+
try {
|
|
34
|
+
console.log = (msg?: any, ...args: any[]) => {
|
|
35
|
+
logs.push([msg, ...args].filter(Boolean).join(' '));
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
await cmd.show(changeName, { json: true });
|
|
39
|
+
|
|
40
|
+
const output = logs.join('\n');
|
|
41
|
+
const parsed = JSON.parse(output);
|
|
42
|
+
expect(parsed).toHaveProperty('deltas');
|
|
43
|
+
expect(Array.isArray(parsed.deltas)).toBe(true);
|
|
44
|
+
} finally {
|
|
45
|
+
console.log = origLog;
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
it('error when no change specified: prints available IDs', async () => {
|
|
50
|
+
const logsErr: string[] = [];
|
|
51
|
+
const origErr = console.error;
|
|
52
|
+
try {
|
|
53
|
+
console.error = (msg?: any, ...args: any[]) => {
|
|
54
|
+
logsErr.push([msg, ...args].filter(Boolean).join(' '));
|
|
55
|
+
};
|
|
56
|
+
await cmd.show(undefined as unknown as string, { json: false } as any);
|
|
57
|
+
// Should have set exit code and printed hint
|
|
58
|
+
expect(process.exitCode).toBe(1);
|
|
59
|
+
const errOut = logsErr.join('\n');
|
|
60
|
+
expect(errOut).toMatch(/No change specified/);
|
|
61
|
+
expect(errOut).toMatch(/Available IDs/);
|
|
62
|
+
} finally {
|
|
63
|
+
console.error = origErr;
|
|
64
|
+
process.exitCode = 0;
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it('show --json --requirements-only returns minimal object with deltas (deprecated alias)', async () => {
|
|
69
|
+
const logs: string[] = [];
|
|
70
|
+
const origLog = console.log;
|
|
71
|
+
try {
|
|
72
|
+
console.log = (msg?: any, ...args: any[]) => {
|
|
73
|
+
logs.push([msg, ...args].filter(Boolean).join(' '));
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
await cmd.show(changeName, { json: true, requirementsOnly: true });
|
|
77
|
+
|
|
78
|
+
const output = logs.join('\n');
|
|
79
|
+
const parsed = JSON.parse(output);
|
|
80
|
+
expect(parsed).toHaveProperty('deltas');
|
|
81
|
+
expect(Array.isArray(parsed.deltas)).toBe(true);
|
|
82
|
+
if (parsed.deltas.length > 0) {
|
|
83
|
+
expect(parsed.deltas[0]).toHaveProperty('spec');
|
|
84
|
+
expect(parsed.deltas[0]).toHaveProperty('operation');
|
|
85
|
+
expect(parsed.deltas[0]).toHaveProperty('description');
|
|
86
|
+
}
|
|
87
|
+
} finally {
|
|
88
|
+
console.log = origLog;
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
it('validate --strict --json returns a report with valid boolean', async () => {
|
|
93
|
+
const logs: string[] = [];
|
|
94
|
+
const origLog = console.log;
|
|
95
|
+
try {
|
|
96
|
+
console.log = (msg?: any, ...args: any[]) => {
|
|
97
|
+
logs.push([msg, ...args].filter(Boolean).join(' '));
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
await cmd.validate(changeName, { strict: true, json: true });
|
|
101
|
+
|
|
102
|
+
const output = logs.join('\n');
|
|
103
|
+
const parsed = JSON.parse(output);
|
|
104
|
+
expect(parsed).toHaveProperty('valid');
|
|
105
|
+
expect(parsed).toHaveProperty('issues');
|
|
106
|
+
expect(Array.isArray(parsed.issues)).toBe(true);
|
|
107
|
+
} finally {
|
|
108
|
+
console.log = origLog;
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
});
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
+
import { promises as fs } from 'fs';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { JsonConverter } from '../../../src/core/converters/json-converter.js';
|
|
5
|
+
|
|
6
|
+
describe('JsonConverter', () => {
|
|
7
|
+
const testDir = path.join(process.cwd(), 'test-json-converter-tmp');
|
|
8
|
+
const converter = new JsonConverter();
|
|
9
|
+
|
|
10
|
+
beforeEach(async () => {
|
|
11
|
+
await fs.mkdir(testDir, { recursive: true });
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
afterEach(async () => {
|
|
15
|
+
await fs.rm(testDir, { recursive: true, force: true });
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
describe('convertSpecToJson', () => {
|
|
19
|
+
it('should convert a spec to JSON format', async () => {
|
|
20
|
+
const specContent = `# User Authentication Spec
|
|
21
|
+
|
|
22
|
+
## Purpose
|
|
23
|
+
This specification defines the requirements for user authentication.
|
|
24
|
+
|
|
25
|
+
## Requirements
|
|
26
|
+
|
|
27
|
+
### The system SHALL provide secure user authentication
|
|
28
|
+
Users need to be able to log in securely.
|
|
29
|
+
|
|
30
|
+
#### Scenario: Successful login
|
|
31
|
+
Given a user with valid credentials
|
|
32
|
+
When they submit the login form
|
|
33
|
+
Then they are authenticated`;
|
|
34
|
+
|
|
35
|
+
const specPath = path.join(testDir, 'spec.md');
|
|
36
|
+
await fs.writeFile(specPath, specContent);
|
|
37
|
+
|
|
38
|
+
const json = converter.convertSpecToJson(specPath);
|
|
39
|
+
const parsed = JSON.parse(json);
|
|
40
|
+
|
|
41
|
+
expect(parsed.name).toBe('spec');
|
|
42
|
+
expect(parsed.overview).toContain('user authentication');
|
|
43
|
+
expect(parsed.requirements).toHaveLength(1);
|
|
44
|
+
expect(parsed.requirements[0].scenarios).toHaveLength(1);
|
|
45
|
+
expect(parsed.metadata).toBeDefined();
|
|
46
|
+
expect(parsed.metadata.format).toBe('openspec');
|
|
47
|
+
expect(parsed.metadata.sourcePath).toBe(specPath);
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
it('should extract spec name from directory structure', async () => {
|
|
51
|
+
const specsDir = path.join(testDir, 'specs', 'user-auth');
|
|
52
|
+
await fs.mkdir(specsDir, { recursive: true });
|
|
53
|
+
|
|
54
|
+
const specContent = `# User Auth
|
|
55
|
+
|
|
56
|
+
## Purpose
|
|
57
|
+
Auth spec overview
|
|
58
|
+
|
|
59
|
+
## Requirements
|
|
60
|
+
|
|
61
|
+
### The system SHALL authenticate users
|
|
62
|
+
|
|
63
|
+
#### Scenario: Login
|
|
64
|
+
Given a user
|
|
65
|
+
When they login
|
|
66
|
+
Then authenticated`;
|
|
67
|
+
|
|
68
|
+
const specPath = path.join(specsDir, 'spec.md');
|
|
69
|
+
await fs.writeFile(specPath, specContent);
|
|
70
|
+
|
|
71
|
+
const json = converter.convertSpecToJson(specPath);
|
|
72
|
+
const parsed = JSON.parse(json);
|
|
73
|
+
|
|
74
|
+
expect(parsed.name).toBe('user-auth');
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
describe('convertChangeToJson', () => {
|
|
79
|
+
it('should convert a change to JSON format', async () => {
|
|
80
|
+
const changeContent = `# Add User Authentication
|
|
81
|
+
|
|
82
|
+
## Why
|
|
83
|
+
We need to implement user authentication to secure the application and protect user data from unauthorized access.
|
|
84
|
+
|
|
85
|
+
## What Changes
|
|
86
|
+
- **user-auth:** Add new user authentication specification
|
|
87
|
+
- **api-endpoints:** Modify to include authentication endpoints`;
|
|
88
|
+
|
|
89
|
+
const changePath = path.join(testDir, 'change.md');
|
|
90
|
+
await fs.writeFile(changePath, changeContent);
|
|
91
|
+
|
|
92
|
+
const json = await converter.convertChangeToJson(changePath);
|
|
93
|
+
const parsed = JSON.parse(json);
|
|
94
|
+
|
|
95
|
+
expect(parsed.name).toBe('change');
|
|
96
|
+
expect(parsed.why).toContain('secure the application');
|
|
97
|
+
expect(parsed.deltas).toHaveLength(2);
|
|
98
|
+
expect(parsed.deltas[0].spec).toBe('user-auth');
|
|
99
|
+
expect(parsed.deltas[0].operation).toBe('ADDED');
|
|
100
|
+
expect(parsed.metadata).toBeDefined();
|
|
101
|
+
expect(parsed.metadata.format).toBe('openspec-change');
|
|
102
|
+
expect(parsed.metadata.sourcePath).toBe(changePath);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it('should extract change name from directory structure', async () => {
|
|
106
|
+
const changesDir = path.join(testDir, 'changes', 'add-auth');
|
|
107
|
+
await fs.mkdir(changesDir, { recursive: true });
|
|
108
|
+
|
|
109
|
+
const changeContent = `# Add Auth
|
|
110
|
+
|
|
111
|
+
## Why
|
|
112
|
+
We need authentication for security reasons and to protect user data properly.
|
|
113
|
+
|
|
114
|
+
## What Changes
|
|
115
|
+
- **auth:** Add authentication`;
|
|
116
|
+
|
|
117
|
+
const changePath = path.join(changesDir, 'proposal.md');
|
|
118
|
+
await fs.writeFile(changePath, changeContent);
|
|
119
|
+
|
|
120
|
+
const json = await converter.convertChangeToJson(changePath);
|
|
121
|
+
const parsed = JSON.parse(json);
|
|
122
|
+
|
|
123
|
+
expect(parsed.name).toBe('add-auth');
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
describe('JSON formatting', () => {
|
|
128
|
+
it('should produce properly formatted JSON with indentation', async () => {
|
|
129
|
+
const specContent = `# Test
|
|
130
|
+
|
|
131
|
+
## Purpose
|
|
132
|
+
Test overview
|
|
133
|
+
|
|
134
|
+
## Requirements
|
|
135
|
+
|
|
136
|
+
### The system SHALL test
|
|
137
|
+
|
|
138
|
+
#### Scenario: Test
|
|
139
|
+
Given test
|
|
140
|
+
When action
|
|
141
|
+
Then result`;
|
|
142
|
+
|
|
143
|
+
const specPath = path.join(testDir, 'spec.md');
|
|
144
|
+
await fs.writeFile(specPath, specContent);
|
|
145
|
+
|
|
146
|
+
const json = converter.convertSpecToJson(specPath);
|
|
147
|
+
|
|
148
|
+
// Check for proper indentation (2 spaces)
|
|
149
|
+
expect(json).toContain(' "name"');
|
|
150
|
+
expect(json).toContain(' "overview"');
|
|
151
|
+
expect(json).toContain(' "requirements"');
|
|
152
|
+
|
|
153
|
+
// Check it's valid JSON
|
|
154
|
+
expect(() => JSON.parse(json)).not.toThrow();
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
it('should handle special characters in content', async () => {
|
|
158
|
+
const specContent = `# Test
|
|
159
|
+
|
|
160
|
+
## Purpose
|
|
161
|
+
This has "quotes" and \\ backslashes and
|
|
162
|
+
newlines
|
|
163
|
+
|
|
164
|
+
## Requirements
|
|
165
|
+
|
|
166
|
+
### The system SHALL handle "special" characters
|
|
167
|
+
|
|
168
|
+
#### Scenario: Special chars
|
|
169
|
+
Given a string with "quotes"
|
|
170
|
+
When processing \\ backslash
|
|
171
|
+
Then handle correctly`;
|
|
172
|
+
|
|
173
|
+
const specPath = path.join(testDir, 'spec.md');
|
|
174
|
+
await fs.writeFile(specPath, specContent);
|
|
175
|
+
|
|
176
|
+
const json = converter.convertSpecToJson(specPath);
|
|
177
|
+
const parsed = JSON.parse(json);
|
|
178
|
+
|
|
179
|
+
expect(parsed.overview).toContain('"quotes"');
|
|
180
|
+
expect(parsed.overview).toContain('\\');
|
|
181
|
+
expect(parsed.requirements[0].text).toContain('"special"');
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
});
|