@sentry/warden 0.0.0 → 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/.github/workflows/ci.yml +1 -1
- package/.github/workflows/release.yml +6 -1
- package/.github/workflows/warden.yml +1 -1
- package/dist/action/159.index.js +523 -0
- package/dist/action/159.index.js.map +1 -0
- package/dist/action/action/index.d.ts +2 -0
- package/dist/action/action/index.d.ts.map +1 -0
- package/dist/action/action/main.d.ts +2 -0
- package/dist/action/action/main.d.ts.map +1 -0
- package/dist/action/cli/args.d.ts +74 -0
- package/dist/action/cli/args.d.ts.map +1 -0
- package/dist/action/cli/args.test.d.ts +2 -0
- package/dist/action/cli/args.test.d.ts.map +1 -0
- package/dist/action/cli/commands/add.d.ts +7 -0
- package/dist/action/cli/commands/add.d.ts.map +1 -0
- package/dist/action/cli/commands/init.d.ts +10 -0
- package/dist/action/cli/commands/init.d.ts.map +1 -0
- package/dist/action/cli/commands/init.test.d.ts +2 -0
- package/dist/action/cli/commands/init.test.d.ts.map +1 -0
- package/dist/action/cli/commands/setup-app/browser.d.ts +9 -0
- package/dist/action/cli/commands/setup-app/browser.d.ts.map +1 -0
- package/dist/action/cli/commands/setup-app/credentials.d.ts +15 -0
- package/dist/action/cli/commands/setup-app/credentials.d.ts.map +1 -0
- package/dist/action/cli/commands/setup-app/manifest.d.ts +24 -0
- package/dist/action/cli/commands/setup-app/manifest.d.ts.map +1 -0
- package/dist/action/cli/commands/setup-app/server.d.ts +28 -0
- package/dist/action/cli/commands/setup-app/server.d.ts.map +1 -0
- package/dist/action/cli/commands/setup-app.d.ts +11 -0
- package/dist/action/cli/commands/setup-app.d.ts.map +1 -0
- package/dist/action/cli/commands/sync.d.ts +9 -0
- package/dist/action/cli/commands/sync.d.ts.map +1 -0
- package/dist/action/cli/context.d.ts +27 -0
- package/dist/action/cli/context.d.ts.map +1 -0
- package/dist/action/cli/files.d.ts +22 -0
- package/dist/action/cli/files.d.ts.map +1 -0
- package/dist/action/cli/files.test.d.ts +2 -0
- package/dist/action/cli/files.test.d.ts.map +1 -0
- package/dist/action/cli/fix.d.ts +41 -0
- package/dist/action/cli/fix.d.ts.map +1 -0
- package/dist/action/cli/fix.test.d.ts +2 -0
- package/dist/action/cli/fix.test.d.ts.map +1 -0
- package/dist/action/cli/git.d.ts +73 -0
- package/dist/action/cli/git.d.ts.map +1 -0
- package/dist/action/cli/git.test.d.ts +2 -0
- package/dist/action/cli/git.test.d.ts.map +1 -0
- package/dist/action/cli/index.d.ts +3 -0
- package/dist/action/cli/index.d.ts.map +1 -0
- package/dist/action/cli/main.d.ts +7 -0
- package/dist/action/cli/main.d.ts.map +1 -0
- package/dist/action/cli/output/box.d.ts +75 -0
- package/dist/action/cli/output/box.d.ts.map +1 -0
- package/dist/action/cli/output/formatters.d.ts +90 -0
- package/dist/action/cli/output/formatters.d.ts.map +1 -0
- package/dist/action/cli/output/formatters.test.d.ts +2 -0
- package/dist/action/cli/output/formatters.test.d.ts.map +1 -0
- package/dist/action/cli/output/icons.d.ts +11 -0
- package/dist/action/cli/output/icons.d.ts.map +1 -0
- package/dist/action/cli/output/index.d.ts +10 -0
- package/dist/action/cli/output/index.d.ts.map +1 -0
- package/dist/action/cli/output/ink-runner.d.ts +9 -0
- package/dist/action/cli/output/ink-runner.d.ts.map +1 -0
- package/dist/action/cli/output/jsonl.d.ts +43 -0
- package/dist/action/cli/output/jsonl.d.ts.map +1 -0
- package/dist/action/cli/output/jsonl.test.d.ts +2 -0
- package/dist/action/cli/output/jsonl.test.d.ts.map +1 -0
- package/dist/action/cli/output/reporter.d.ts +108 -0
- package/dist/action/cli/output/reporter.d.ts.map +1 -0
- package/dist/action/cli/output/tasks.d.ts +89 -0
- package/dist/action/cli/output/tasks.d.ts.map +1 -0
- package/dist/action/cli/output/tty.d.ts +21 -0
- package/dist/action/cli/output/tty.d.ts.map +1 -0
- package/dist/action/cli/output/tty.test.d.ts +2 -0
- package/dist/action/cli/output/tty.test.d.ts.map +1 -0
- package/dist/action/cli/output/verbosity.d.ts +20 -0
- package/dist/action/cli/output/verbosity.d.ts.map +1 -0
- package/dist/action/cli/output/verbosity.test.d.ts +2 -0
- package/dist/action/cli/output/verbosity.test.d.ts.map +1 -0
- package/dist/action/cli/terminal.d.ts +19 -0
- package/dist/action/cli/terminal.d.ts.map +1 -0
- package/dist/action/cli/terminal.test.d.ts +2 -0
- package/dist/action/cli/terminal.test.d.ts.map +1 -0
- package/dist/action/config/index.d.ts +4 -0
- package/dist/action/config/index.d.ts.map +1 -0
- package/dist/action/config/loader.d.ts +27 -0
- package/dist/action/config/loader.d.ts.map +1 -0
- package/dist/action/config/loader.test.d.ts +2 -0
- package/dist/action/config/loader.test.d.ts.map +1 -0
- package/dist/action/config/schema.d.ts +318 -0
- package/dist/action/config/schema.d.ts.map +1 -0
- package/dist/action/config/writer.d.ts +11 -0
- package/dist/action/config/writer.d.ts.map +1 -0
- package/dist/action/config/writer.test.d.ts +2 -0
- package/dist/action/config/writer.test.d.ts.map +1 -0
- package/dist/action/diff/classify.d.ts +29 -0
- package/dist/action/diff/classify.d.ts.map +1 -0
- package/dist/action/diff/classify.test.d.ts +2 -0
- package/dist/action/diff/classify.test.d.ts.map +1 -0
- package/dist/action/diff/coalesce.d.ts +42 -0
- package/dist/action/diff/coalesce.d.ts.map +1 -0
- package/dist/action/diff/coalesce.test.d.ts +2 -0
- package/dist/action/diff/coalesce.test.d.ts.map +1 -0
- package/dist/action/diff/context.d.ts +30 -0
- package/dist/action/diff/context.d.ts.map +1 -0
- package/dist/action/diff/context.test.d.ts +2 -0
- package/dist/action/diff/context.test.d.ts.map +1 -0
- package/dist/action/diff/index.d.ts +5 -0
- package/dist/action/diff/index.d.ts.map +1 -0
- package/dist/action/diff/parser.d.ts +52 -0
- package/dist/action/diff/parser.d.ts.map +1 -0
- package/dist/action/diff/parser.test.d.ts +2 -0
- package/dist/action/diff/parser.test.d.ts.map +1 -0
- package/dist/action/event/context.d.ts +9 -0
- package/dist/action/event/context.d.ts.map +1 -0
- package/dist/action/event/index.d.ts +3 -0
- package/dist/action/event/index.d.ts.map +1 -0
- package/dist/action/event/schedule-context.d.ts +30 -0
- package/dist/action/event/schedule-context.d.ts.map +1 -0
- package/dist/action/examples/examples.integration.test.d.ts +2 -0
- package/dist/action/examples/examples.integration.test.d.ts.map +1 -0
- package/dist/action/examples/index.d.ts +50 -0
- package/dist/action/examples/index.d.ts.map +1 -0
- package/dist/action/examples/index.test.d.ts +2 -0
- package/dist/action/examples/index.test.d.ts.map +1 -0
- package/dist/action/examples/setup.d.ts +2 -0
- package/dist/action/examples/setup.d.ts.map +1 -0
- package/dist/action/index.d.ts +11 -0
- package/dist/action/index.d.ts.map +1 -0
- package/dist/action/index.js +38231 -0
- package/dist/action/index.js.map +1 -0
- package/dist/action/licenses.txt +992 -0
- package/dist/action/main.d.ts +2 -0
- package/dist/action/main.d.ts.map +1 -0
- package/dist/action/main.js +707 -0
- package/dist/action/main.js.map +1 -0
- package/dist/action/output/dedup.d.ts +153 -0
- package/dist/action/output/dedup.d.ts.map +1 -0
- package/dist/action/output/dedup.test.d.ts +2 -0
- package/dist/action/output/dedup.test.d.ts.map +1 -0
- package/dist/action/output/github-checks.d.ts +106 -0
- package/dist/action/output/github-checks.d.ts.map +1 -0
- package/dist/action/output/github-checks.test.d.ts +2 -0
- package/dist/action/output/github-checks.test.d.ts.map +1 -0
- package/dist/action/output/github-issues.d.ts +35 -0
- package/dist/action/output/github-issues.d.ts.map +1 -0
- package/dist/action/output/index.d.ts +6 -0
- package/dist/action/output/index.d.ts.map +1 -0
- package/dist/action/output/issue-renderer.d.ts +20 -0
- package/dist/action/output/issue-renderer.d.ts.map +1 -0
- package/dist/action/output/renderer.d.ts +4 -0
- package/dist/action/output/renderer.d.ts.map +1 -0
- package/dist/action/output/renderer.test.d.ts +2 -0
- package/dist/action/output/renderer.test.d.ts.map +1 -0
- package/dist/action/output/stale.d.ts +31 -0
- package/dist/action/output/stale.d.ts.map +1 -0
- package/dist/action/output/stale.test.d.ts +2 -0
- package/dist/action/output/stale.test.d.ts.map +1 -0
- package/dist/action/output/types.d.ts +31 -0
- package/dist/action/output/types.d.ts.map +1 -0
- package/dist/action/package.json +3 -0
- package/dist/action/sdk/index.d.ts +2 -0
- package/dist/action/sdk/index.d.ts.map +1 -0
- package/dist/action/sdk/runner.d.ts +202 -0
- package/dist/action/sdk/runner.d.ts.map +1 -0
- package/dist/action/sdk/runner.test.d.ts +2 -0
- package/dist/action/sdk/runner.test.d.ts.map +1 -0
- package/dist/action/skills/index.d.ts +5 -0
- package/dist/action/skills/index.d.ts.map +1 -0
- package/dist/action/skills/loader.d.ts +111 -0
- package/dist/action/skills/loader.d.ts.map +1 -0
- package/dist/action/skills/loader.test.d.ts +2 -0
- package/dist/action/skills/loader.test.d.ts.map +1 -0
- package/dist/action/skills/remote.d.ts +117 -0
- package/dist/action/skills/remote.d.ts.map +1 -0
- package/dist/action/skills/remote.test.d.ts +2 -0
- package/dist/action/skills/remote.test.d.ts.map +1 -0
- package/dist/action/sourcemap-register.cjs +1 -0
- package/dist/action/triggers/matcher.d.ts +30 -0
- package/dist/action/triggers/matcher.d.ts.map +1 -0
- package/dist/action/triggers/matcher.test.d.ts +2 -0
- package/dist/action/triggers/matcher.test.d.ts.map +1 -0
- package/dist/action/types/index.d.ts +269 -0
- package/dist/action/types/index.d.ts.map +1 -0
- package/dist/action/utils/async.d.ts +5 -0
- package/dist/action/utils/async.d.ts.map +1 -0
- package/dist/action/utils/index.d.ts +16 -0
- package/dist/action/utils/index.d.ts.map +1 -0
- package/dist/action/utils/index.test.d.ts +2 -0
- package/dist/action/utils/index.test.d.ts.map +1 -0
- package/dist/action/utils/version.d.ts +3 -0
- package/dist/action/utils/version.d.ts.map +1 -0
- package/dist/cli/args.d.ts +74 -0
- package/dist/cli/args.d.ts.map +1 -0
- package/dist/cli/args.js +359 -0
- package/dist/cli/args.js.map +1 -0
- package/dist/cli/args.test.d.ts +2 -0
- package/dist/cli/args.test.d.ts.map +1 -0
- package/dist/cli/args.test.js +392 -0
- package/dist/cli/args.test.js.map +1 -0
- package/dist/cli/commands/add.d.ts +7 -0
- package/dist/cli/commands/add.d.ts.map +1 -0
- package/dist/cli/commands/add.js +380 -0
- package/dist/cli/commands/add.js.map +1 -0
- package/dist/cli/commands/init.d.ts +10 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +113 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/init.test.d.ts +2 -0
- package/dist/cli/commands/init.test.d.ts.map +1 -0
- package/dist/cli/commands/init.test.js +117 -0
- package/dist/cli/commands/init.test.js.map +1 -0
- package/dist/cli/commands/setup-app/browser.d.ts +9 -0
- package/dist/cli/commands/setup-app/browser.d.ts.map +1 -0
- package/dist/cli/commands/setup-app/browser.js +36 -0
- package/dist/cli/commands/setup-app/browser.js.map +1 -0
- package/dist/cli/commands/setup-app/credentials.d.ts +15 -0
- package/dist/cli/commands/setup-app/credentials.d.ts.map +1 -0
- package/dist/cli/commands/setup-app/credentials.js +29 -0
- package/dist/cli/commands/setup-app/credentials.js.map +1 -0
- package/dist/cli/commands/setup-app/manifest.d.ts +24 -0
- package/dist/cli/commands/setup-app/manifest.d.ts.map +1 -0
- package/dist/cli/commands/setup-app/manifest.js +29 -0
- package/dist/cli/commands/setup-app/manifest.js.map +1 -0
- package/dist/cli/commands/setup-app/server.d.ts +28 -0
- package/dist/cli/commands/setup-app/server.d.ts.map +1 -0
- package/dist/cli/commands/setup-app/server.js +136 -0
- package/dist/cli/commands/setup-app/server.js.map +1 -0
- package/dist/cli/commands/setup-app.d.ts +11 -0
- package/dist/cli/commands/setup-app.d.ts.map +1 -0
- package/dist/cli/commands/setup-app.js +139 -0
- package/dist/cli/commands/setup-app.js.map +1 -0
- package/dist/cli/commands/sync.d.ts +9 -0
- package/dist/cli/commands/sync.d.ts.map +1 -0
- package/dist/cli/commands/sync.js +96 -0
- package/dist/cli/commands/sync.js.map +1 -0
- package/dist/cli/context.d.ts +27 -0
- package/dist/cli/context.d.ts.map +1 -0
- package/dist/cli/context.js +101 -0
- package/dist/cli/context.js.map +1 -0
- package/dist/cli/files.d.ts +22 -0
- package/dist/cli/files.d.ts.map +1 -0
- package/dist/cli/files.js +66 -0
- package/dist/cli/files.js.map +1 -0
- package/dist/cli/files.test.d.ts +2 -0
- package/dist/cli/files.test.d.ts.map +1 -0
- package/dist/cli/files.test.js +117 -0
- package/dist/cli/files.test.js.map +1 -0
- package/dist/cli/fix.d.ts +41 -0
- package/dist/cli/fix.d.ts.map +1 -0
- package/dist/cli/fix.js +320 -0
- package/dist/cli/fix.js.map +1 -0
- package/dist/cli/fix.test.d.ts +2 -0
- package/dist/cli/fix.test.d.ts.map +1 -0
- package/dist/cli/fix.test.js +251 -0
- package/dist/cli/fix.test.js.map +1 -0
- package/dist/cli/git.d.ts +73 -0
- package/dist/cli/git.d.ts.map +1 -0
- package/dist/cli/git.js +267 -0
- package/dist/cli/git.js.map +1 -0
- package/dist/cli/git.test.d.ts +2 -0
- package/dist/cli/git.test.d.ts.map +1 -0
- package/dist/cli/git.test.js +96 -0
- package/dist/cli/git.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 +13 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/main.d.ts +7 -0
- package/dist/cli/main.d.ts.map +1 -0
- package/dist/cli/main.js +560 -0
- package/dist/cli/main.js.map +1 -0
- package/dist/cli/output/box.d.ts +75 -0
- package/dist/cli/output/box.d.ts.map +1 -0
- package/dist/cli/output/box.js +191 -0
- package/dist/cli/output/box.js.map +1 -0
- package/dist/cli/output/formatters.d.ts +90 -0
- package/dist/cli/output/formatters.d.ts.map +1 -0
- package/dist/cli/output/formatters.js +248 -0
- package/dist/cli/output/formatters.js.map +1 -0
- package/dist/cli/output/formatters.test.d.ts +2 -0
- package/dist/cli/output/formatters.test.d.ts.map +1 -0
- package/dist/cli/output/formatters.test.js +152 -0
- package/dist/cli/output/formatters.test.js.map +1 -0
- package/dist/cli/output/icons.d.ts +11 -0
- package/dist/cli/output/icons.d.ts.map +1 -0
- package/dist/cli/output/icons.js +11 -0
- package/dist/cli/output/icons.js.map +1 -0
- package/dist/cli/output/index.d.ts +10 -0
- package/dist/cli/output/index.d.ts.map +1 -0
- package/dist/cli/output/index.js +10 -0
- package/dist/cli/output/index.js.map +1 -0
- package/dist/cli/output/ink-runner.d.ts +9 -0
- package/dist/cli/output/ink-runner.d.ts.map +1 -0
- package/dist/cli/output/ink-runner.js +207 -0
- package/dist/cli/output/ink-runner.js.map +1 -0
- package/dist/cli/output/jsonl.d.ts +43 -0
- package/dist/cli/output/jsonl.d.ts.map +1 -0
- package/dist/cli/output/jsonl.js +89 -0
- package/dist/cli/output/jsonl.js.map +1 -0
- package/dist/cli/output/jsonl.test.d.ts +2 -0
- package/dist/cli/output/jsonl.test.d.ts.map +1 -0
- package/dist/cli/output/jsonl.test.js +284 -0
- package/dist/cli/output/jsonl.test.js.map +1 -0
- package/dist/cli/output/reporter.d.ts +108 -0
- package/dist/cli/output/reporter.d.ts.map +1 -0
- package/dist/cli/output/reporter.js +378 -0
- package/dist/cli/output/reporter.js.map +1 -0
- package/dist/cli/output/tasks.d.ts +89 -0
- package/dist/cli/output/tasks.d.ts.map +1 -0
- package/dist/cli/output/tasks.js +251 -0
- package/dist/cli/output/tasks.js.map +1 -0
- package/dist/cli/output/tty.d.ts +21 -0
- package/dist/cli/output/tty.d.ts.map +1 -0
- package/dist/cli/output/tty.js +44 -0
- package/dist/cli/output/tty.js.map +1 -0
- package/dist/cli/output/tty.test.d.ts +2 -0
- package/dist/cli/output/tty.test.d.ts.map +1 -0
- package/dist/cli/output/tty.test.js +105 -0
- package/dist/cli/output/tty.test.js.map +1 -0
- package/dist/cli/output/verbosity.d.ts +20 -0
- package/dist/cli/output/verbosity.d.ts.map +1 -0
- package/dist/cli/output/verbosity.js +32 -0
- package/dist/cli/output/verbosity.js.map +1 -0
- package/dist/cli/output/verbosity.test.d.ts +2 -0
- package/dist/cli/output/verbosity.test.d.ts.map +1 -0
- package/dist/cli/output/verbosity.test.js +35 -0
- package/dist/cli/output/verbosity.test.js.map +1 -0
- package/dist/cli/terminal.d.ts +19 -0
- package/dist/cli/terminal.d.ts.map +1 -0
- package/dist/cli/terminal.js +247 -0
- package/dist/cli/terminal.js.map +1 -0
- package/dist/cli/terminal.test.d.ts +2 -0
- package/dist/cli/terminal.test.d.ts.map +1 -0
- package/dist/cli/terminal.test.js +123 -0
- package/dist/cli/terminal.test.js.map +1 -0
- package/dist/config/index.d.ts +4 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +4 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/loader.d.ts +27 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +77 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/loader.test.d.ts +2 -0
- package/dist/config/loader.test.d.ts.map +1 -0
- package/dist/config/loader.test.js +263 -0
- package/dist/config/loader.test.js.map +1 -0
- package/dist/config/schema.d.ts +318 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +137 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/config/writer.d.ts +11 -0
- package/dist/config/writer.d.ts.map +1 -0
- package/dist/config/writer.js +74 -0
- package/dist/config/writer.js.map +1 -0
- package/dist/config/writer.test.d.ts +2 -0
- package/dist/config/writer.test.d.ts.map +1 -0
- package/dist/config/writer.test.js +98 -0
- package/dist/config/writer.test.js.map +1 -0
- package/dist/diff/classify.d.ts +29 -0
- package/dist/diff/classify.d.ts.map +1 -0
- package/dist/diff/classify.js +74 -0
- package/dist/diff/classify.js.map +1 -0
- package/dist/diff/classify.test.d.ts +2 -0
- package/dist/diff/classify.test.d.ts.map +1 -0
- package/dist/diff/classify.test.js +140 -0
- package/dist/diff/classify.test.js.map +1 -0
- package/dist/diff/coalesce.d.ts +42 -0
- package/dist/diff/coalesce.d.ts.map +1 -0
- package/dist/diff/coalesce.js +104 -0
- package/dist/diff/coalesce.js.map +1 -0
- package/dist/diff/coalesce.test.d.ts +2 -0
- package/dist/diff/coalesce.test.d.ts.map +1 -0
- package/dist/diff/coalesce.test.js +159 -0
- package/dist/diff/coalesce.test.js.map +1 -0
- package/dist/diff/context.d.ts +30 -0
- package/dist/diff/context.d.ts.map +1 -0
- package/dist/diff/context.js +144 -0
- package/dist/diff/context.js.map +1 -0
- package/dist/diff/context.test.d.ts +2 -0
- package/dist/diff/context.test.d.ts.map +1 -0
- package/dist/diff/context.test.js +190 -0
- package/dist/diff/context.test.js.map +1 -0
- package/dist/diff/index.d.ts +5 -0
- package/dist/diff/index.d.ts.map +1 -0
- package/dist/diff/index.js +5 -0
- package/dist/diff/index.js.map +1 -0
- package/dist/diff/parser.d.ts +52 -0
- package/dist/diff/parser.d.ts.map +1 -0
- package/dist/diff/parser.js +95 -0
- package/dist/diff/parser.js.map +1 -0
- package/dist/diff/parser.test.d.ts +2 -0
- package/dist/diff/parser.test.d.ts.map +1 -0
- package/dist/diff/parser.test.js +178 -0
- package/dist/diff/parser.test.js.map +1 -0
- package/dist/event/context.d.ts +9 -0
- package/dist/event/context.d.ts.map +1 -0
- package/dist/event/context.js +94 -0
- package/dist/event/context.js.map +1 -0
- package/dist/event/index.d.ts +3 -0
- package/dist/event/index.d.ts.map +1 -0
- package/dist/event/index.js +3 -0
- package/dist/event/index.js.map +1 -0
- package/dist/event/schedule-context.d.ts +30 -0
- package/dist/event/schedule-context.d.ts.map +1 -0
- package/dist/event/schedule-context.js +57 -0
- package/dist/event/schedule-context.js.map +1 -0
- package/dist/examples/examples.integration.test.d.ts +2 -0
- package/dist/examples/examples.integration.test.d.ts.map +1 -0
- package/dist/examples/examples.integration.test.js +55 -0
- package/dist/examples/examples.integration.test.js.map +1 -0
- package/dist/examples/index.d.ts +50 -0
- package/dist/examples/index.d.ts.map +1 -0
- package/dist/examples/index.js +104 -0
- package/dist/examples/index.js.map +1 -0
- package/dist/examples/index.test.d.ts +2 -0
- package/dist/examples/index.test.d.ts.map +1 -0
- package/dist/examples/index.test.js +88 -0
- package/dist/examples/index.test.js.map +1 -0
- package/dist/examples/setup.d.ts +2 -0
- package/dist/examples/setup.d.ts.map +1 -0
- package/dist/examples/setup.js +22 -0
- package/dist/examples/setup.js.map +1 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +57 -0
- package/dist/index.js.map +1 -0
- package/dist/output/dedup.d.ts +153 -0
- package/dist/output/dedup.d.ts.map +1 -0
- package/dist/output/dedup.js +416 -0
- package/dist/output/dedup.js.map +1 -0
- package/dist/output/dedup.test.d.ts +2 -0
- package/dist/output/dedup.test.d.ts.map +1 -0
- package/dist/output/dedup.test.js +357 -0
- package/dist/output/dedup.test.js.map +1 -0
- package/dist/output/github-checks.d.ts +106 -0
- package/dist/output/github-checks.d.ts.map +1 -0
- package/dist/output/github-checks.js +321 -0
- package/dist/output/github-checks.js.map +1 -0
- package/dist/output/github-checks.test.d.ts +2 -0
- package/dist/output/github-checks.test.d.ts.map +1 -0
- package/dist/output/github-checks.test.js +255 -0
- package/dist/output/github-checks.test.js.map +1 -0
- package/dist/output/github-issues.d.ts +35 -0
- package/dist/output/github-issues.d.ts.map +1 -0
- package/dist/output/github-issues.js +246 -0
- package/dist/output/github-issues.js.map +1 -0
- package/dist/output/index.d.ts +6 -0
- package/dist/output/index.d.ts.map +1 -0
- package/dist/output/index.js +6 -0
- package/dist/output/index.js.map +1 -0
- package/dist/output/issue-renderer.d.ts +20 -0
- package/dist/output/issue-renderer.d.ts.map +1 -0
- package/dist/output/issue-renderer.js +154 -0
- package/dist/output/issue-renderer.js.map +1 -0
- package/dist/output/renderer.d.ts +4 -0
- package/dist/output/renderer.d.ts.map +1 -0
- package/dist/output/renderer.js +168 -0
- package/dist/output/renderer.js.map +1 -0
- package/dist/output/renderer.test.d.ts +2 -0
- package/dist/output/renderer.test.d.ts.map +1 -0
- package/dist/output/renderer.test.js +645 -0
- package/dist/output/renderer.test.js.map +1 -0
- package/dist/output/stale.d.ts +31 -0
- package/dist/output/stale.d.ts.map +1 -0
- package/dist/output/stale.js +114 -0
- package/dist/output/stale.js.map +1 -0
- package/dist/output/stale.test.d.ts +2 -0
- package/dist/output/stale.test.d.ts.map +1 -0
- package/dist/output/stale.test.js +330 -0
- package/dist/output/stale.test.js.map +1 -0
- package/dist/output/types.d.ts +31 -0
- package/dist/output/types.d.ts.map +1 -0
- package/dist/output/types.js +2 -0
- package/dist/output/types.js.map +1 -0
- package/dist/sdk/index.d.ts +2 -0
- package/dist/sdk/index.d.ts.map +1 -0
- package/dist/sdk/index.js +2 -0
- package/dist/sdk/index.js.map +1 -0
- package/dist/sdk/runner.d.ts +202 -0
- package/dist/sdk/runner.d.ts.map +1 -0
- package/dist/sdk/runner.js +888 -0
- package/dist/sdk/runner.js.map +1 -0
- package/dist/sdk/runner.test.d.ts +2 -0
- package/dist/sdk/runner.test.d.ts.map +1 -0
- package/dist/sdk/runner.test.js +677 -0
- package/dist/sdk/runner.test.js.map +1 -0
- package/dist/skills/index.d.ts +5 -0
- package/dist/skills/index.d.ts.map +1 -0
- package/dist/skills/index.js +3 -0
- package/dist/skills/index.js.map +1 -0
- package/dist/skills/loader.d.ts +111 -0
- package/dist/skills/loader.d.ts.map +1 -0
- package/dist/skills/loader.js +319 -0
- package/dist/skills/loader.js.map +1 -0
- package/dist/skills/loader.test.d.ts +2 -0
- package/dist/skills/loader.test.d.ts.map +1 -0
- package/dist/skills/loader.test.js +241 -0
- package/dist/skills/loader.test.js.map +1 -0
- package/dist/skills/remote.d.ts +117 -0
- package/dist/skills/remote.d.ts.map +1 -0
- package/dist/skills/remote.js +496 -0
- package/dist/skills/remote.js.map +1 -0
- package/dist/skills/remote.test.d.ts +2 -0
- package/dist/skills/remote.test.d.ts.map +1 -0
- package/dist/skills/remote.test.js +582 -0
- package/dist/skills/remote.test.js.map +1 -0
- package/dist/triggers/matcher.d.ts +30 -0
- package/dist/triggers/matcher.d.ts.map +1 -0
- package/dist/triggers/matcher.js +122 -0
- package/dist/triggers/matcher.js.map +1 -0
- package/dist/triggers/matcher.test.d.ts +2 -0
- package/dist/triggers/matcher.test.d.ts.map +1 -0
- package/dist/triggers/matcher.test.js +234 -0
- package/dist/triggers/matcher.test.js.map +1 -0
- package/dist/types/index.d.ts +269 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +162 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/async.d.ts +5 -0
- package/dist/utils/async.d.ts.map +1 -0
- package/dist/utils/async.js +13 -0
- package/dist/utils/async.js.map +1 -0
- package/dist/utils/index.d.ts +16 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +44 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/index.test.d.ts +2 -0
- package/dist/utils/index.test.d.ts.map +1 -0
- package/dist/utils/index.test.js +68 -0
- package/dist/utils/index.test.js.map +1 -0
- package/dist/utils/version.d.ts +3 -0
- package/dist/utils/version.d.ts.map +1 -0
- package/dist/utils/version.js +16 -0
- package/dist/utils/version.js.map +1 -0
- package/docs/src/pages/config.astro +2 -1
- package/docs/src/pages/guide.astro +2 -1
- package/docs/src/utils/version.ts +6 -0
- package/package.json +12 -2
- package/src/cli/args.ts +2 -3
- package/src/cli/commands/init.test.ts +2 -1
- package/src/cli/commands/init.ts +3 -1
- package/src/cli/output/reporter.ts +3 -4
- package/src/utils/index.ts +1 -0
- package/src/utils/version.ts +17 -0
- package/.claude/settings.local.json +0 -88
- package/docs/.claude/settings.local.json +0 -11
|
@@ -0,0 +1,357 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { generateContentHash, generateMarker, parseMarker, parseWardenComment, isWardenComment, deduplicateFindings, findingToExistingComment, parseWardenSkills, updateWardenCommentBody, } from './dedup.js';
|
|
3
|
+
describe('generateContentHash', () => {
|
|
4
|
+
it('generates consistent 8-char hex hash', () => {
|
|
5
|
+
const hash = generateContentHash('SQL Injection', 'User input passed to query');
|
|
6
|
+
expect(hash).toMatch(/^[a-f0-9]{8}$/);
|
|
7
|
+
});
|
|
8
|
+
it('returns same hash for same content', () => {
|
|
9
|
+
const hash1 = generateContentHash('Title', 'Description');
|
|
10
|
+
const hash2 = generateContentHash('Title', 'Description');
|
|
11
|
+
expect(hash1).toBe(hash2);
|
|
12
|
+
});
|
|
13
|
+
it('returns different hash for different content', () => {
|
|
14
|
+
const hash1 = generateContentHash('Title A', 'Description');
|
|
15
|
+
const hash2 = generateContentHash('Title B', 'Description');
|
|
16
|
+
expect(hash1).not.toBe(hash2);
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
describe('generateMarker', () => {
|
|
20
|
+
it('generates marker in expected format', () => {
|
|
21
|
+
const marker = generateMarker('src/db.ts', 42, 'a1b2c3d4');
|
|
22
|
+
expect(marker).toBe('<!-- warden:v1:src/db.ts:42:a1b2c3d4 -->');
|
|
23
|
+
});
|
|
24
|
+
it('handles paths with special characters', () => {
|
|
25
|
+
const marker = generateMarker('src/utils/db-helper.ts', 100, 'abcd1234');
|
|
26
|
+
expect(marker).toBe('<!-- warden:v1:src/utils/db-helper.ts:100:abcd1234 -->');
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
describe('parseMarker', () => {
|
|
30
|
+
it('parses valid marker', () => {
|
|
31
|
+
const body = `**:warning: SQL Injection**
|
|
32
|
+
|
|
33
|
+
User input passed to query.
|
|
34
|
+
|
|
35
|
+
---
|
|
36
|
+
<sub>warden: security-review</sub>
|
|
37
|
+
<!-- warden:v1:src/db.ts:42:a1b2c3d4 -->`;
|
|
38
|
+
const marker = parseMarker(body);
|
|
39
|
+
expect(marker).toEqual({
|
|
40
|
+
path: 'src/db.ts',
|
|
41
|
+
line: 42,
|
|
42
|
+
contentHash: 'a1b2c3d4',
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
it('returns null for body without marker', () => {
|
|
46
|
+
const body = '**:warning: Some Issue**\n\nDescription';
|
|
47
|
+
expect(parseMarker(body)).toBeNull();
|
|
48
|
+
});
|
|
49
|
+
it('returns null for invalid marker format', () => {
|
|
50
|
+
const body = '<!-- warden:invalid -->';
|
|
51
|
+
expect(parseMarker(body)).toBeNull();
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
describe('parseWardenComment', () => {
|
|
55
|
+
it('parses comment with emoji', () => {
|
|
56
|
+
const body = `**:warning: SQL Injection**
|
|
57
|
+
|
|
58
|
+
User input passed directly to query.
|
|
59
|
+
|
|
60
|
+
---
|
|
61
|
+
<sub>warden: security-review</sub>`;
|
|
62
|
+
const parsed = parseWardenComment(body);
|
|
63
|
+
expect(parsed).toEqual({
|
|
64
|
+
title: 'SQL Injection',
|
|
65
|
+
description: 'User input passed directly to query.',
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
it('parses comment without emoji', () => {
|
|
69
|
+
const body = `**Missing Validation**
|
|
70
|
+
|
|
71
|
+
No input validation on user data.
|
|
72
|
+
|
|
73
|
+
---
|
|
74
|
+
<sub>warden: code-review</sub>`;
|
|
75
|
+
const parsed = parseWardenComment(body);
|
|
76
|
+
expect(parsed).toEqual({
|
|
77
|
+
title: 'Missing Validation',
|
|
78
|
+
description: 'No input validation on user data.',
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
it('returns null for non-Warden comment', () => {
|
|
82
|
+
const body = 'This is a regular comment without the expected format.';
|
|
83
|
+
expect(parseWardenComment(body)).toBeNull();
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
describe('isWardenComment', () => {
|
|
87
|
+
it('returns true for comment with attribution', () => {
|
|
88
|
+
const body = `**:warning: Issue**\n\nDescription\n\n---\n<sub>warden: skill</sub>`;
|
|
89
|
+
expect(isWardenComment(body)).toBe(true);
|
|
90
|
+
});
|
|
91
|
+
it('returns true for comment with marker', () => {
|
|
92
|
+
const body = `**Issue**\n\n<!-- warden:v1:file.ts:10:abc12345 -->`;
|
|
93
|
+
expect(isWardenComment(body)).toBe(true);
|
|
94
|
+
});
|
|
95
|
+
it('returns false for regular comment', () => {
|
|
96
|
+
const body = 'This is a regular comment.';
|
|
97
|
+
expect(isWardenComment(body)).toBe(false);
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
describe('deduplicateFindings', () => {
|
|
101
|
+
const baseFinding = {
|
|
102
|
+
id: 'f1',
|
|
103
|
+
severity: 'high',
|
|
104
|
+
title: 'SQL Injection',
|
|
105
|
+
description: 'User input passed to query',
|
|
106
|
+
location: {
|
|
107
|
+
path: 'src/db.ts',
|
|
108
|
+
startLine: 42,
|
|
109
|
+
},
|
|
110
|
+
};
|
|
111
|
+
it('returns all findings when no existing comments', async () => {
|
|
112
|
+
const findings = [baseFinding];
|
|
113
|
+
const result = await deduplicateFindings(findings, [], { hashOnly: true });
|
|
114
|
+
expect(result.newFindings).toHaveLength(1);
|
|
115
|
+
expect(result.newFindings[0]).toBe(baseFinding);
|
|
116
|
+
expect(result.duplicateActions).toHaveLength(0);
|
|
117
|
+
});
|
|
118
|
+
it('returns all findings when findings array is empty', async () => {
|
|
119
|
+
const existingComments = [
|
|
120
|
+
{
|
|
121
|
+
id: 1,
|
|
122
|
+
path: 'src/db.ts',
|
|
123
|
+
line: 42,
|
|
124
|
+
title: 'SQL Injection',
|
|
125
|
+
description: 'User input passed to query',
|
|
126
|
+
contentHash: generateContentHash('SQL Injection', 'User input passed to query'),
|
|
127
|
+
},
|
|
128
|
+
];
|
|
129
|
+
const result = await deduplicateFindings([], existingComments, { hashOnly: true });
|
|
130
|
+
expect(result.newFindings).toHaveLength(0);
|
|
131
|
+
expect(result.duplicateActions).toHaveLength(0);
|
|
132
|
+
});
|
|
133
|
+
it('filters out exact hash matches and creates duplicate action', async () => {
|
|
134
|
+
const existingComments = [
|
|
135
|
+
{
|
|
136
|
+
id: 1,
|
|
137
|
+
path: 'src/db.ts',
|
|
138
|
+
line: 42,
|
|
139
|
+
title: 'SQL Injection',
|
|
140
|
+
description: 'User input passed to query',
|
|
141
|
+
contentHash: generateContentHash('SQL Injection', 'User input passed to query'),
|
|
142
|
+
isWarden: true,
|
|
143
|
+
},
|
|
144
|
+
];
|
|
145
|
+
const result = await deduplicateFindings([baseFinding], existingComments, { hashOnly: true });
|
|
146
|
+
expect(result.newFindings).toHaveLength(0);
|
|
147
|
+
expect(result.duplicateActions).toHaveLength(1);
|
|
148
|
+
expect(result.duplicateActions[0].type).toBe('update_warden');
|
|
149
|
+
expect(result.duplicateActions[0].matchType).toBe('hash');
|
|
150
|
+
});
|
|
151
|
+
it('keeps findings with different content', async () => {
|
|
152
|
+
const existingComments = [
|
|
153
|
+
{
|
|
154
|
+
id: 1,
|
|
155
|
+
path: 'src/db.ts',
|
|
156
|
+
line: 42,
|
|
157
|
+
title: 'SQL Injection',
|
|
158
|
+
description: 'User input passed to query',
|
|
159
|
+
contentHash: generateContentHash('SQL Injection', 'User input passed to query'),
|
|
160
|
+
},
|
|
161
|
+
];
|
|
162
|
+
const differentFinding = {
|
|
163
|
+
...baseFinding,
|
|
164
|
+
id: 'f2',
|
|
165
|
+
title: 'XSS Vulnerability',
|
|
166
|
+
description: 'Unescaped output in HTML',
|
|
167
|
+
};
|
|
168
|
+
const result = await deduplicateFindings([differentFinding], existingComments, {
|
|
169
|
+
hashOnly: true,
|
|
170
|
+
});
|
|
171
|
+
expect(result.newFindings).toHaveLength(1);
|
|
172
|
+
expect(result.newFindings[0].title).toBe('XSS Vulnerability');
|
|
173
|
+
expect(result.duplicateActions).toHaveLength(0);
|
|
174
|
+
});
|
|
175
|
+
it('filters multiple duplicates and keeps unique findings', async () => {
|
|
176
|
+
const finding1 = {
|
|
177
|
+
id: 'f1',
|
|
178
|
+
severity: 'high',
|
|
179
|
+
title: 'SQL Injection',
|
|
180
|
+
description: 'User input passed to query',
|
|
181
|
+
location: { path: 'src/db.ts', startLine: 42 },
|
|
182
|
+
};
|
|
183
|
+
const finding2 = {
|
|
184
|
+
id: 'f2',
|
|
185
|
+
severity: 'medium',
|
|
186
|
+
title: 'Missing Error Handling',
|
|
187
|
+
description: 'No try-catch block',
|
|
188
|
+
location: { path: 'src/api.ts', startLine: 100 },
|
|
189
|
+
};
|
|
190
|
+
const finding3 = {
|
|
191
|
+
id: 'f3',
|
|
192
|
+
severity: 'low',
|
|
193
|
+
title: 'Code Style',
|
|
194
|
+
description: 'Inconsistent indentation',
|
|
195
|
+
location: { path: 'src/utils.ts', startLine: 50 },
|
|
196
|
+
};
|
|
197
|
+
const existingComments = [
|
|
198
|
+
{
|
|
199
|
+
id: 1,
|
|
200
|
+
path: 'src/db.ts',
|
|
201
|
+
line: 42,
|
|
202
|
+
title: 'SQL Injection',
|
|
203
|
+
description: 'User input passed to query',
|
|
204
|
+
contentHash: generateContentHash('SQL Injection', 'User input passed to query'),
|
|
205
|
+
isWarden: true,
|
|
206
|
+
},
|
|
207
|
+
{
|
|
208
|
+
id: 2,
|
|
209
|
+
path: 'src/utils.ts',
|
|
210
|
+
line: 50,
|
|
211
|
+
title: 'Code Style',
|
|
212
|
+
description: 'Inconsistent indentation',
|
|
213
|
+
contentHash: generateContentHash('Code Style', 'Inconsistent indentation'),
|
|
214
|
+
isWarden: false,
|
|
215
|
+
},
|
|
216
|
+
];
|
|
217
|
+
const result = await deduplicateFindings([finding1, finding2, finding3], existingComments, {
|
|
218
|
+
hashOnly: true,
|
|
219
|
+
});
|
|
220
|
+
expect(result.newFindings).toHaveLength(1);
|
|
221
|
+
expect(result.newFindings[0].id).toBe('f2');
|
|
222
|
+
expect(result.duplicateActions).toHaveLength(2);
|
|
223
|
+
// First should be update_warden (isWarden: true)
|
|
224
|
+
expect(result.duplicateActions[0].type).toBe('update_warden');
|
|
225
|
+
// Second should be react_external (isWarden: false)
|
|
226
|
+
expect(result.duplicateActions[1].type).toBe('react_external');
|
|
227
|
+
});
|
|
228
|
+
it('works without API key (hash-only mode)', async () => {
|
|
229
|
+
const findings = [baseFinding];
|
|
230
|
+
const existingComments = [];
|
|
231
|
+
const result = await deduplicateFindings(findings, existingComments, {});
|
|
232
|
+
expect(result.newFindings).toHaveLength(1);
|
|
233
|
+
});
|
|
234
|
+
});
|
|
235
|
+
describe('parseWardenSkills', () => {
|
|
236
|
+
it('parses single skill', () => {
|
|
237
|
+
const body = `**:warning: Issue**\n\nDescription\n\n---\n<sub>warden: security-review</sub>`;
|
|
238
|
+
expect(parseWardenSkills(body)).toEqual(['security-review']);
|
|
239
|
+
});
|
|
240
|
+
it('parses multiple skills', () => {
|
|
241
|
+
const body = `**:warning: Issue**\n\nDescription\n\n---\n<sub>warden: security-review, code-quality, performance</sub>`;
|
|
242
|
+
expect(parseWardenSkills(body)).toEqual(['security-review', 'code-quality', 'performance']);
|
|
243
|
+
});
|
|
244
|
+
it('handles extra whitespace', () => {
|
|
245
|
+
const body = `<sub>warden: skill1 , skill2 </sub>`;
|
|
246
|
+
expect(parseWardenSkills(body)).toEqual(['skill1', 'skill2']);
|
|
247
|
+
});
|
|
248
|
+
it('returns empty array for non-Warden comment', () => {
|
|
249
|
+
const body = 'Regular comment without attribution';
|
|
250
|
+
expect(parseWardenSkills(body)).toEqual([]);
|
|
251
|
+
});
|
|
252
|
+
});
|
|
253
|
+
describe('updateWardenCommentBody', () => {
|
|
254
|
+
it('adds new skill to attribution', () => {
|
|
255
|
+
const body = `**:warning: Issue**\n\nDescription\n\n---\n<sub>warden: skill1</sub>`;
|
|
256
|
+
const result = updateWardenCommentBody(body, 'skill2');
|
|
257
|
+
expect(result).toContain('<sub>warden: skill1, skill2</sub>');
|
|
258
|
+
});
|
|
259
|
+
it('returns null if skill already listed', () => {
|
|
260
|
+
const body = `<sub>warden: skill1, skill2</sub>`;
|
|
261
|
+
const result = updateWardenCommentBody(body, 'skill1');
|
|
262
|
+
expect(result).toBeNull();
|
|
263
|
+
});
|
|
264
|
+
it('preserves rest of comment body', () => {
|
|
265
|
+
const body = `**:warning: SQL Injection**\n\nUser input passed to query\n\n---\n<sub>warden: security-review</sub>\n<!-- warden:v1:file.ts:10:abc123 -->`;
|
|
266
|
+
const result = updateWardenCommentBody(body, 'code-quality');
|
|
267
|
+
expect(result).toContain('**:warning: SQL Injection**');
|
|
268
|
+
expect(result).toContain('User input passed to query');
|
|
269
|
+
expect(result).toContain('<sub>warden: security-review, code-quality</sub>');
|
|
270
|
+
expect(result).toContain('<!-- warden:v1:file.ts:10:abc123 -->');
|
|
271
|
+
});
|
|
272
|
+
});
|
|
273
|
+
describe('findingToExistingComment', () => {
|
|
274
|
+
it('converts finding with location to ExistingComment', () => {
|
|
275
|
+
const finding = {
|
|
276
|
+
id: 'f1',
|
|
277
|
+
severity: 'high',
|
|
278
|
+
title: 'SQL Injection',
|
|
279
|
+
description: 'User input passed to query',
|
|
280
|
+
location: {
|
|
281
|
+
path: 'src/db.ts',
|
|
282
|
+
startLine: 42,
|
|
283
|
+
endLine: 45,
|
|
284
|
+
},
|
|
285
|
+
};
|
|
286
|
+
const comment = findingToExistingComment(finding);
|
|
287
|
+
expect(comment).toEqual({
|
|
288
|
+
id: -1,
|
|
289
|
+
path: 'src/db.ts',
|
|
290
|
+
line: 45,
|
|
291
|
+
title: 'SQL Injection',
|
|
292
|
+
description: 'User input passed to query',
|
|
293
|
+
contentHash: generateContentHash('SQL Injection', 'User input passed to query'),
|
|
294
|
+
isWarden: true,
|
|
295
|
+
skills: [],
|
|
296
|
+
});
|
|
297
|
+
});
|
|
298
|
+
it('includes skill when provided', () => {
|
|
299
|
+
const finding = {
|
|
300
|
+
id: 'f1',
|
|
301
|
+
severity: 'high',
|
|
302
|
+
title: 'SQL Injection',
|
|
303
|
+
description: 'User input passed to query',
|
|
304
|
+
location: {
|
|
305
|
+
path: 'src/db.ts',
|
|
306
|
+
startLine: 42,
|
|
307
|
+
},
|
|
308
|
+
};
|
|
309
|
+
const comment = findingToExistingComment(finding, 'security-review');
|
|
310
|
+
expect(comment).not.toBeNull();
|
|
311
|
+
expect(comment.isWarden).toBe(true);
|
|
312
|
+
expect(comment.skills).toEqual(['security-review']);
|
|
313
|
+
});
|
|
314
|
+
it('uses startLine when endLine is not set', () => {
|
|
315
|
+
const finding = {
|
|
316
|
+
id: 'f1',
|
|
317
|
+
severity: 'medium',
|
|
318
|
+
title: 'Missing Error Handling',
|
|
319
|
+
description: 'No try-catch block',
|
|
320
|
+
location: {
|
|
321
|
+
path: 'src/api.ts',
|
|
322
|
+
startLine: 100,
|
|
323
|
+
},
|
|
324
|
+
};
|
|
325
|
+
const comment = findingToExistingComment(finding);
|
|
326
|
+
expect(comment).not.toBeNull();
|
|
327
|
+
expect(comment.line).toBe(100);
|
|
328
|
+
});
|
|
329
|
+
it('returns null for finding without location', () => {
|
|
330
|
+
const finding = {
|
|
331
|
+
id: 'f1',
|
|
332
|
+
severity: 'low',
|
|
333
|
+
title: 'General Issue',
|
|
334
|
+
description: 'Some general finding',
|
|
335
|
+
};
|
|
336
|
+
const comment = findingToExistingComment(finding);
|
|
337
|
+
expect(comment).toBeNull();
|
|
338
|
+
});
|
|
339
|
+
});
|
|
340
|
+
describe('renderer marker integration', () => {
|
|
341
|
+
it('marker can be parsed after being generated', () => {
|
|
342
|
+
const path = 'src/db.ts';
|
|
343
|
+
const line = 42;
|
|
344
|
+
const hash = generateContentHash('SQL Injection', 'User input passed to query');
|
|
345
|
+
const marker = generateMarker(path, line, hash);
|
|
346
|
+
const body = `**:warning: SQL Injection**
|
|
347
|
+
|
|
348
|
+
User input passed to query
|
|
349
|
+
|
|
350
|
+
---
|
|
351
|
+
<sub>warden: security-review</sub>
|
|
352
|
+
${marker}`;
|
|
353
|
+
const parsed = parseMarker(body);
|
|
354
|
+
expect(parsed).toEqual({ path, line, contentHash: hash });
|
|
355
|
+
});
|
|
356
|
+
});
|
|
357
|
+
//# sourceMappingURL=dedup.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dedup.test.js","sourceRoot":"","sources":["../../src/output/dedup.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import type { Octokit } from '@octokit/rest';
|
|
2
|
+
import type { Severity, SeverityThreshold, Finding, SkillReport, UsageStats } from '../types/index.js';
|
|
3
|
+
/**
|
|
4
|
+
* GitHub Check annotation for inline code comments.
|
|
5
|
+
*/
|
|
6
|
+
export interface CheckAnnotation {
|
|
7
|
+
path: string;
|
|
8
|
+
start_line: number;
|
|
9
|
+
end_line: number;
|
|
10
|
+
annotation_level: 'failure' | 'warning' | 'notice';
|
|
11
|
+
message: string;
|
|
12
|
+
title?: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Possible conclusions for a GitHub Check run.
|
|
16
|
+
*/
|
|
17
|
+
export type CheckConclusion = 'success' | 'failure' | 'neutral' | 'cancelled';
|
|
18
|
+
/**
|
|
19
|
+
* Options for creating/updating checks.
|
|
20
|
+
*/
|
|
21
|
+
export interface CheckOptions {
|
|
22
|
+
owner: string;
|
|
23
|
+
repo: string;
|
|
24
|
+
headSha: string;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Options for updating a skill check.
|
|
28
|
+
*/
|
|
29
|
+
export interface UpdateSkillCheckOptions extends CheckOptions {
|
|
30
|
+
failOn?: SeverityThreshold;
|
|
31
|
+
/** Only include findings at or above this severity level in annotations */
|
|
32
|
+
commentOn?: SeverityThreshold;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Summary data for the core warden check.
|
|
36
|
+
*/
|
|
37
|
+
export interface CoreCheckSummaryData {
|
|
38
|
+
totalSkills: number;
|
|
39
|
+
totalFindings: number;
|
|
40
|
+
findingsBySeverity: Record<Severity, number>;
|
|
41
|
+
totalDurationMs?: number;
|
|
42
|
+
totalUsage?: UsageStats;
|
|
43
|
+
/** All findings from all skills */
|
|
44
|
+
findings: Finding[];
|
|
45
|
+
skillResults: {
|
|
46
|
+
name: string;
|
|
47
|
+
findingCount: number;
|
|
48
|
+
conclusion: CheckConclusion;
|
|
49
|
+
durationMs?: number;
|
|
50
|
+
usage?: UsageStats;
|
|
51
|
+
}[];
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Result from creating a check run.
|
|
55
|
+
*/
|
|
56
|
+
export interface CreateCheckResult {
|
|
57
|
+
checkRunId: number;
|
|
58
|
+
url: string;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Map severity levels to GitHub annotation levels.
|
|
62
|
+
* critical/high -> failure, medium -> warning, low/info -> notice
|
|
63
|
+
*/
|
|
64
|
+
export declare function severityToAnnotationLevel(severity: Severity): CheckAnnotation['annotation_level'];
|
|
65
|
+
/**
|
|
66
|
+
* Convert findings to GitHub Check annotations.
|
|
67
|
+
* Only findings with locations can be converted to annotations.
|
|
68
|
+
* Returns at most MAX_ANNOTATIONS_PER_REQUEST annotations.
|
|
69
|
+
* If commentOn is specified, only include findings at or above that severity.
|
|
70
|
+
*/
|
|
71
|
+
export declare function findingsToAnnotations(findings: Finding[], commentOn?: SeverityThreshold): CheckAnnotation[];
|
|
72
|
+
/**
|
|
73
|
+
* Determine the check conclusion based on findings and failOn threshold.
|
|
74
|
+
* - No findings: success
|
|
75
|
+
* - Findings, none >= failOn: neutral
|
|
76
|
+
* - Findings >= failOn threshold: failure
|
|
77
|
+
*/
|
|
78
|
+
export declare function determineConclusion(findings: Finding[], failOn?: SeverityThreshold): CheckConclusion;
|
|
79
|
+
/**
|
|
80
|
+
* Create a check run for a skill.
|
|
81
|
+
* The check is created with status: in_progress.
|
|
82
|
+
*/
|
|
83
|
+
export declare function createSkillCheck(octokit: Octokit, skillName: string, options: CheckOptions): Promise<CreateCheckResult>;
|
|
84
|
+
/**
|
|
85
|
+
* Update a skill check with results.
|
|
86
|
+
* Completes the check with conclusion, summary, and annotations.
|
|
87
|
+
*/
|
|
88
|
+
export declare function updateSkillCheck(octokit: Octokit, checkRunId: number, report: SkillReport, options: UpdateSkillCheckOptions): Promise<void>;
|
|
89
|
+
/**
|
|
90
|
+
* Mark a skill check as failed due to execution error.
|
|
91
|
+
*/
|
|
92
|
+
export declare function failSkillCheck(octokit: Octokit, checkRunId: number, error: unknown, options: CheckOptions): Promise<void>;
|
|
93
|
+
/**
|
|
94
|
+
* Create the core warden check run.
|
|
95
|
+
* The check is created with status: in_progress.
|
|
96
|
+
*/
|
|
97
|
+
export declare function createCoreCheck(octokit: Octokit, options: CheckOptions): Promise<CreateCheckResult>;
|
|
98
|
+
/**
|
|
99
|
+
* Update the core warden check with overall summary.
|
|
100
|
+
*/
|
|
101
|
+
export declare function updateCoreCheck(octokit: Octokit, checkRunId: number, summaryData: CoreCheckSummaryData, conclusion: CheckConclusion, options: Omit<CheckOptions, 'headSha'>): Promise<void>;
|
|
102
|
+
/**
|
|
103
|
+
* Aggregate severity counts from multiple reports.
|
|
104
|
+
*/
|
|
105
|
+
export declare function aggregateSeverityCounts(reports: SkillReport[]): Record<Severity, number>;
|
|
106
|
+
//# sourceMappingURL=github-checks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"github-checks.d.ts","sourceRoot":"","sources":["../../src/output/github-checks.ts"],"names":[],"mappings":"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"}
|