prose-qa 0.1.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/LICENSE +21 -0
- package/README.md +570 -0
- package/dist/agent/bash.d.ts +52 -0
- package/dist/agent/bash.d.ts.map +1 -0
- package/dist/agent/bash.js +186 -0
- package/dist/agent/bash.js.map +1 -0
- package/dist/agent/bash.test.d.ts +2 -0
- package/dist/agent/bash.test.d.ts.map +1 -0
- package/dist/agent/bash.test.js +70 -0
- package/dist/agent/bash.test.js.map +1 -0
- package/dist/agent/llm-model.d.ts +5 -0
- package/dist/agent/llm-model.d.ts.map +1 -0
- package/dist/agent/llm-model.js +29 -0
- package/dist/agent/llm-model.js.map +1 -0
- package/dist/agent/llm-model.test.d.ts +2 -0
- package/dist/agent/llm-model.test.d.ts.map +1 -0
- package/dist/agent/llm-model.test.js +28 -0
- package/dist/agent/llm-model.test.js.map +1 -0
- package/dist/agent/prompt.d.ts +17 -0
- package/dist/agent/prompt.d.ts.map +1 -0
- package/dist/agent/prompt.js +97 -0
- package/dist/agent/prompt.js.map +1 -0
- package/dist/agent/prompt.test.d.ts +2 -0
- package/dist/agent/prompt.test.d.ts.map +1 -0
- package/dist/agent/prompt.test.js +124 -0
- package/dist/agent/prompt.test.js.map +1 -0
- package/dist/agent/provider-options.d.ts +8 -0
- package/dist/agent/provider-options.d.ts.map +1 -0
- package/dist/agent/provider-options.js +115 -0
- package/dist/agent/provider-options.js.map +1 -0
- package/dist/agent/provider-options.test.d.ts +2 -0
- package/dist/agent/provider-options.test.d.ts.map +1 -0
- package/dist/agent/provider-options.test.js +114 -0
- package/dist/agent/provider-options.test.js.map +1 -0
- package/dist/agent/runner.d.ts +27 -0
- package/dist/agent/runner.d.ts.map +1 -0
- package/dist/agent/runner.js +291 -0
- package/dist/agent/runner.js.map +1 -0
- package/dist/agent/verdict-retry-prompt.d.ts +3 -0
- package/dist/agent/verdict-retry-prompt.d.ts.map +1 -0
- package/dist/agent/verdict-retry-prompt.js +18 -0
- package/dist/agent/verdict-retry-prompt.js.map +1 -0
- package/dist/agent/verdict-retry-prompt.test.d.ts +2 -0
- package/dist/agent/verdict-retry-prompt.test.d.ts.map +1 -0
- package/dist/agent/verdict-retry-prompt.test.js +25 -0
- package/dist/agent/verdict-retry-prompt.test.js.map +1 -0
- package/dist/agent/verdict.d.ts +31 -0
- package/dist/agent/verdict.d.ts.map +1 -0
- package/dist/agent/verdict.js +123 -0
- package/dist/agent/verdict.js.map +1 -0
- package/dist/agent/verdict.test.d.ts +2 -0
- package/dist/agent/verdict.test.d.ts.map +1 -0
- package/dist/agent/verdict.test.js +156 -0
- package/dist/agent/verdict.test.js.map +1 -0
- package/dist/analyze/build-context.d.ts +58 -0
- package/dist/analyze/build-context.d.ts.map +1 -0
- package/dist/analyze/build-context.js +141 -0
- package/dist/analyze/build-context.js.map +1 -0
- package/dist/analyze/build-context.test.d.ts +2 -0
- package/dist/analyze/build-context.test.d.ts.map +1 -0
- package/dist/analyze/build-context.test.js +118 -0
- package/dist/analyze/build-context.test.js.map +1 -0
- package/dist/analyze/compare-runs.d.ts +49 -0
- package/dist/analyze/compare-runs.d.ts.map +1 -0
- package/dist/analyze/compare-runs.js +214 -0
- package/dist/analyze/compare-runs.js.map +1 -0
- package/dist/analyze/compare-runs.test.d.ts +2 -0
- package/dist/analyze/compare-runs.test.d.ts.map +1 -0
- package/dist/analyze/compare-runs.test.js +139 -0
- package/dist/analyze/compare-runs.test.js.map +1 -0
- package/dist/analyze/diff-hunks.d.ts +16 -0
- package/dist/analyze/diff-hunks.d.ts.map +1 -0
- package/dist/analyze/diff-hunks.js +287 -0
- package/dist/analyze/diff-hunks.js.map +1 -0
- package/dist/analyze/diff-hunks.test.d.ts +2 -0
- package/dist/analyze/diff-hunks.test.d.ts.map +1 -0
- package/dist/analyze/diff-hunks.test.js +54 -0
- package/dist/analyze/diff-hunks.test.js.map +1 -0
- package/dist/analyze/hunk-editor.d.ts +8 -0
- package/dist/analyze/hunk-editor.d.ts.map +1 -0
- package/dist/analyze/hunk-editor.js +129 -0
- package/dist/analyze/hunk-editor.js.map +1 -0
- package/dist/analyze/hunk-editor.test.d.ts +2 -0
- package/dist/analyze/hunk-editor.test.d.ts.map +1 -0
- package/dist/analyze/hunk-editor.test.js +48 -0
- package/dist/analyze/hunk-editor.test.js.map +1 -0
- package/dist/analyze/index.d.ts +23 -0
- package/dist/analyze/index.d.ts.map +1 -0
- package/dist/analyze/index.js +122 -0
- package/dist/analyze/index.js.map +1 -0
- package/dist/analyze/llm-fix.d.ts +11 -0
- package/dist/analyze/llm-fix.d.ts.map +1 -0
- package/dist/analyze/llm-fix.js +76 -0
- package/dist/analyze/llm-fix.js.map +1 -0
- package/dist/analyze/parse-proposal.d.ts +41 -0
- package/dist/analyze/parse-proposal.d.ts.map +1 -0
- package/dist/analyze/parse-proposal.js +53 -0
- package/dist/analyze/parse-proposal.js.map +1 -0
- package/dist/analyze/parse-proposal.test.d.ts +2 -0
- package/dist/analyze/parse-proposal.test.d.ts.map +1 -0
- package/dist/analyze/parse-proposal.test.js +40 -0
- package/dist/analyze/parse-proposal.test.js.map +1 -0
- package/dist/analyze/repl.d.ts +28 -0
- package/dist/analyze/repl.d.ts.map +1 -0
- package/dist/analyze/repl.js +284 -0
- package/dist/analyze/repl.js.map +1 -0
- package/dist/analyze/repl.test.d.ts +2 -0
- package/dist/analyze/repl.test.d.ts.map +1 -0
- package/dist/analyze/repl.test.js +101 -0
- package/dist/analyze/repl.test.js.map +1 -0
- package/dist/analyze/suggest.d.ts +5 -0
- package/dist/analyze/suggest.d.ts.map +1 -0
- package/dist/analyze/suggest.js +75 -0
- package/dist/analyze/suggest.js.map +1 -0
- package/dist/analyze/suggest.test.d.ts +2 -0
- package/dist/analyze/suggest.test.d.ts.map +1 -0
- package/dist/analyze/suggest.test.js +53 -0
- package/dist/analyze/suggest.test.js.map +1 -0
- package/dist/analyze/validate-markdown.d.ts +3 -0
- package/dist/analyze/validate-markdown.d.ts.map +1 -0
- package/dist/analyze/validate-markdown.js +25 -0
- package/dist/analyze/validate-markdown.js.map +1 -0
- package/dist/artifacts/policy.d.ts +9 -0
- package/dist/artifacts/policy.d.ts.map +1 -0
- package/dist/artifacts/policy.js +46 -0
- package/dist/artifacts/policy.js.map +1 -0
- package/dist/artifacts/policy.test.d.ts +2 -0
- package/dist/artifacts/policy.test.d.ts.map +1 -0
- package/dist/artifacts/policy.test.js +73 -0
- package/dist/artifacts/policy.test.js.map +1 -0
- package/dist/auth/resolve.d.ts +22 -0
- package/dist/auth/resolve.d.ts.map +1 -0
- package/dist/auth/resolve.js +148 -0
- package/dist/auth/resolve.js.map +1 -0
- package/dist/auth/store.d.ts +23 -0
- package/dist/auth/store.d.ts.map +1 -0
- package/dist/auth/store.js +103 -0
- package/dist/auth/store.js.map +1 -0
- package/dist/cache/generate.d.ts +8 -0
- package/dist/cache/generate.d.ts.map +1 -0
- package/dist/cache/generate.js +61 -0
- package/dist/cache/generate.js.map +1 -0
- package/dist/cache/hash.d.ts +5 -0
- package/dist/cache/hash.d.ts.map +1 -0
- package/dist/cache/hash.js +21 -0
- package/dist/cache/hash.js.map +1 -0
- package/dist/cache/hash.test.d.ts +2 -0
- package/dist/cache/hash.test.d.ts.map +1 -0
- package/dist/cache/hash.test.js +42 -0
- package/dist/cache/hash.test.js.map +1 -0
- package/dist/cache/resolve.d.ts +5 -0
- package/dist/cache/resolve.d.ts.map +1 -0
- package/dist/cache/resolve.js +8 -0
- package/dist/cache/resolve.js.map +1 -0
- package/dist/cache/store.d.ts +20 -0
- package/dist/cache/store.d.ts.map +1 -0
- package/dist/cache/store.js +90 -0
- package/dist/cache/store.js.map +1 -0
- package/dist/cache/store.test.d.ts +2 -0
- package/dist/cache/store.test.d.ts.map +1 -0
- package/dist/cache/store.test.js +101 -0
- package/dist/cache/store.test.js.map +1 -0
- package/dist/cli/analyze.d.ts +21 -0
- package/dist/cli/analyze.d.ts.map +1 -0
- package/dist/cli/analyze.js +148 -0
- package/dist/cli/analyze.js.map +1 -0
- package/dist/cli/concurrency.d.ts +17 -0
- package/dist/cli/concurrency.d.ts.map +1 -0
- package/dist/cli/concurrency.js +56 -0
- package/dist/cli/concurrency.js.map +1 -0
- package/dist/cli/concurrency.test.d.ts +2 -0
- package/dist/cli/concurrency.test.d.ts.map +1 -0
- package/dist/cli/concurrency.test.js +74 -0
- package/dist/cli/concurrency.test.js.map +1 -0
- package/dist/cli/config.d.ts +2 -0
- package/dist/cli/config.d.ts.map +1 -0
- package/dist/cli/config.js +14 -0
- package/dist/cli/config.js.map +1 -0
- package/dist/cli/help.d.ts +23 -0
- package/dist/cli/help.d.ts.map +1 -0
- package/dist/cli/help.js +458 -0
- package/dist/cli/help.js.map +1 -0
- package/dist/cli/help.test.d.ts +2 -0
- package/dist/cli/help.test.d.ts.map +1 -0
- package/dist/cli/help.test.js +41 -0
- package/dist/cli/help.test.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +300 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/mcp.d.ts +6 -0
- package/dist/cli/mcp.d.ts.map +1 -0
- package/dist/cli/mcp.js +17 -0
- package/dist/cli/mcp.js.map +1 -0
- package/dist/cli/record.d.ts +27 -0
- package/dist/cli/record.d.ts.map +1 -0
- package/dist/cli/record.js +244 -0
- package/dist/cli/record.js.map +1 -0
- package/dist/cli/run.d.ts +11 -0
- package/dist/cli/run.d.ts.map +1 -0
- package/dist/cli/run.js +676 -0
- package/dist/cli/run.js.map +1 -0
- package/dist/cli/subprocess.d.ts +19 -0
- package/dist/cli/subprocess.d.ts.map +1 -0
- package/dist/cli/subprocess.js +142 -0
- package/dist/cli/subprocess.js.map +1 -0
- package/dist/cli/subprocess.test.d.ts +2 -0
- package/dist/cli/subprocess.test.d.ts.map +1 -0
- package/dist/cli/subprocess.test.js +76 -0
- package/dist/cli/subprocess.test.js.map +1 -0
- package/dist/cli/tags.d.ts +5 -0
- package/dist/cli/tags.d.ts.map +1 -0
- package/dist/cli/tags.js +33 -0
- package/dist/cli/tags.js.map +1 -0
- package/dist/cli/tags.test.d.ts +2 -0
- package/dist/cli/tags.test.d.ts.map +1 -0
- package/dist/cli/tags.test.js +31 -0
- package/dist/cli/tags.test.js.map +1 -0
- package/dist/config/env-vars.d.ts +2 -0
- package/dist/config/env-vars.d.ts.map +1 -0
- package/dist/config/env-vars.js +14 -0
- package/dist/config/env-vars.js.map +1 -0
- package/dist/config/env.d.ts +2 -0
- package/dist/config/env.d.ts.map +1 -0
- package/dist/config/env.js +9 -0
- package/dist/config/env.js.map +1 -0
- package/dist/config/lightpanda.d.ts +6 -0
- package/dist/config/lightpanda.d.ts.map +1 -0
- package/dist/config/lightpanda.js +38 -0
- package/dist/config/lightpanda.js.map +1 -0
- package/dist/config/lightpanda.test.d.ts +2 -0
- package/dist/config/lightpanda.test.d.ts.map +1 -0
- package/dist/config/lightpanda.test.js +46 -0
- package/dist/config/lightpanda.test.js.map +1 -0
- package/dist/config/load.d.ts +22 -0
- package/dist/config/load.d.ts.map +1 -0
- package/dist/config/load.js +242 -0
- package/dist/config/load.js.map +1 -0
- package/dist/config/load.test.d.ts +2 -0
- package/dist/config/load.test.d.ts.map +1 -0
- package/dist/config/load.test.js +86 -0
- package/dist/config/load.test.js.map +1 -0
- package/dist/config/set.d.ts +8 -0
- package/dist/config/set.d.ts.map +1 -0
- package/dist/config/set.js +93 -0
- package/dist/config/set.js.map +1 -0
- package/dist/config/set.test.d.ts +2 -0
- package/dist/config/set.test.d.ts.map +1 -0
- package/dist/config/set.test.js +98 -0
- package/dist/config/set.test.js.map +1 -0
- package/dist/healing/classify.d.ts +15 -0
- package/dist/healing/classify.d.ts.map +1 -0
- package/dist/healing/classify.js +209 -0
- package/dist/healing/classify.js.map +1 -0
- package/dist/healing/classify.test.d.ts +2 -0
- package/dist/healing/classify.test.d.ts.map +1 -0
- package/dist/healing/classify.test.js +167 -0
- package/dist/healing/classify.test.js.map +1 -0
- package/dist/healing/recovery-prompt.d.ts +3 -0
- package/dist/healing/recovery-prompt.d.ts.map +1 -0
- package/dist/healing/recovery-prompt.js +22 -0
- package/dist/healing/recovery-prompt.js.map +1 -0
- package/dist/mcp/inline-scenario.d.ts +13 -0
- package/dist/mcp/inline-scenario.d.ts.map +1 -0
- package/dist/mcp/inline-scenario.js +23 -0
- package/dist/mcp/inline-scenario.js.map +1 -0
- package/dist/mcp/server.d.ts +4 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +186 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/skill.d.ts +5 -0
- package/dist/mcp/skill.d.ts.map +1 -0
- package/dist/mcp/skill.js +38 -0
- package/dist/mcp/skill.js.map +1 -0
- package/dist/mcp/skill.test.d.ts +2 -0
- package/dist/mcp/skill.test.d.ts.map +1 -0
- package/dist/mcp/skill.test.js +18 -0
- package/dist/mcp/skill.test.js.map +1 -0
- package/dist/paths.d.ts +12 -0
- package/dist/paths.d.ts.map +1 -0
- package/dist/paths.js +61 -0
- package/dist/paths.js.map +1 -0
- package/dist/prompt/load.d.ts +4 -0
- package/dist/prompt/load.d.ts.map +1 -0
- package/dist/prompt/load.js +19 -0
- package/dist/prompt/load.js.map +1 -0
- package/dist/recorder/bridge-process.d.ts +14 -0
- package/dist/recorder/bridge-process.d.ts.map +1 -0
- package/dist/recorder/bridge-process.js +133 -0
- package/dist/recorder/bridge-process.js.map +1 -0
- package/dist/recorder/bridge-process.test.d.ts +2 -0
- package/dist/recorder/bridge-process.test.d.ts.map +1 -0
- package/dist/recorder/bridge-process.test.js +36 -0
- package/dist/recorder/bridge-process.test.js.map +1 -0
- package/dist/recorder/bridge-worker.d.ts +2 -0
- package/dist/recorder/bridge-worker.d.ts.map +1 -0
- package/dist/recorder/bridge-worker.js +76 -0
- package/dist/recorder/bridge-worker.js.map +1 -0
- package/dist/recorder/bridge.d.ts +12 -0
- package/dist/recorder/bridge.d.ts.map +1 -0
- package/dist/recorder/bridge.js +61 -0
- package/dist/recorder/bridge.js.map +1 -0
- package/dist/recorder/bridge.test.d.ts +2 -0
- package/dist/recorder/bridge.test.d.ts.map +1 -0
- package/dist/recorder/bridge.test.js +21 -0
- package/dist/recorder/bridge.test.js.map +1 -0
- package/dist/recorder/enrich-event.d.ts +31 -0
- package/dist/recorder/enrich-event.d.ts.map +1 -0
- package/dist/recorder/enrich-event.js +91 -0
- package/dist/recorder/enrich-event.js.map +1 -0
- package/dist/recorder/events.d.ts +11 -0
- package/dist/recorder/events.d.ts.map +1 -0
- package/dist/recorder/events.js +42 -0
- package/dist/recorder/events.js.map +1 -0
- package/dist/recorder/events.test.d.ts +2 -0
- package/dist/recorder/events.test.d.ts.map +1 -0
- package/dist/recorder/events.test.js +40 -0
- package/dist/recorder/events.test.js.map +1 -0
- package/dist/recorder/generate-scenario.d.ts +16 -0
- package/dist/recorder/generate-scenario.d.ts.map +1 -0
- package/dist/recorder/generate-scenario.js +78 -0
- package/dist/recorder/generate-scenario.js.map +1 -0
- package/dist/recorder/in-page-helpers.d.ts +6 -0
- package/dist/recorder/in-page-helpers.d.ts.map +1 -0
- package/dist/recorder/in-page-helpers.js +238 -0
- package/dist/recorder/in-page-helpers.js.map +1 -0
- package/dist/recorder/in-page-helpers.test.d.ts +2 -0
- package/dist/recorder/in-page-helpers.test.d.ts.map +1 -0
- package/dist/recorder/in-page-helpers.test.js +186 -0
- package/dist/recorder/in-page-helpers.test.js.map +1 -0
- package/dist/recorder/page-script.d.ts +7 -0
- package/dist/recorder/page-script.d.ts.map +1 -0
- package/dist/recorder/page-script.js +132 -0
- package/dist/recorder/page-script.js.map +1 -0
- package/dist/recorder/redact.d.ts +8 -0
- package/dist/recorder/redact.d.ts.map +1 -0
- package/dist/recorder/redact.js +26 -0
- package/dist/recorder/redact.js.map +1 -0
- package/dist/recorder/redact.test.d.ts +2 -0
- package/dist/recorder/redact.test.d.ts.map +1 -0
- package/dist/recorder/redact.test.js +27 -0
- package/dist/recorder/redact.test.js.map +1 -0
- package/dist/recorder/session.d.ts +8 -0
- package/dist/recorder/session.d.ts.map +1 -0
- package/dist/recorder/session.js +28 -0
- package/dist/recorder/session.js.map +1 -0
- package/dist/recorder/snapshot-match.d.ts +22 -0
- package/dist/recorder/snapshot-match.d.ts.map +1 -0
- package/dist/recorder/snapshot-match.js +102 -0
- package/dist/recorder/snapshot-match.js.map +1 -0
- package/dist/recorder/snapshot-match.test.d.ts +2 -0
- package/dist/recorder/snapshot-match.test.d.ts.map +1 -0
- package/dist/recorder/snapshot-match.test.js +34 -0
- package/dist/recorder/snapshot-match.test.js.map +1 -0
- package/dist/redact/env-secrets.d.ts +14 -0
- package/dist/redact/env-secrets.d.ts.map +1 -0
- package/dist/redact/env-secrets.js +86 -0
- package/dist/redact/env-secrets.js.map +1 -0
- package/dist/redact/env-secrets.test.d.ts +2 -0
- package/dist/redact/env-secrets.test.d.ts.map +1 -0
- package/dist/redact/env-secrets.test.js +103 -0
- package/dist/redact/env-secrets.test.js.map +1 -0
- package/dist/reporter/export.d.ts +14 -0
- package/dist/reporter/export.d.ts.map +1 -0
- package/dist/reporter/export.js +53 -0
- package/dist/reporter/export.js.map +1 -0
- package/dist/reporter/export.test.d.ts +2 -0
- package/dist/reporter/export.test.d.ts.map +1 -0
- package/dist/reporter/export.test.js +100 -0
- package/dist/reporter/export.test.js.map +1 -0
- package/dist/reporter/index.d.ts +11 -0
- package/dist/reporter/index.d.ts.map +1 -0
- package/dist/reporter/index.js +161 -0
- package/dist/reporter/index.js.map +1 -0
- package/dist/reporter/index.test.d.ts +2 -0
- package/dist/reporter/index.test.d.ts.map +1 -0
- package/dist/reporter/index.test.js +61 -0
- package/dist/reporter/index.test.js.map +1 -0
- package/dist/scenarios/globs.d.ts +15 -0
- package/dist/scenarios/globs.d.ts.map +1 -0
- package/dist/scenarios/globs.js +48 -0
- package/dist/scenarios/globs.js.map +1 -0
- package/dist/scenarios/globs.test.d.ts +2 -0
- package/dist/scenarios/globs.test.d.ts.map +1 -0
- package/dist/scenarios/globs.test.js +53 -0
- package/dist/scenarios/globs.test.js.map +1 -0
- package/dist/scenarios/parser.d.ts +15 -0
- package/dist/scenarios/parser.d.ts.map +1 -0
- package/dist/scenarios/parser.js +278 -0
- package/dist/scenarios/parser.js.map +1 -0
- package/dist/scenarios/parser.test.d.ts +2 -0
- package/dist/scenarios/parser.test.d.ts.map +1 -0
- package/dist/scenarios/parser.test.js +373 -0
- package/dist/scenarios/parser.test.js.map +1 -0
- package/dist/skills/loader.d.ts +10 -0
- package/dist/skills/loader.d.ts.map +1 -0
- package/dist/skills/loader.js +98 -0
- package/dist/skills/loader.js.map +1 -0
- package/dist/types/config.d.ts +131 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/recorder.d.ts +71 -0
- package/dist/types/recorder.d.ts.map +1 -0
- package/dist/types/recorder.js +2 -0
- package/dist/types/recorder.js.map +1 -0
- package/dist/types/scenario.d.ts +41 -0
- package/dist/types/scenario.d.ts.map +1 -0
- package/dist/types/scenario.js +2 -0
- package/dist/types/scenario.js.map +1 -0
- package/dist/types/skill.d.ts +20 -0
- package/dist/types/skill.d.ts.map +1 -0
- package/dist/types/skill.js +13 -0
- package/dist/types/skill.js.map +1 -0
- package/dist/types/verdict.d.ts +82 -0
- package/dist/types/verdict.d.ts.map +1 -0
- package/dist/types/verdict.js +13 -0
- package/dist/types/verdict.js.map +1 -0
- package/package.json +75 -0
- package/pqa.config.ts +82 -0
- package/prompt/ANALYZE-FLAKY.md +62 -0
- package/prompt/ANALYZE.md +110 -0
- package/prompt/CACHE-HINTS.md +49 -0
- package/prompt/RECORD.md +114 -0
- package/prompt/SYSTEM.md +118 -0
- package/skills/agent-browser/SKILL.md +2438 -0
- package/skills/create-pqa-scenario/SKILL.md +273 -0
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
import { createInterface } from "node:readline/promises";
|
|
2
|
+
import { stdin as input, stdout as output } from "node:process";
|
|
3
|
+
import { readFileSync, writeFileSync } from "node:fs";
|
|
4
|
+
import path from "node:path";
|
|
5
|
+
import chalk from "chalk";
|
|
6
|
+
import { canSplitHunk, computeDiffHunks, formatHunkBody, formatHunkHeader, splitHunk, } from "./diff-hunks.js";
|
|
7
|
+
import { applyHunkList, editHunkInEditor, hunkMatchesAt, } from "./hunk-editor.js";
|
|
8
|
+
import { normalizeScenarioMarkdown, validateScenarioMarkdown, } from "./validate-markdown.js";
|
|
9
|
+
const PATCH_HELP = `y — apply this hunk
|
|
10
|
+
n — skip this hunk
|
|
11
|
+
e — edit this hunk in $EDITOR (save & close to apply if valid)
|
|
12
|
+
s — split this hunk into smaller hunks (when possible)
|
|
13
|
+
q — quit; unreviewed hunks are not applied
|
|
14
|
+
? — show this help`;
|
|
15
|
+
export async function waitForAnyKey(message, waitForKey) {
|
|
16
|
+
if (waitForKey) {
|
|
17
|
+
await waitForKey(message);
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
process.stdout.write(message);
|
|
21
|
+
if (!process.stdin.isTTY) {
|
|
22
|
+
await new Promise((resolve) => {
|
|
23
|
+
process.stdin.once("end", resolve);
|
|
24
|
+
process.stdin.once("data", resolve);
|
|
25
|
+
});
|
|
26
|
+
process.stdout.write("\n");
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
process.stdin.setRawMode(true);
|
|
30
|
+
process.stdin.resume();
|
|
31
|
+
await new Promise((resolve) => {
|
|
32
|
+
process.stdin.once("data", () => resolve());
|
|
33
|
+
});
|
|
34
|
+
process.stdin.setRawMode(false);
|
|
35
|
+
process.stdin.pause();
|
|
36
|
+
process.stdout.write("\n");
|
|
37
|
+
}
|
|
38
|
+
export function formatHunkDisplay(hunk, index, total, filePath) {
|
|
39
|
+
const header = formatHunkHeader(hunk, index, total, filePath);
|
|
40
|
+
const body = formatHunkBody(hunk)
|
|
41
|
+
.split("\n")
|
|
42
|
+
.map((line) => {
|
|
43
|
+
if (line.startsWith("+"))
|
|
44
|
+
return chalk.green(line);
|
|
45
|
+
if (line.startsWith("-"))
|
|
46
|
+
return chalk.red(line);
|
|
47
|
+
return chalk.dim(line);
|
|
48
|
+
})
|
|
49
|
+
.join("\n");
|
|
50
|
+
return `${chalk.bold(header)}\n${body}`;
|
|
51
|
+
}
|
|
52
|
+
async function reviewFileHunks(options) {
|
|
53
|
+
const pending = [...options.hunks];
|
|
54
|
+
const accepted = [];
|
|
55
|
+
const fileLines = options.before.split("\n");
|
|
56
|
+
let offset = 0;
|
|
57
|
+
const recomputeOffset = () => {
|
|
58
|
+
offset = 0;
|
|
59
|
+
for (const hunk of accepted) {
|
|
60
|
+
offset += hunk.added.length - hunk.removed.length;
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
while (pending.length > 0) {
|
|
64
|
+
const hunk = pending.shift();
|
|
65
|
+
const total = pending.length + accepted.length + 1;
|
|
66
|
+
const index = accepted.length;
|
|
67
|
+
console.log("");
|
|
68
|
+
console.log(formatHunkDisplay(hunk, index, total, options.relPath));
|
|
69
|
+
while (true) {
|
|
70
|
+
const answer = (await options.ask(chalk.bold("Stage this hunk [y/n/e/s/q/?]? "))).toLowerCase();
|
|
71
|
+
if (answer === "?" || answer === "h") {
|
|
72
|
+
console.log(PATCH_HELP);
|
|
73
|
+
await waitForAnyKey(chalk.dim("\nPress any key to continue… "), options.waitForKey);
|
|
74
|
+
continue;
|
|
75
|
+
}
|
|
76
|
+
if (answer === "q" || answer === "quit") {
|
|
77
|
+
return { accepted, quit: true };
|
|
78
|
+
}
|
|
79
|
+
if (answer === "s" || answer === "split") {
|
|
80
|
+
if (!canSplitHunk(hunk)) {
|
|
81
|
+
console.log(chalk.yellow("Hunk cannot be split further."));
|
|
82
|
+
continue;
|
|
83
|
+
}
|
|
84
|
+
const parts = splitHunk(hunk);
|
|
85
|
+
if (!parts) {
|
|
86
|
+
console.log(chalk.yellow("Hunk cannot be split further."));
|
|
87
|
+
continue;
|
|
88
|
+
}
|
|
89
|
+
pending.unshift(parts[1]);
|
|
90
|
+
pending.unshift(parts[0]);
|
|
91
|
+
break;
|
|
92
|
+
}
|
|
93
|
+
if (answer === "e" || answer === "edit") {
|
|
94
|
+
const edited = options.editHunk(hunk, options.relPath);
|
|
95
|
+
if (!edited) {
|
|
96
|
+
console.log(chalk.dim("Edit cancelled or editor failed."));
|
|
97
|
+
continue;
|
|
98
|
+
}
|
|
99
|
+
recomputeOffset();
|
|
100
|
+
if (!hunkMatchesAt(fileLines, edited, offset)) {
|
|
101
|
+
console.log(chalk.red("Edited hunk does not apply cleanly to the file — try again."));
|
|
102
|
+
continue;
|
|
103
|
+
}
|
|
104
|
+
accepted.push(edited);
|
|
105
|
+
break;
|
|
106
|
+
}
|
|
107
|
+
if (answer === "y" || answer === "yes") {
|
|
108
|
+
recomputeOffset();
|
|
109
|
+
if (!hunkMatchesAt(fileLines, hunk, offset)) {
|
|
110
|
+
console.log(chalk.red("Hunk no longer applies cleanly to the file."));
|
|
111
|
+
break;
|
|
112
|
+
}
|
|
113
|
+
accepted.push(hunk);
|
|
114
|
+
break;
|
|
115
|
+
}
|
|
116
|
+
if (answer === "n" || answer === "no" || answer === "") {
|
|
117
|
+
break;
|
|
118
|
+
}
|
|
119
|
+
console.log(chalk.dim("Unknown option. Type ? for help."));
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
return { accepted, quit: false };
|
|
123
|
+
}
|
|
124
|
+
export async function runAnalyzeRepl(options) {
|
|
125
|
+
const appliedFiles = [];
|
|
126
|
+
let quit = false;
|
|
127
|
+
const editHunk = options.editHunk ?? editHunkInEditor;
|
|
128
|
+
console.log("");
|
|
129
|
+
console.log(chalk.bold("Heuristic analysis"));
|
|
130
|
+
if (options.flakyReport) {
|
|
131
|
+
console.log(formatFlakySummary(options.flakyReport));
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
console.log(formatHeuristicSummary(options.heuristicReport));
|
|
135
|
+
}
|
|
136
|
+
await waitForAnyKey(chalk.dim("\nPress any key to continue to LLM proposals… "), options.waitForKey);
|
|
137
|
+
if (options.llmEntries.length === 0) {
|
|
138
|
+
console.log(chalk.green("\nNo failed scenarios — nothing to review."));
|
|
139
|
+
return { appliedFiles, quit: false };
|
|
140
|
+
}
|
|
141
|
+
const rl = options.ask ? undefined : createInterface({ input, output });
|
|
142
|
+
const ask = options.ask ?? ((prompt) => rl.question(prompt).then((a) => a.trim()));
|
|
143
|
+
try {
|
|
144
|
+
for (const entry of options.llmEntries) {
|
|
145
|
+
if (quit)
|
|
146
|
+
break;
|
|
147
|
+
console.log("");
|
|
148
|
+
console.log(chalk.bold.cyan(`Scenario: ${entry.finding.scenario}`));
|
|
149
|
+
console.log(chalk.dim(entry.finding.filePath));
|
|
150
|
+
if (!entry.proposal) {
|
|
151
|
+
console.log(chalk.red(`LLM analysis failed: ${entry.parseError ?? "unknown error"}`));
|
|
152
|
+
await waitForAnyKey(chalk.dim("Press any key to continue… "), options.waitForKey);
|
|
153
|
+
continue;
|
|
154
|
+
}
|
|
155
|
+
console.log("");
|
|
156
|
+
if (entry.proposal.flakeDiagnosis) {
|
|
157
|
+
const d = entry.proposal.flakeDiagnosis;
|
|
158
|
+
console.log(chalk.magenta(`Flake diagnosis: ${d.type} [${d.confidence}] — ${d.explanation}`));
|
|
159
|
+
console.log("");
|
|
160
|
+
}
|
|
161
|
+
console.log(entry.proposal.rationale);
|
|
162
|
+
if (!entry.proposal.shouldEditScenario ||
|
|
163
|
+
!entry.proposal.revisedMarkdown) {
|
|
164
|
+
console.log(chalk.yellow("\nNo scenario edit proposed."));
|
|
165
|
+
await waitForAnyKey(chalk.dim("Press any key to continue… "), options.waitForKey);
|
|
166
|
+
continue;
|
|
167
|
+
}
|
|
168
|
+
const resolved = path.isAbsolute(entry.finding.filePath)
|
|
169
|
+
? entry.finding.filePath
|
|
170
|
+
: path.resolve(options.cwd, entry.finding.filePath);
|
|
171
|
+
const before = readFileSync(resolved, "utf-8");
|
|
172
|
+
const after = normalizeScenarioMarkdown(entry.proposal.revisedMarkdown);
|
|
173
|
+
const hunks = computeDiffHunks(before, after);
|
|
174
|
+
const relPath = path.relative(options.cwd, resolved);
|
|
175
|
+
if (hunks.length === 0) {
|
|
176
|
+
console.log(chalk.dim("\nNo diff hunks — skipping file."));
|
|
177
|
+
await waitForAnyKey(chalk.dim("Press any key to continue… "), options.waitForKey);
|
|
178
|
+
continue;
|
|
179
|
+
}
|
|
180
|
+
const review = await reviewFileHunks({
|
|
181
|
+
before,
|
|
182
|
+
hunks,
|
|
183
|
+
relPath,
|
|
184
|
+
ask,
|
|
185
|
+
waitForKey: options.waitForKey,
|
|
186
|
+
editHunk,
|
|
187
|
+
});
|
|
188
|
+
if (review.quit) {
|
|
189
|
+
quit = true;
|
|
190
|
+
}
|
|
191
|
+
if (review.accepted.length > 0) {
|
|
192
|
+
try {
|
|
193
|
+
const merged = applyHunkList(before, review.accepted);
|
|
194
|
+
const normalized = normalizeScenarioMarkdown(merged);
|
|
195
|
+
const err = writeScenarioFile(resolved, normalized);
|
|
196
|
+
if (err) {
|
|
197
|
+
console.error(chalk.red(`Failed to write ${relPath}: ${err}`));
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
console.log(chalk.green(`Updated ${relPath} (${review.accepted.length} hunk(s) applied)`));
|
|
201
|
+
appliedFiles.push(resolved);
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
catch (err) {
|
|
205
|
+
console.error(chalk.red(String(err)));
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
if (quit)
|
|
209
|
+
break;
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
finally {
|
|
213
|
+
rl?.close();
|
|
214
|
+
}
|
|
215
|
+
return { appliedFiles, quit };
|
|
216
|
+
}
|
|
217
|
+
export function formatHeuristicSummary(report) {
|
|
218
|
+
if (report.findings.length === 0) {
|
|
219
|
+
return chalk.green(`Run ${report.runId}: all scenarios passed.`);
|
|
220
|
+
}
|
|
221
|
+
const lines = [
|
|
222
|
+
chalk.dim(`Run ${report.runId}`),
|
|
223
|
+
chalk.bold(`${report.findings.length} failed scenario(s):`),
|
|
224
|
+
"",
|
|
225
|
+
];
|
|
226
|
+
for (const f of report.findings) {
|
|
227
|
+
const kindColor = f.failureKind === "scenario_issue"
|
|
228
|
+
? chalk.yellow
|
|
229
|
+
: f.failureKind === "product"
|
|
230
|
+
? chalk.red
|
|
231
|
+
: f.failureKind === "transient"
|
|
232
|
+
? chalk.cyan
|
|
233
|
+
: chalk.gray;
|
|
234
|
+
lines.push(`• ${chalk.bold(f.scenario)} — ${kindColor(f.failureKind)} [${f.confidence}]`);
|
|
235
|
+
if (f.signals.length > 0) {
|
|
236
|
+
lines.push(chalk.dim(` signals: ${f.signals.join(", ")}`));
|
|
237
|
+
}
|
|
238
|
+
for (const s of f.suggestions.slice(0, 3)) {
|
|
239
|
+
lines.push(chalk.dim(` - ${s}`));
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
return lines.join("\n");
|
|
243
|
+
}
|
|
244
|
+
export function formatFlakySummary(report) {
|
|
245
|
+
if (report.findings.length === 0) {
|
|
246
|
+
return chalk.green(`No flaky scenarios across ${report.runIds.length} run(s).`);
|
|
247
|
+
}
|
|
248
|
+
const lines = [
|
|
249
|
+
chalk.bold(`Flaky scenarios across ${report.runIds.length} run(s):`),
|
|
250
|
+
chalk.dim(`Runs: ${report.runIds.join(", ")}`),
|
|
251
|
+
"",
|
|
252
|
+
];
|
|
253
|
+
for (const f of report.findings) {
|
|
254
|
+
lines.push(` ${chalk.bold(f.scenario)} ${f.passCount} pass / ${f.failCount} fail / ${f.errorCount} error`);
|
|
255
|
+
for (const cp of f.inconsistentCheckpoints.slice(0, 3)) {
|
|
256
|
+
lines.push(chalk.dim(` checkpoint flip: "${cp.assertion}" (pass: ${cp.passedIn.length}, fail: ${cp.failedIn.length})`));
|
|
257
|
+
}
|
|
258
|
+
const assessment = f.heuristicAssessment;
|
|
259
|
+
const hints = [];
|
|
260
|
+
if (assessment.likelyFalseNegative)
|
|
261
|
+
hints.push("likely false negative");
|
|
262
|
+
if (assessment.likelyFalsePositive)
|
|
263
|
+
hints.push("likely false positive");
|
|
264
|
+
if (hints.length > 0) {
|
|
265
|
+
lines.push(chalk.dim(` diagnosis hint: ${hints.join(", ")} [${assessment.dominantKind}]`));
|
|
266
|
+
}
|
|
267
|
+
for (const w of f.filePathWarnings) {
|
|
268
|
+
lines.push(chalk.yellow(` warning: ${w}`));
|
|
269
|
+
}
|
|
270
|
+
lines.push("");
|
|
271
|
+
}
|
|
272
|
+
return lines.join("\n");
|
|
273
|
+
}
|
|
274
|
+
function writeScenarioFile(filePath, markdown) {
|
|
275
|
+
try {
|
|
276
|
+
validateScenarioMarkdown(markdown, path.basename(filePath));
|
|
277
|
+
writeFileSync(filePath, markdown, "utf-8");
|
|
278
|
+
return undefined;
|
|
279
|
+
}
|
|
280
|
+
catch (err) {
|
|
281
|
+
return String(err);
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
//# sourceMappingURL=repl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repl.js","sourceRoot":"","sources":["../../src/analyze/repl.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repl.test.d.ts","sourceRoot":"","sources":["../../src/analyze/repl.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import assert from "node:assert/strict";
|
|
2
|
+
import { describe, it } from "node:test";
|
|
3
|
+
import { computeDiffHunks } from "./diff-hunks.js";
|
|
4
|
+
import { formatFlakySummary, formatHeuristicSummary } from "./repl.js";
|
|
5
|
+
describe("formatHeuristicSummary", () => {
|
|
6
|
+
it("reports when all scenarios passed", () => {
|
|
7
|
+
const text = formatHeuristicSummary({
|
|
8
|
+
runId: "run-1",
|
|
9
|
+
analyzedAt: "now",
|
|
10
|
+
findings: [],
|
|
11
|
+
});
|
|
12
|
+
assert.match(text, /all scenarios passed/i);
|
|
13
|
+
});
|
|
14
|
+
it("lists failed scenarios", () => {
|
|
15
|
+
const text = formatHeuristicSummary({
|
|
16
|
+
runId: "run-1",
|
|
17
|
+
analyzedAt: "now",
|
|
18
|
+
findings: [
|
|
19
|
+
{
|
|
20
|
+
scenario: "demo",
|
|
21
|
+
filePath: "scenarios/demo.md",
|
|
22
|
+
status: "fail",
|
|
23
|
+
failureKind: "scenario_issue",
|
|
24
|
+
confidence: "high",
|
|
25
|
+
suggestions: ["Move checkpoint"],
|
|
26
|
+
signals: ["steps_completed"],
|
|
27
|
+
},
|
|
28
|
+
],
|
|
29
|
+
});
|
|
30
|
+
assert.match(text, /demo/);
|
|
31
|
+
assert.match(text, /scenario_issue/);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
describe("formatFlakySummary", () => {
|
|
35
|
+
it("reports when no flaky scenarios found", () => {
|
|
36
|
+
const text = formatFlakySummary({
|
|
37
|
+
runIds: ["a", "b"],
|
|
38
|
+
analyzedAt: "now",
|
|
39
|
+
findings: [],
|
|
40
|
+
});
|
|
41
|
+
assert.match(text, /No flaky scenarios/i);
|
|
42
|
+
});
|
|
43
|
+
it("lists flaky scenario stats", () => {
|
|
44
|
+
const report = {
|
|
45
|
+
runIds: ["a", "b", "c"],
|
|
46
|
+
analyzedAt: "now",
|
|
47
|
+
findings: [
|
|
48
|
+
{
|
|
49
|
+
scenario: "pilar-smoke",
|
|
50
|
+
filePath: "scenarios/pilar-smoke.md",
|
|
51
|
+
filePathWarnings: [],
|
|
52
|
+
runCount: 3,
|
|
53
|
+
passCount: 2,
|
|
54
|
+
failCount: 1,
|
|
55
|
+
errorCount: 0,
|
|
56
|
+
inconsistentCheckpoints: [
|
|
57
|
+
{
|
|
58
|
+
assertion: 'page shows "Projects"',
|
|
59
|
+
passedIn: ["a", "b"],
|
|
60
|
+
failedIn: ["c"],
|
|
61
|
+
},
|
|
62
|
+
],
|
|
63
|
+
runs: [],
|
|
64
|
+
heuristicAssessment: {
|
|
65
|
+
dominantKind: "scenario_issue",
|
|
66
|
+
likelyFalseNegative: true,
|
|
67
|
+
likelyFalsePositive: false,
|
|
68
|
+
suggestions: [],
|
|
69
|
+
},
|
|
70
|
+
},
|
|
71
|
+
],
|
|
72
|
+
};
|
|
73
|
+
const text = formatFlakySummary(report);
|
|
74
|
+
assert.match(text, /pilar-smoke/);
|
|
75
|
+
assert.match(text, /2 pass \/ 1 fail/);
|
|
76
|
+
assert.match(text, /checkpoint flip/i);
|
|
77
|
+
assert.match(text, /false negative/i);
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
describe("computeDiffHunks integration", () => {
|
|
81
|
+
it("produces hunks for scenario-like edits", () => {
|
|
82
|
+
const before = `# Steps
|
|
83
|
+
1. Open app
|
|
84
|
+
2. Click Save
|
|
85
|
+
|
|
86
|
+
# Then
|
|
87
|
+
- page shows "Done"
|
|
88
|
+
`;
|
|
89
|
+
const after = `# Steps
|
|
90
|
+
1. Open app
|
|
91
|
+
2. Click Save
|
|
92
|
+
3. Wait for confirmation
|
|
93
|
+
|
|
94
|
+
# Then
|
|
95
|
+
- page shows "Done"
|
|
96
|
+
`;
|
|
97
|
+
const hunks = computeDiffHunks(before, after);
|
|
98
|
+
assert.ok(hunks.length >= 1);
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=repl.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repl.test.js","sourceRoot":"","sources":["../../src/analyze/repl.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ClassifiedFailure } from "../healing/classify.js";
|
|
2
|
+
import type { Scenario } from "../types/scenario.js";
|
|
3
|
+
import type { ScenarioResult } from "../types/verdict.js";
|
|
4
|
+
export declare function suggestScenarioFixes(result: ScenarioResult, scenario: Scenario | undefined, classified: ClassifiedFailure): string[];
|
|
5
|
+
//# sourceMappingURL=suggest.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suggest.d.ts","sourceRoot":"","sources":["../../src/analyze/suggest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AA+B1D,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,cAAc,EACtB,QAAQ,EAAE,QAAQ,GAAG,SAAS,EAC9B,UAAU,EAAE,iBAAiB,GAC5B,MAAM,EAAE,CAkEV"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
function lastNumberedStepIndex(steps) {
|
|
2
|
+
const matches = [...steps.matchAll(/^\s*(\d+)\./gm)];
|
|
3
|
+
if (matches.length === 0)
|
|
4
|
+
return undefined;
|
|
5
|
+
const last = matches.at(-1);
|
|
6
|
+
return last ? parseInt(last[1], 10) : undefined;
|
|
7
|
+
}
|
|
8
|
+
function stepBeforeNavigation(scenario) {
|
|
9
|
+
const lines = scenario.steps.split("\n");
|
|
10
|
+
for (let i = 0; i < lines.length; i++) {
|
|
11
|
+
const line = lines[i].toLowerCase();
|
|
12
|
+
if (/open (the )?(first )?project\b|open (a )?project\b|navigate.*project.*detail|see details/i.test(line) &&
|
|
13
|
+
!/my projects|all projects|projects list|sidebar/i.test(line)) {
|
|
14
|
+
const prev = lines
|
|
15
|
+
.slice(0, i)
|
|
16
|
+
.map((l) => /^\s*(\d+)\./.exec(l))
|
|
17
|
+
.filter(Boolean)
|
|
18
|
+
.at(-1);
|
|
19
|
+
if (prev)
|
|
20
|
+
return parseInt(prev[1], 10);
|
|
21
|
+
return Math.max(1, i);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
return lastNumberedStepIndex(scenario.steps);
|
|
25
|
+
}
|
|
26
|
+
export function suggestScenarioFixes(result, scenario, classified) {
|
|
27
|
+
const suggestions = [];
|
|
28
|
+
const failed = result.verdict?.checkpoints.filter((c) => !c.pass) ?? [];
|
|
29
|
+
switch (classified.kind) {
|
|
30
|
+
case "scenario_issue": {
|
|
31
|
+
for (const cp of failed) {
|
|
32
|
+
if (/^page shows/i.test(cp.assertion)) {
|
|
33
|
+
const stepN = scenario ? stepBeforeNavigation(scenario) : undefined;
|
|
34
|
+
if (stepN !== undefined) {
|
|
35
|
+
suggestions.push(`Move checkpoint "${cp.assertion}" to immediately after step ${stepN} (before navigation changes the page).`);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
suggestions.push(`Add an intermediate Then with "${cp.assertion}" before the step that navigates away from that view.`);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
if (/^url contains/i.test(cp.assertion) && /detail/i.test(cp.reason)) {
|
|
42
|
+
suggestions.push(`Narrow "${cp.assertion}" to the list route only (e.g. exact path "/projects" without project id), or verify URL before opening a detail page.`);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
if (suggestions.length === 0) {
|
|
46
|
+
suggestions.push("Review Then placement: checkpoints may target an earlier page state than the final step leaves the browser on.");
|
|
47
|
+
}
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
case "transient": {
|
|
51
|
+
if (classified.signals.length > 0) {
|
|
52
|
+
suggestions.push(`Flake suspected (signals: ${classified.signals.join(", ")}). Add explicit waits after steps that trigger navigation or data loading.`);
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
suggestions.push("Flake suspected — add agent-browser wait commands after unstable steps.");
|
|
56
|
+
}
|
|
57
|
+
suggestions.push("Consider `pqa run ... --retries 1 --retries-policy transient` for CI.");
|
|
58
|
+
break;
|
|
59
|
+
}
|
|
60
|
+
case "product": {
|
|
61
|
+
for (const cp of failed) {
|
|
62
|
+
suggestions.push(`Likely application regression — do not heal. Failed: "${cp.assertion}" — ${cp.reason.slice(0, 120)}`);
|
|
63
|
+
}
|
|
64
|
+
break;
|
|
65
|
+
}
|
|
66
|
+
default: {
|
|
67
|
+
suggestions.push(`Review transcript and artifacts in ${result.artifactDir ?? "(no artifact dir)"}.`);
|
|
68
|
+
if (result.error) {
|
|
69
|
+
suggestions.push(`Error: ${result.error.slice(0, 200)}`);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return suggestions.slice(0, 5);
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=suggest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suggest.js","sourceRoot":"","sources":["../../src/analyze/suggest.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suggest.test.d.ts","sourceRoot":"","sources":["../../src/analyze/suggest.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import assert from "node:assert/strict";
|
|
2
|
+
import { describe, it } from "node:test";
|
|
3
|
+
import { classifyFailure } from "../healing/classify.js";
|
|
4
|
+
import { suggestScenarioFixes } from "./suggest.js";
|
|
5
|
+
const scenario = {
|
|
6
|
+
filePath: "/scenarios/pilar-smoke.md",
|
|
7
|
+
frontmatter: { name: "pilar-smoke" },
|
|
8
|
+
skills: [],
|
|
9
|
+
goal: "Smoke",
|
|
10
|
+
steps: `1. Open app
|
|
11
|
+
4. Click My projects
|
|
12
|
+
5. Open the first project`,
|
|
13
|
+
then: ['url contains "/projects"', 'page shows "Projects"'],
|
|
14
|
+
rawCheckpoints: [],
|
|
15
|
+
checkpoints: [
|
|
16
|
+
{ raw: 'url contains "/projects"', kind: "url_contains", value: "/projects" },
|
|
17
|
+
{ raw: 'page shows "Projects"', kind: "page_shows", value: "Projects" },
|
|
18
|
+
],
|
|
19
|
+
};
|
|
20
|
+
const failResult = {
|
|
21
|
+
scenario: "pilar-smoke",
|
|
22
|
+
filePath: "/scenarios/pilar-smoke.md",
|
|
23
|
+
status: "fail",
|
|
24
|
+
durationMs: 1,
|
|
25
|
+
verdict: {
|
|
26
|
+
status: "fail",
|
|
27
|
+
summary: "All 5 steps completed successfully.",
|
|
28
|
+
checkpoints: [
|
|
29
|
+
{ assertion: 'url contains "/projects"', pass: true, reason: "ok" },
|
|
30
|
+
{
|
|
31
|
+
assertion: 'page shows "Projects"',
|
|
32
|
+
pass: false,
|
|
33
|
+
reason: "After completing all steps, on project detail page.",
|
|
34
|
+
},
|
|
35
|
+
],
|
|
36
|
+
},
|
|
37
|
+
transcript: { entries: [] },
|
|
38
|
+
};
|
|
39
|
+
describe("suggestScenarioFixes", () => {
|
|
40
|
+
it("suggests moving page_shows checkpoint before navigation", () => {
|
|
41
|
+
const classified = classifyFailure(failResult, scenario, {
|
|
42
|
+
llm: { provider: "anthropic", model: "x" },
|
|
43
|
+
browser: { headed: false, sessionName: "pqa", defaultTimeout: 25_000, engine: "chrome" },
|
|
44
|
+
skills: { dirs: [], preloads: [] },
|
|
45
|
+
agent: { maxTurns: 30, bashTimeoutMs: 120_000 },
|
|
46
|
+
auth: {},
|
|
47
|
+
});
|
|
48
|
+
const suggestions = suggestScenarioFixes(failResult, scenario, classified);
|
|
49
|
+
assert.equal(classified.kind, "scenario_issue");
|
|
50
|
+
assert.ok(suggestions.some((s) => s.includes('page shows "Projects"') && s.includes("step 4")));
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
//# sourceMappingURL=suggest.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suggest.test.js","sourceRoot":"","sources":["../../src/analyze/suggest.test.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAGzD,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAEpD,MAAM,QAAQ,GAAa;IACzB,QAAQ,EAAE,2BAA2B;IACrC,WAAW,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE;IACpC,MAAM,EAAE,EAAE;IACV,IAAI,EAAE,OAAO;IACb,KAAK,EAAE;;0BAEiB;IACxB,IAAI,EAAE,CAAC,0BAA0B,EAAE,uBAAuB,CAAC;IAC3D,cAAc,EAAE,EAAE;IAClB,WAAW,EAAE;QACX,EAAE,GAAG,EAAE,0BAA0B,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,WAAW,EAAE;QAC7E,EAAE,GAAG,EAAE,uBAAuB,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,UAAU,EAAE;KACxE;CACF,CAAC;AAEF,MAAM,UAAU,GAAmB;IACjC,QAAQ,EAAE,aAAa;IACvB,QAAQ,EAAE,2BAA2B;IACrC,MAAM,EAAE,MAAM;IACd,UAAU,EAAE,CAAC;IACb,OAAO,EAAE;QACP,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,qCAAqC;QAC9C,WAAW,EAAE;YACX,EAAE,SAAS,EAAE,0BAA0B,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE;YACnE;gBACE,SAAS,EAAE,uBAAuB;gBAClC,IAAI,EAAE,KAAK;gBACX,MAAM,EAAE,qDAAqD;aAC9D;SACF;KACF;IACD,UAAU,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE;CAC5B,CAAC;AAEF,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;QACjE,MAAM,UAAU,GAAG,eAAe,CAAC,UAAU,EAAE,QAAQ,EAAE;YACvD,GAAG,EAAE,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,EAAE,GAAG,EAAE;YAC1C,OAAO,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE;YACxF,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;YAClC,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,aAAa,EAAE,OAAO,EAAE;YAC/C,IAAI,EAAE,EAAE;SACT,CAAC,CAAC;QACH,MAAM,WAAW,GAAG,oBAAoB,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;QAC3E,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;QAChD,MAAM,CAAC,EAAE,CACP,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CACrF,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-markdown.d.ts","sourceRoot":"","sources":["../../src/analyze/validate-markdown.ts"],"names":[],"mappings":"AAKA,wBAAgB,yBAAyB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAElE;AAED,wBAAgB,wBAAwB,CACtC,QAAQ,EAAE,MAAM,EAChB,YAAY,SAAa,GACxB,IAAI,CAcN"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { mkdtempSync, unlinkSync, writeFileSync } from "node:fs";
|
|
2
|
+
import { tmpdir } from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { parseScenarioFile, stripScenarioComments } from "../scenarios/parser.js";
|
|
5
|
+
export function normalizeScenarioMarkdown(markdown) {
|
|
6
|
+
return `${stripScenarioComments(markdown).trim()}\n`;
|
|
7
|
+
}
|
|
8
|
+
export function validateScenarioMarkdown(markdown, hintBasename = "draft.md") {
|
|
9
|
+
const normalized = normalizeScenarioMarkdown(markdown);
|
|
10
|
+
const dir = mkdtempSync(path.join(tmpdir(), "pqa-analyze-"));
|
|
11
|
+
const draft = path.join(dir, hintBasename);
|
|
12
|
+
writeFileSync(draft, normalized, "utf-8");
|
|
13
|
+
try {
|
|
14
|
+
parseScenarioFile(draft);
|
|
15
|
+
}
|
|
16
|
+
finally {
|
|
17
|
+
try {
|
|
18
|
+
unlinkSync(draft);
|
|
19
|
+
}
|
|
20
|
+
catch {
|
|
21
|
+
/* ignore */
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=validate-markdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-markdown.js","sourceRoot":"","sources":["../../src/analyze/validate-markdown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACjE,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAElF,MAAM,UAAU,yBAAyB,CAAC,QAAgB;IACxD,OAAO,GAAG,qBAAqB,CAAC,QAAQ,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC;AACvD,CAAC;AAED,MAAM,UAAU,wBAAwB,CACtC,QAAgB,EAChB,YAAY,GAAG,UAAU;IAEzB,MAAM,UAAU,GAAG,yBAAyB,CAAC,QAAQ,CAAC,CAAC;IACvD,MAAM,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,cAAc,CAAC,CAAC,CAAC;IAC7D,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;IAC3C,aAAa,CAAC,KAAK,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;IAC1C,IAAI,CAAC;QACH,iBAAiB,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;YAAS,CAAC;QACT,IAAI,CAAC;YACH,UAAU,CAAC,KAAK,CAAC,CAAC;QACpB,CAAC;QAAC,MAAM,CAAC;YACP,YAAY;QACd,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ArtifactsMode } from "../types/config.js";
|
|
2
|
+
import type { ScenarioResult } from "../types/verdict.js";
|
|
3
|
+
/** Browser failure captures written by the agent under $PQA_ARTIFACT_DIR */
|
|
4
|
+
export declare const BROWSER_ARTIFACT_FILES: readonly ["failure.png", "snapshot.json"];
|
|
5
|
+
export declare function formatArtifactsRuntimeHint(mode: ArtifactsMode): string;
|
|
6
|
+
export declare function pruneBrowserArtifacts(artifactDir: string): void;
|
|
7
|
+
/** Enforce --artifacts policy after a scenario (harness transcripts are unaffected). */
|
|
8
|
+
export declare function applyArtifactsPolicy(artifactDir: string, mode: ArtifactsMode, result: Pick<ScenarioResult, "status">): void;
|
|
9
|
+
//# sourceMappingURL=policy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../src/artifacts/policy.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAE1D,4EAA4E;AAC5E,eAAO,MAAM,sBAAsB,2CAA4C,CAAC;AAEhF,wBAAgB,0BAA0B,CAAC,IAAI,EAAE,aAAa,GAAG,MAAM,CAsBtE;AAED,wBAAgB,qBAAqB,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI,CAO/D;AAED,wFAAwF;AACxF,wBAAgB,oBAAoB,CAClC,WAAW,EAAE,MAAM,EACnB,IAAI,EAAE,aAAa,EACnB,MAAM,EAAE,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,GACrC,IAAI,CAQN"}
|