@sentry/warden 0.1.0 → 0.2.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.
Files changed (588) hide show
  1. package/dist/cli/commands/init.d.ts.map +1 -1
  2. package/dist/cli/commands/init.js +3 -1
  3. package/dist/cli/commands/init.js.map +1 -1
  4. package/dist/cli/commands/setup-app/manifest.d.ts.map +1 -1
  5. package/dist/cli/commands/setup-app/manifest.js +3 -1
  6. package/dist/cli/commands/setup-app/manifest.js.map +1 -1
  7. package/dist/cli/commands/setup-app.js +1 -1
  8. package/dist/cli/commands/setup-app.js.map +1 -1
  9. package/dist/cli/files.d.ts +11 -1
  10. package/dist/cli/files.d.ts.map +1 -1
  11. package/dist/cli/files.js +145 -4
  12. package/dist/cli/files.js.map +1 -1
  13. package/dist/cli/git.d.ts.map +1 -1
  14. package/dist/cli/git.js +5 -9
  15. package/dist/cli/git.js.map +1 -1
  16. package/dist/cli/index.js +0 -0
  17. package/dist/cli/output/icons.d.ts +4 -0
  18. package/dist/cli/output/icons.d.ts.map +1 -1
  19. package/dist/cli/output/icons.js +4 -0
  20. package/dist/cli/output/icons.js.map +1 -1
  21. package/dist/cli/output/ink-runner.d.ts +20 -0
  22. package/dist/cli/output/ink-runner.d.ts.map +1 -1
  23. package/dist/cli/output/ink-runner.js +53 -19
  24. package/dist/cli/output/ink-runner.js.map +1 -1
  25. package/dist/cli/output/tasks.d.ts.map +1 -1
  26. package/dist/cli/output/tasks.js +5 -1
  27. package/dist/cli/output/tasks.js.map +1 -1
  28. package/dist/config/schema.d.ts.map +1 -1
  29. package/dist/config/schema.js +15 -1
  30. package/dist/config/schema.js.map +1 -1
  31. package/dist/diff/coalesce.d.ts +32 -2
  32. package/dist/diff/coalesce.d.ts.map +1 -1
  33. package/dist/diff/coalesce.js +174 -2
  34. package/dist/diff/coalesce.js.map +1 -1
  35. package/dist/output/dedup.d.ts.map +1 -1
  36. package/dist/output/dedup.js +8 -3
  37. package/dist/output/dedup.js.map +1 -1
  38. package/dist/output/renderer.d.ts.map +1 -1
  39. package/dist/output/renderer.js +49 -5
  40. package/dist/output/renderer.js.map +1 -1
  41. package/dist/output/stale.d.ts.map +1 -1
  42. package/dist/output/stale.js +7 -0
  43. package/dist/output/stale.js.map +1 -1
  44. package/dist/output/types.d.ts +15 -1
  45. package/dist/output/types.d.ts.map +1 -1
  46. package/dist/sdk/analyze.d.ts +18 -0
  47. package/dist/sdk/analyze.d.ts.map +1 -0
  48. package/dist/sdk/analyze.js +425 -0
  49. package/dist/sdk/analyze.js.map +1 -0
  50. package/dist/sdk/errors.d.ts +23 -0
  51. package/dist/sdk/errors.d.ts.map +1 -0
  52. package/dist/sdk/errors.js +72 -0
  53. package/dist/sdk/errors.js.map +1 -0
  54. package/dist/sdk/extract.d.ts +44 -0
  55. package/dist/sdk/extract.d.ts.map +1 -0
  56. package/dist/sdk/extract.js +224 -0
  57. package/dist/sdk/extract.js.map +1 -0
  58. package/dist/sdk/prepare.d.ts +13 -0
  59. package/dist/sdk/prepare.d.ts.map +1 -0
  60. package/dist/sdk/prepare.js +73 -0
  61. package/dist/sdk/prepare.js.map +1 -0
  62. package/dist/sdk/prompt.d.ts +30 -0
  63. package/dist/sdk/prompt.d.ts.map +1 -0
  64. package/dist/sdk/prompt.js +109 -0
  65. package/dist/sdk/prompt.js.map +1 -0
  66. package/dist/sdk/retry.d.ts +12 -0
  67. package/dist/sdk/retry.d.ts.map +1 -0
  68. package/dist/sdk/retry.js +31 -0
  69. package/dist/sdk/retry.js.map +1 -0
  70. package/dist/sdk/runner.d.ts +22 -199
  71. package/dist/sdk/runner.d.ts.map +1 -1
  72. package/dist/sdk/runner.js +26 -884
  73. package/dist/sdk/runner.js.map +1 -1
  74. package/dist/sdk/types.d.ts +127 -0
  75. package/dist/sdk/types.d.ts.map +1 -0
  76. package/dist/sdk/types.js +5 -0
  77. package/dist/sdk/types.js.map +1 -0
  78. package/dist/sdk/usage.d.ts +20 -0
  79. package/dist/sdk/usage.d.ts.map +1 -0
  80. package/dist/sdk/usage.js +44 -0
  81. package/dist/sdk/usage.js.map +1 -0
  82. package/dist/skills/remote.d.ts.map +1 -1
  83. package/dist/skills/remote.js +3 -7
  84. package/dist/skills/remote.js.map +1 -1
  85. package/dist/types/index.d.ts +1 -0
  86. package/dist/types/index.d.ts.map +1 -1
  87. package/dist/types/index.js +2 -0
  88. package/dist/types/index.js.map +1 -1
  89. package/dist/utils/exec.d.ts +61 -0
  90. package/dist/utils/exec.d.ts.map +1 -0
  91. package/dist/utils/exec.js +111 -0
  92. package/dist/utils/exec.js.map +1 -0
  93. package/dist/utils/index.d.ts +2 -0
  94. package/dist/utils/index.d.ts.map +1 -1
  95. package/dist/utils/index.js +1 -0
  96. package/dist/utils/index.js.map +1 -1
  97. package/package.json +15 -16
  98. package/.agents/skills/find-bugs/SKILL.md +0 -75
  99. package/.agents/skills/vercel-react-best-practices/AGENTS.md +0 -2934
  100. package/.agents/skills/vercel-react-best-practices/SKILL.md +0 -136
  101. package/.agents/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +0 -55
  102. package/.agents/skills/vercel-react-best-practices/rules/advanced-init-once.md +0 -42
  103. package/.agents/skills/vercel-react-best-practices/rules/advanced-use-latest.md +0 -39
  104. package/.agents/skills/vercel-react-best-practices/rules/async-api-routes.md +0 -38
  105. package/.agents/skills/vercel-react-best-practices/rules/async-defer-await.md +0 -80
  106. package/.agents/skills/vercel-react-best-practices/rules/async-dependencies.md +0 -51
  107. package/.agents/skills/vercel-react-best-practices/rules/async-parallel.md +0 -28
  108. package/.agents/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +0 -99
  109. package/.agents/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +0 -59
  110. package/.agents/skills/vercel-react-best-practices/rules/bundle-conditional.md +0 -31
  111. package/.agents/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +0 -49
  112. package/.agents/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +0 -35
  113. package/.agents/skills/vercel-react-best-practices/rules/bundle-preload.md +0 -50
  114. package/.agents/skills/vercel-react-best-practices/rules/client-event-listeners.md +0 -74
  115. package/.agents/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +0 -71
  116. package/.agents/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +0 -48
  117. package/.agents/skills/vercel-react-best-practices/rules/client-swr-dedup.md +0 -56
  118. package/.agents/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +0 -107
  119. package/.agents/skills/vercel-react-best-practices/rules/js-cache-function-results.md +0 -80
  120. package/.agents/skills/vercel-react-best-practices/rules/js-cache-property-access.md +0 -28
  121. package/.agents/skills/vercel-react-best-practices/rules/js-cache-storage.md +0 -70
  122. package/.agents/skills/vercel-react-best-practices/rules/js-combine-iterations.md +0 -32
  123. package/.agents/skills/vercel-react-best-practices/rules/js-early-exit.md +0 -50
  124. package/.agents/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +0 -45
  125. package/.agents/skills/vercel-react-best-practices/rules/js-index-maps.md +0 -37
  126. package/.agents/skills/vercel-react-best-practices/rules/js-length-check-first.md +0 -49
  127. package/.agents/skills/vercel-react-best-practices/rules/js-min-max-loop.md +0 -82
  128. package/.agents/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +0 -24
  129. package/.agents/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +0 -57
  130. package/.agents/skills/vercel-react-best-practices/rules/rendering-activity.md +0 -26
  131. package/.agents/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +0 -47
  132. package/.agents/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +0 -40
  133. package/.agents/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +0 -38
  134. package/.agents/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +0 -46
  135. package/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +0 -82
  136. package/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +0 -30
  137. package/.agents/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +0 -28
  138. package/.agents/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +0 -75
  139. package/.agents/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +0 -39
  140. package/.agents/skills/vercel-react-best-practices/rules/rerender-dependencies.md +0 -45
  141. package/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +0 -40
  142. package/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state.md +0 -29
  143. package/.agents/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +0 -74
  144. package/.agents/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +0 -58
  145. package/.agents/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +0 -38
  146. package/.agents/skills/vercel-react-best-practices/rules/rerender-memo.md +0 -44
  147. package/.agents/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +0 -45
  148. package/.agents/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +0 -35
  149. package/.agents/skills/vercel-react-best-practices/rules/rerender-transitions.md +0 -40
  150. package/.agents/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +0 -73
  151. package/.agents/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +0 -73
  152. package/.agents/skills/vercel-react-best-practices/rules/server-auth-actions.md +0 -96
  153. package/.agents/skills/vercel-react-best-practices/rules/server-cache-lru.md +0 -41
  154. package/.agents/skills/vercel-react-best-practices/rules/server-cache-react.md +0 -76
  155. package/.agents/skills/vercel-react-best-practices/rules/server-dedup-props.md +0 -65
  156. package/.agents/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +0 -83
  157. package/.agents/skills/vercel-react-best-practices/rules/server-serialization.md +0 -38
  158. package/.claude/settings.json +0 -57
  159. package/.claude/skills/agent-prompt/SKILL.md +0 -54
  160. package/.claude/skills/agent-prompt/references/agentic-patterns.md +0 -94
  161. package/.claude/skills/agent-prompt/references/anti-patterns.md +0 -140
  162. package/.claude/skills/agent-prompt/references/context-design.md +0 -124
  163. package/.claude/skills/agent-prompt/references/core-principles.md +0 -75
  164. package/.claude/skills/agent-prompt/references/model-guidance.md +0 -118
  165. package/.claude/skills/agent-prompt/references/output-formats.md +0 -98
  166. package/.claude/skills/agent-prompt/references/skill-structure.md +0 -115
  167. package/.claude/skills/agent-prompt/references/system-prompts.md +0 -115
  168. package/.claude/skills/notseer/SKILL.md +0 -131
  169. package/.claude/skills/skill-writer/SKILL.md +0 -140
  170. package/.claude/skills/testing-guidelines/SKILL.md +0 -132
  171. package/.claude/skills/warden-skill/SKILL.md +0 -250
  172. package/.claude/skills/warden-skill/references/config-schema.md +0 -133
  173. package/.dex/config.toml +0 -2
  174. package/.github/workflows/ci.yml +0 -33
  175. package/.github/workflows/release.yml +0 -59
  176. package/.github/workflows/warden.yml +0 -40
  177. package/AGENTS.md +0 -89
  178. package/CONTRIBUTING.md +0 -60
  179. package/SPEC.md +0 -263
  180. package/action.yml +0 -87
  181. package/assets/favicon.png +0 -0
  182. package/assets/warden-icon-bw.svg +0 -5
  183. package/assets/warden-icon-purple.png +0 -0
  184. package/assets/warden-icon-purple.svg +0 -5
  185. package/dist/action/159.index.js +0 -523
  186. package/dist/action/159.index.js.map +0 -1
  187. package/dist/action/action/index.d.ts +0 -2
  188. package/dist/action/action/index.d.ts.map +0 -1
  189. package/dist/action/action/main.d.ts +0 -2
  190. package/dist/action/action/main.d.ts.map +0 -1
  191. package/dist/action/cli/args.d.ts +0 -74
  192. package/dist/action/cli/args.d.ts.map +0 -1
  193. package/dist/action/cli/args.test.d.ts +0 -2
  194. package/dist/action/cli/args.test.d.ts.map +0 -1
  195. package/dist/action/cli/commands/add.d.ts +0 -7
  196. package/dist/action/cli/commands/add.d.ts.map +0 -1
  197. package/dist/action/cli/commands/init.d.ts +0 -10
  198. package/dist/action/cli/commands/init.d.ts.map +0 -1
  199. package/dist/action/cli/commands/init.test.d.ts +0 -2
  200. package/dist/action/cli/commands/init.test.d.ts.map +0 -1
  201. package/dist/action/cli/commands/setup-app/browser.d.ts +0 -9
  202. package/dist/action/cli/commands/setup-app/browser.d.ts.map +0 -1
  203. package/dist/action/cli/commands/setup-app/credentials.d.ts +0 -15
  204. package/dist/action/cli/commands/setup-app/credentials.d.ts.map +0 -1
  205. package/dist/action/cli/commands/setup-app/manifest.d.ts +0 -24
  206. package/dist/action/cli/commands/setup-app/manifest.d.ts.map +0 -1
  207. package/dist/action/cli/commands/setup-app/server.d.ts +0 -28
  208. package/dist/action/cli/commands/setup-app/server.d.ts.map +0 -1
  209. package/dist/action/cli/commands/setup-app.d.ts +0 -11
  210. package/dist/action/cli/commands/setup-app.d.ts.map +0 -1
  211. package/dist/action/cli/commands/sync.d.ts +0 -9
  212. package/dist/action/cli/commands/sync.d.ts.map +0 -1
  213. package/dist/action/cli/context.d.ts +0 -27
  214. package/dist/action/cli/context.d.ts.map +0 -1
  215. package/dist/action/cli/files.d.ts +0 -22
  216. package/dist/action/cli/files.d.ts.map +0 -1
  217. package/dist/action/cli/files.test.d.ts +0 -2
  218. package/dist/action/cli/files.test.d.ts.map +0 -1
  219. package/dist/action/cli/fix.d.ts +0 -41
  220. package/dist/action/cli/fix.d.ts.map +0 -1
  221. package/dist/action/cli/fix.test.d.ts +0 -2
  222. package/dist/action/cli/fix.test.d.ts.map +0 -1
  223. package/dist/action/cli/git.d.ts +0 -73
  224. package/dist/action/cli/git.d.ts.map +0 -1
  225. package/dist/action/cli/git.test.d.ts +0 -2
  226. package/dist/action/cli/git.test.d.ts.map +0 -1
  227. package/dist/action/cli/index.d.ts +0 -3
  228. package/dist/action/cli/index.d.ts.map +0 -1
  229. package/dist/action/cli/main.d.ts +0 -7
  230. package/dist/action/cli/main.d.ts.map +0 -1
  231. package/dist/action/cli/output/box.d.ts +0 -75
  232. package/dist/action/cli/output/box.d.ts.map +0 -1
  233. package/dist/action/cli/output/formatters.d.ts +0 -90
  234. package/dist/action/cli/output/formatters.d.ts.map +0 -1
  235. package/dist/action/cli/output/formatters.test.d.ts +0 -2
  236. package/dist/action/cli/output/formatters.test.d.ts.map +0 -1
  237. package/dist/action/cli/output/icons.d.ts +0 -11
  238. package/dist/action/cli/output/icons.d.ts.map +0 -1
  239. package/dist/action/cli/output/index.d.ts +0 -10
  240. package/dist/action/cli/output/index.d.ts.map +0 -1
  241. package/dist/action/cli/output/ink-runner.d.ts +0 -9
  242. package/dist/action/cli/output/ink-runner.d.ts.map +0 -1
  243. package/dist/action/cli/output/jsonl.d.ts +0 -43
  244. package/dist/action/cli/output/jsonl.d.ts.map +0 -1
  245. package/dist/action/cli/output/jsonl.test.d.ts +0 -2
  246. package/dist/action/cli/output/jsonl.test.d.ts.map +0 -1
  247. package/dist/action/cli/output/reporter.d.ts +0 -108
  248. package/dist/action/cli/output/reporter.d.ts.map +0 -1
  249. package/dist/action/cli/output/tasks.d.ts +0 -89
  250. package/dist/action/cli/output/tasks.d.ts.map +0 -1
  251. package/dist/action/cli/output/tty.d.ts +0 -21
  252. package/dist/action/cli/output/tty.d.ts.map +0 -1
  253. package/dist/action/cli/output/tty.test.d.ts +0 -2
  254. package/dist/action/cli/output/tty.test.d.ts.map +0 -1
  255. package/dist/action/cli/output/verbosity.d.ts +0 -20
  256. package/dist/action/cli/output/verbosity.d.ts.map +0 -1
  257. package/dist/action/cli/output/verbosity.test.d.ts +0 -2
  258. package/dist/action/cli/output/verbosity.test.d.ts.map +0 -1
  259. package/dist/action/cli/terminal.d.ts +0 -19
  260. package/dist/action/cli/terminal.d.ts.map +0 -1
  261. package/dist/action/cli/terminal.test.d.ts +0 -2
  262. package/dist/action/cli/terminal.test.d.ts.map +0 -1
  263. package/dist/action/config/index.d.ts +0 -4
  264. package/dist/action/config/index.d.ts.map +0 -1
  265. package/dist/action/config/loader.d.ts +0 -27
  266. package/dist/action/config/loader.d.ts.map +0 -1
  267. package/dist/action/config/loader.test.d.ts +0 -2
  268. package/dist/action/config/loader.test.d.ts.map +0 -1
  269. package/dist/action/config/schema.d.ts +0 -318
  270. package/dist/action/config/schema.d.ts.map +0 -1
  271. package/dist/action/config/writer.d.ts +0 -11
  272. package/dist/action/config/writer.d.ts.map +0 -1
  273. package/dist/action/config/writer.test.d.ts +0 -2
  274. package/dist/action/config/writer.test.d.ts.map +0 -1
  275. package/dist/action/diff/classify.d.ts +0 -29
  276. package/dist/action/diff/classify.d.ts.map +0 -1
  277. package/dist/action/diff/classify.test.d.ts +0 -2
  278. package/dist/action/diff/classify.test.d.ts.map +0 -1
  279. package/dist/action/diff/coalesce.d.ts +0 -42
  280. package/dist/action/diff/coalesce.d.ts.map +0 -1
  281. package/dist/action/diff/coalesce.test.d.ts +0 -2
  282. package/dist/action/diff/coalesce.test.d.ts.map +0 -1
  283. package/dist/action/diff/context.d.ts +0 -30
  284. package/dist/action/diff/context.d.ts.map +0 -1
  285. package/dist/action/diff/context.test.d.ts +0 -2
  286. package/dist/action/diff/context.test.d.ts.map +0 -1
  287. package/dist/action/diff/index.d.ts +0 -5
  288. package/dist/action/diff/index.d.ts.map +0 -1
  289. package/dist/action/diff/parser.d.ts +0 -52
  290. package/dist/action/diff/parser.d.ts.map +0 -1
  291. package/dist/action/diff/parser.test.d.ts +0 -2
  292. package/dist/action/diff/parser.test.d.ts.map +0 -1
  293. package/dist/action/event/context.d.ts +0 -9
  294. package/dist/action/event/context.d.ts.map +0 -1
  295. package/dist/action/event/index.d.ts +0 -3
  296. package/dist/action/event/index.d.ts.map +0 -1
  297. package/dist/action/event/schedule-context.d.ts +0 -30
  298. package/dist/action/event/schedule-context.d.ts.map +0 -1
  299. package/dist/action/examples/examples.integration.test.d.ts +0 -2
  300. package/dist/action/examples/examples.integration.test.d.ts.map +0 -1
  301. package/dist/action/examples/index.d.ts +0 -50
  302. package/dist/action/examples/index.d.ts.map +0 -1
  303. package/dist/action/examples/index.test.d.ts +0 -2
  304. package/dist/action/examples/index.test.d.ts.map +0 -1
  305. package/dist/action/examples/setup.d.ts +0 -2
  306. package/dist/action/examples/setup.d.ts.map +0 -1
  307. package/dist/action/index.d.ts +0 -11
  308. package/dist/action/index.d.ts.map +0 -1
  309. package/dist/action/index.js +0 -38231
  310. package/dist/action/index.js.map +0 -1
  311. package/dist/action/licenses.txt +0 -992
  312. package/dist/action/main.d.ts +0 -2
  313. package/dist/action/main.d.ts.map +0 -1
  314. package/dist/action/main.js +0 -707
  315. package/dist/action/main.js.map +0 -1
  316. package/dist/action/output/dedup.d.ts +0 -153
  317. package/dist/action/output/dedup.d.ts.map +0 -1
  318. package/dist/action/output/dedup.test.d.ts +0 -2
  319. package/dist/action/output/dedup.test.d.ts.map +0 -1
  320. package/dist/action/output/github-checks.d.ts +0 -106
  321. package/dist/action/output/github-checks.d.ts.map +0 -1
  322. package/dist/action/output/github-checks.test.d.ts +0 -2
  323. package/dist/action/output/github-checks.test.d.ts.map +0 -1
  324. package/dist/action/output/github-issues.d.ts +0 -35
  325. package/dist/action/output/github-issues.d.ts.map +0 -1
  326. package/dist/action/output/index.d.ts +0 -6
  327. package/dist/action/output/index.d.ts.map +0 -1
  328. package/dist/action/output/issue-renderer.d.ts +0 -20
  329. package/dist/action/output/issue-renderer.d.ts.map +0 -1
  330. package/dist/action/output/renderer.d.ts +0 -4
  331. package/dist/action/output/renderer.d.ts.map +0 -1
  332. package/dist/action/output/renderer.test.d.ts +0 -2
  333. package/dist/action/output/renderer.test.d.ts.map +0 -1
  334. package/dist/action/output/stale.d.ts +0 -31
  335. package/dist/action/output/stale.d.ts.map +0 -1
  336. package/dist/action/output/stale.test.d.ts +0 -2
  337. package/dist/action/output/stale.test.d.ts.map +0 -1
  338. package/dist/action/output/types.d.ts +0 -31
  339. package/dist/action/output/types.d.ts.map +0 -1
  340. package/dist/action/package.json +0 -3
  341. package/dist/action/sdk/index.d.ts +0 -2
  342. package/dist/action/sdk/index.d.ts.map +0 -1
  343. package/dist/action/sdk/runner.d.ts +0 -202
  344. package/dist/action/sdk/runner.d.ts.map +0 -1
  345. package/dist/action/sdk/runner.test.d.ts +0 -2
  346. package/dist/action/sdk/runner.test.d.ts.map +0 -1
  347. package/dist/action/skills/index.d.ts +0 -5
  348. package/dist/action/skills/index.d.ts.map +0 -1
  349. package/dist/action/skills/loader.d.ts +0 -111
  350. package/dist/action/skills/loader.d.ts.map +0 -1
  351. package/dist/action/skills/loader.test.d.ts +0 -2
  352. package/dist/action/skills/loader.test.d.ts.map +0 -1
  353. package/dist/action/skills/remote.d.ts +0 -117
  354. package/dist/action/skills/remote.d.ts.map +0 -1
  355. package/dist/action/skills/remote.test.d.ts +0 -2
  356. package/dist/action/skills/remote.test.d.ts.map +0 -1
  357. package/dist/action/sourcemap-register.cjs +0 -1
  358. package/dist/action/triggers/matcher.d.ts +0 -30
  359. package/dist/action/triggers/matcher.d.ts.map +0 -1
  360. package/dist/action/triggers/matcher.test.d.ts +0 -2
  361. package/dist/action/triggers/matcher.test.d.ts.map +0 -1
  362. package/dist/action/types/index.d.ts +0 -269
  363. package/dist/action/types/index.d.ts.map +0 -1
  364. package/dist/action/utils/async.d.ts +0 -5
  365. package/dist/action/utils/async.d.ts.map +0 -1
  366. package/dist/action/utils/index.d.ts +0 -16
  367. package/dist/action/utils/index.d.ts.map +0 -1
  368. package/dist/action/utils/index.test.d.ts +0 -2
  369. package/dist/action/utils/index.test.d.ts.map +0 -1
  370. package/dist/action/utils/version.d.ts +0 -3
  371. package/dist/action/utils/version.d.ts.map +0 -1
  372. package/dist/cli/args.test.d.ts +0 -2
  373. package/dist/cli/args.test.d.ts.map +0 -1
  374. package/dist/cli/args.test.js +0 -392
  375. package/dist/cli/args.test.js.map +0 -1
  376. package/dist/cli/commands/init.test.d.ts +0 -2
  377. package/dist/cli/commands/init.test.d.ts.map +0 -1
  378. package/dist/cli/commands/init.test.js +0 -117
  379. package/dist/cli/commands/init.test.js.map +0 -1
  380. package/dist/cli/files.test.d.ts +0 -2
  381. package/dist/cli/files.test.d.ts.map +0 -1
  382. package/dist/cli/files.test.js +0 -117
  383. package/dist/cli/files.test.js.map +0 -1
  384. package/dist/cli/fix.test.d.ts +0 -2
  385. package/dist/cli/fix.test.d.ts.map +0 -1
  386. package/dist/cli/fix.test.js +0 -251
  387. package/dist/cli/fix.test.js.map +0 -1
  388. package/dist/cli/git.test.d.ts +0 -2
  389. package/dist/cli/git.test.d.ts.map +0 -1
  390. package/dist/cli/git.test.js +0 -96
  391. package/dist/cli/git.test.js.map +0 -1
  392. package/dist/cli/output/formatters.test.d.ts +0 -2
  393. package/dist/cli/output/formatters.test.d.ts.map +0 -1
  394. package/dist/cli/output/formatters.test.js +0 -152
  395. package/dist/cli/output/formatters.test.js.map +0 -1
  396. package/dist/cli/output/jsonl.test.d.ts +0 -2
  397. package/dist/cli/output/jsonl.test.d.ts.map +0 -1
  398. package/dist/cli/output/jsonl.test.js +0 -284
  399. package/dist/cli/output/jsonl.test.js.map +0 -1
  400. package/dist/cli/output/tty.test.d.ts +0 -2
  401. package/dist/cli/output/tty.test.d.ts.map +0 -1
  402. package/dist/cli/output/tty.test.js +0 -105
  403. package/dist/cli/output/tty.test.js.map +0 -1
  404. package/dist/cli/output/verbosity.test.d.ts +0 -2
  405. package/dist/cli/output/verbosity.test.d.ts.map +0 -1
  406. package/dist/cli/output/verbosity.test.js +0 -35
  407. package/dist/cli/output/verbosity.test.js.map +0 -1
  408. package/dist/cli/terminal.test.d.ts +0 -2
  409. package/dist/cli/terminal.test.d.ts.map +0 -1
  410. package/dist/cli/terminal.test.js +0 -123
  411. package/dist/cli/terminal.test.js.map +0 -1
  412. package/dist/config/loader.test.d.ts +0 -2
  413. package/dist/config/loader.test.d.ts.map +0 -1
  414. package/dist/config/loader.test.js +0 -263
  415. package/dist/config/loader.test.js.map +0 -1
  416. package/dist/config/writer.test.d.ts +0 -2
  417. package/dist/config/writer.test.d.ts.map +0 -1
  418. package/dist/config/writer.test.js +0 -98
  419. package/dist/config/writer.test.js.map +0 -1
  420. package/dist/diff/classify.test.d.ts +0 -2
  421. package/dist/diff/classify.test.d.ts.map +0 -1
  422. package/dist/diff/classify.test.js +0 -140
  423. package/dist/diff/classify.test.js.map +0 -1
  424. package/dist/diff/coalesce.test.d.ts +0 -2
  425. package/dist/diff/coalesce.test.d.ts.map +0 -1
  426. package/dist/diff/coalesce.test.js +0 -159
  427. package/dist/diff/coalesce.test.js.map +0 -1
  428. package/dist/diff/context.test.d.ts +0 -2
  429. package/dist/diff/context.test.d.ts.map +0 -1
  430. package/dist/diff/context.test.js +0 -190
  431. package/dist/diff/context.test.js.map +0 -1
  432. package/dist/diff/parser.test.d.ts +0 -2
  433. package/dist/diff/parser.test.d.ts.map +0 -1
  434. package/dist/diff/parser.test.js +0 -178
  435. package/dist/diff/parser.test.js.map +0 -1
  436. package/dist/examples/examples.integration.test.d.ts +0 -2
  437. package/dist/examples/examples.integration.test.d.ts.map +0 -1
  438. package/dist/examples/examples.integration.test.js +0 -55
  439. package/dist/examples/examples.integration.test.js.map +0 -1
  440. package/dist/examples/index.test.d.ts +0 -2
  441. package/dist/examples/index.test.d.ts.map +0 -1
  442. package/dist/examples/index.test.js +0 -88
  443. package/dist/examples/index.test.js.map +0 -1
  444. package/dist/output/dedup.test.d.ts +0 -2
  445. package/dist/output/dedup.test.d.ts.map +0 -1
  446. package/dist/output/dedup.test.js +0 -357
  447. package/dist/output/dedup.test.js.map +0 -1
  448. package/dist/output/github-checks.test.d.ts +0 -2
  449. package/dist/output/github-checks.test.d.ts.map +0 -1
  450. package/dist/output/github-checks.test.js +0 -255
  451. package/dist/output/github-checks.test.js.map +0 -1
  452. package/dist/output/renderer.test.d.ts +0 -2
  453. package/dist/output/renderer.test.d.ts.map +0 -1
  454. package/dist/output/renderer.test.js +0 -645
  455. package/dist/output/renderer.test.js.map +0 -1
  456. package/dist/output/stale.test.d.ts +0 -2
  457. package/dist/output/stale.test.d.ts.map +0 -1
  458. package/dist/output/stale.test.js +0 -330
  459. package/dist/output/stale.test.js.map +0 -1
  460. package/dist/sdk/runner.test.d.ts +0 -2
  461. package/dist/sdk/runner.test.d.ts.map +0 -1
  462. package/dist/sdk/runner.test.js +0 -677
  463. package/dist/sdk/runner.test.js.map +0 -1
  464. package/dist/skills/loader.test.d.ts +0 -2
  465. package/dist/skills/loader.test.d.ts.map +0 -1
  466. package/dist/skills/loader.test.js +0 -241
  467. package/dist/skills/loader.test.js.map +0 -1
  468. package/dist/skills/remote.test.d.ts +0 -2
  469. package/dist/skills/remote.test.d.ts.map +0 -1
  470. package/dist/skills/remote.test.js +0 -582
  471. package/dist/skills/remote.test.js.map +0 -1
  472. package/dist/triggers/matcher.test.d.ts +0 -2
  473. package/dist/triggers/matcher.test.d.ts.map +0 -1
  474. package/dist/triggers/matcher.test.js +0 -234
  475. package/dist/triggers/matcher.test.js.map +0 -1
  476. package/dist/utils/index.test.d.ts +0 -2
  477. package/dist/utils/index.test.d.ts.map +0 -1
  478. package/dist/utils/index.test.js +0 -68
  479. package/dist/utils/index.test.js.map +0 -1
  480. package/docs/astro.config.mjs +0 -43
  481. package/docs/package.json +0 -19
  482. package/docs/pnpm-lock.yaml +0 -4000
  483. package/docs/public/favicon.svg +0 -5
  484. package/docs/src/components/Code.astro +0 -141
  485. package/docs/src/components/PackageManagerTabs.astro +0 -183
  486. package/docs/src/components/Terminal.astro +0 -212
  487. package/docs/src/layouts/Base.astro +0 -380
  488. package/docs/src/pages/cli.astro +0 -167
  489. package/docs/src/pages/config.astro +0 -395
  490. package/docs/src/pages/guide.astro +0 -450
  491. package/docs/src/pages/index.astro +0 -490
  492. package/docs/src/styles/global.css +0 -551
  493. package/docs/src/utils/version.ts +0 -6
  494. package/docs/tsconfig.json +0 -3
  495. package/docs/vercel.json +0 -5
  496. package/eslint.config.js +0 -33
  497. package/src/action/index.ts +0 -1
  498. package/src/action/main.ts +0 -868
  499. package/src/cli/args.test.ts +0 -477
  500. package/src/cli/args.ts +0 -414
  501. package/src/cli/commands/add.ts +0 -447
  502. package/src/cli/commands/init.test.ts +0 -137
  503. package/src/cli/commands/init.ts +0 -134
  504. package/src/cli/commands/setup-app/browser.ts +0 -38
  505. package/src/cli/commands/setup-app/credentials.ts +0 -45
  506. package/src/cli/commands/setup-app/manifest.ts +0 -48
  507. package/src/cli/commands/setup-app/server.ts +0 -172
  508. package/src/cli/commands/setup-app.ts +0 -156
  509. package/src/cli/commands/sync.ts +0 -114
  510. package/src/cli/context.ts +0 -131
  511. package/src/cli/files.test.ts +0 -155
  512. package/src/cli/files.ts +0 -89
  513. package/src/cli/fix.test.ts +0 -310
  514. package/src/cli/fix.ts +0 -387
  515. package/src/cli/git.test.ts +0 -119
  516. package/src/cli/git.ts +0 -318
  517. package/src/cli/index.ts +0 -14
  518. package/src/cli/main.ts +0 -672
  519. package/src/cli/output/box.ts +0 -235
  520. package/src/cli/output/formatters.test.ts +0 -187
  521. package/src/cli/output/formatters.ts +0 -269
  522. package/src/cli/output/icons.ts +0 -13
  523. package/src/cli/output/index.ts +0 -44
  524. package/src/cli/output/ink-runner.tsx +0 -337
  525. package/src/cli/output/jsonl.test.ts +0 -347
  526. package/src/cli/output/jsonl.ts +0 -126
  527. package/src/cli/output/reporter.ts +0 -434
  528. package/src/cli/output/tasks.ts +0 -374
  529. package/src/cli/output/tty.test.ts +0 -117
  530. package/src/cli/output/tty.ts +0 -60
  531. package/src/cli/output/verbosity.test.ts +0 -40
  532. package/src/cli/output/verbosity.ts +0 -31
  533. package/src/cli/terminal.test.ts +0 -148
  534. package/src/cli/terminal.ts +0 -301
  535. package/src/config/index.ts +0 -3
  536. package/src/config/loader.test.ts +0 -313
  537. package/src/config/loader.ts +0 -103
  538. package/src/config/schema.ts +0 -168
  539. package/src/config/writer.test.ts +0 -119
  540. package/src/config/writer.ts +0 -84
  541. package/src/diff/classify.test.ts +0 -162
  542. package/src/diff/classify.ts +0 -92
  543. package/src/diff/coalesce.test.ts +0 -208
  544. package/src/diff/coalesce.ts +0 -133
  545. package/src/diff/context.test.ts +0 -226
  546. package/src/diff/context.ts +0 -201
  547. package/src/diff/index.ts +0 -4
  548. package/src/diff/parser.test.ts +0 -212
  549. package/src/diff/parser.ts +0 -149
  550. package/src/event/context.ts +0 -132
  551. package/src/event/index.ts +0 -2
  552. package/src/event/schedule-context.ts +0 -101
  553. package/src/examples/examples.integration.test.ts +0 -66
  554. package/src/examples/index.test.ts +0 -101
  555. package/src/examples/index.ts +0 -122
  556. package/src/examples/setup.ts +0 -25
  557. package/src/index.ts +0 -115
  558. package/src/output/dedup.test.ts +0 -419
  559. package/src/output/dedup.ts +0 -607
  560. package/src/output/github-checks.test.ts +0 -300
  561. package/src/output/github-checks.ts +0 -476
  562. package/src/output/github-issues.ts +0 -329
  563. package/src/output/index.ts +0 -5
  564. package/src/output/issue-renderer.ts +0 -197
  565. package/src/output/renderer.test.ts +0 -727
  566. package/src/output/renderer.ts +0 -217
  567. package/src/output/stale.test.ts +0 -375
  568. package/src/output/stale.ts +0 -155
  569. package/src/output/types.ts +0 -34
  570. package/src/sdk/index.ts +0 -1
  571. package/src/sdk/runner.test.ts +0 -806
  572. package/src/sdk/runner.ts +0 -1232
  573. package/src/skills/index.ts +0 -36
  574. package/src/skills/loader.test.ts +0 -300
  575. package/src/skills/loader.ts +0 -423
  576. package/src/skills/remote.test.ts +0 -704
  577. package/src/skills/remote.ts +0 -604
  578. package/src/triggers/matcher.test.ts +0 -277
  579. package/src/triggers/matcher.ts +0 -152
  580. package/src/types/index.ts +0 -194
  581. package/src/utils/async.ts +0 -18
  582. package/src/utils/index.test.ts +0 -84
  583. package/src/utils/index.ts +0 -51
  584. package/src/utils/version.ts +0 -17
  585. package/tsconfig.json +0 -25
  586. package/vitest.config.ts +0 -8
  587. package/vitest.integration.config.ts +0 -11
  588. package/warden.toml +0 -19
@@ -1,477 +0,0 @@
1
- import { existsSync } from 'node:fs';
2
- import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
3
- import { parseCliArgs, CLIOptionsSchema, detectTargetType, classifyTargets } from './args.js';
4
-
5
- vi.mock('node:fs', async () => {
6
- const actual = await vi.importActual('node:fs');
7
- return {
8
- ...actual,
9
- existsSync: vi.fn(() => false),
10
- };
11
- });
12
-
13
- describe('parseCliArgs', () => {
14
- const originalExit = process.exit;
15
- const originalError = console.error;
16
-
17
- beforeEach(() => {
18
- process.exit = vi.fn() as never;
19
- console.error = vi.fn();
20
- });
21
-
22
- afterEach(() => {
23
- process.exit = originalExit;
24
- console.error = originalError;
25
- });
26
-
27
- it('parses with no arguments', () => {
28
- const result = parseCliArgs([]);
29
- expect(result.command).toBe('run');
30
- expect(result.options.targets).toBeUndefined();
31
- });
32
-
33
- it('parses file target with skill', () => {
34
- const result = parseCliArgs(['src/auth.ts', '--skill', 'security-review']);
35
- expect(result.options.targets).toEqual(['src/auth.ts']);
36
- expect(result.options.skill).toBe('security-review');
37
- });
38
-
39
- it('parses multiple file targets', () => {
40
- const result = parseCliArgs(['file1.ts', 'file2.ts', '--skill', 'security-review']);
41
- expect(result.options.targets).toEqual(['file1.ts', 'file2.ts']);
42
- });
43
-
44
- it('parses glob pattern', () => {
45
- const result = parseCliArgs(['src/**/*.ts', '--skill', 'security-review']);
46
- expect(result.options.targets).toEqual(['src/**/*.ts']);
47
- });
48
-
49
- it('parses git ref target', () => {
50
- const result = parseCliArgs(['HEAD~3', '--skill', 'security-review']);
51
- expect(result.options.targets).toEqual(['HEAD~3']);
52
- });
53
-
54
- it('parses git range target', () => {
55
- const result = parseCliArgs(['main..feature', '--skill', 'security-review']);
56
- expect(result.options.targets).toEqual(['main..feature']);
57
- });
58
-
59
- it('parses --skill option', () => {
60
- const result = parseCliArgs(['--skill', 'security-review']);
61
- expect(result.options.skill).toBe('security-review');
62
- });
63
-
64
- it('parses --config option', () => {
65
- const result = parseCliArgs(['--config', './custom.toml']);
66
- expect(result.options.config).toBe('./custom.toml');
67
- });
68
-
69
- it('parses --json flag', () => {
70
- const result = parseCliArgs(['--json']);
71
- expect(result.options.json).toBe(true);
72
- });
73
-
74
- it('parses --fail-on option', () => {
75
- const result = parseCliArgs(['--fail-on', 'high']);
76
- expect(result.options.failOn).toBe('high');
77
- });
78
-
79
- it('parses help command', () => {
80
- const result = parseCliArgs(['help']);
81
- expect(result.command).toBe('help');
82
- });
83
-
84
- it('parses --help flag', () => {
85
- const result = parseCliArgs(['--help']);
86
- expect(result.command).toBe('help');
87
- });
88
-
89
- it('parses -h flag', () => {
90
- const result = parseCliArgs(['-h']);
91
- expect(result.command).toBe('help');
92
- });
93
-
94
- it('ignores run command for backward compat', () => {
95
- const result = parseCliArgs(['run', '--skill', 'security-review']);
96
- expect(result.options.targets).toBeUndefined();
97
- expect(result.options.skill).toBe('security-review');
98
- });
99
-
100
- it('allows targets without --skill (runs all skills)', () => {
101
- const result = parseCliArgs(['src/auth.ts']);
102
- expect(result.options.targets).toEqual(['src/auth.ts']);
103
- expect(result.options.skill).toBeUndefined();
104
- });
105
-
106
- it('parses --parallel option', () => {
107
- const result = parseCliArgs(['--parallel', '8']);
108
- expect(result.options.parallel).toBe(8);
109
- });
110
-
111
- it('does not set parallel when not provided', () => {
112
- const result = parseCliArgs([]);
113
- expect(result.options.parallel).toBeUndefined();
114
- });
115
-
116
- it('parses --quiet flag', () => {
117
- const result = parseCliArgs(['--quiet']);
118
- expect(result.options.quiet).toBe(true);
119
- });
120
-
121
- it('parses single -v flag', () => {
122
- const result = parseCliArgs(['-v']);
123
- expect(result.options.verbose).toBe(1);
124
- });
125
-
126
- it('parses multiple -v flags', () => {
127
- const result = parseCliArgs(['-v', '-v']);
128
- expect(result.options.verbose).toBe(2);
129
- });
130
-
131
- it('parses -vv flag', () => {
132
- const result = parseCliArgs(['-vv']);
133
- expect(result.options.verbose).toBe(2);
134
- });
135
-
136
- it('parses --verbose flag', () => {
137
- const result = parseCliArgs(['--verbose']);
138
- expect(result.options.verbose).toBe(1);
139
- });
140
-
141
- it('parses --color flag', () => {
142
- const result = parseCliArgs(['--color']);
143
- expect(result.options.color).toBe(true);
144
- });
145
-
146
- it('parses --no-color flag', () => {
147
- const result = parseCliArgs(['--no-color']);
148
- expect(result.options.color).toBe(false);
149
- });
150
-
151
- it('--no-color overrides --color when both specified', () => {
152
- const result = parseCliArgs(['--color', '--no-color']);
153
- expect(result.options.color).toBe(false);
154
- });
155
-
156
- it('defaults quiet to false', () => {
157
- const result = parseCliArgs([]);
158
- expect(result.options.quiet).toBe(false);
159
- });
160
-
161
- it('defaults verbose to 0', () => {
162
- const result = parseCliArgs([]);
163
- expect(result.options.verbose).toBe(0);
164
- });
165
-
166
- it('color is undefined by default (auto-detect)', () => {
167
- const result = parseCliArgs([]);
168
- expect(result.options.color).toBeUndefined();
169
- });
170
-
171
- it('parses --fix flag', () => {
172
- const result = parseCliArgs(['--fix']);
173
- expect(result.options.fix).toBe(true);
174
- });
175
-
176
- it('defaults fix to false', () => {
177
- const result = parseCliArgs([]);
178
- expect(result.options.fix).toBe(false);
179
- });
180
-
181
- it('parses add command', () => {
182
- const result = parseCliArgs(['add']);
183
- expect(result.command).toBe('add');
184
- });
185
-
186
- it('parses add command with skill argument', () => {
187
- const result = parseCliArgs(['add', 'security-review']);
188
- expect(result.command).toBe('add');
189
- expect(result.options.skill).toBe('security-review');
190
- });
191
-
192
- it('parses add --list flag', () => {
193
- const result = parseCliArgs(['add', '--list']);
194
- expect(result.command).toBe('add');
195
- expect(result.options.list).toBe(true);
196
- });
197
-
198
- it('parses add -l flag', () => {
199
- const result = parseCliArgs(['add', '-l']);
200
- expect(result.command).toBe('add');
201
- expect(result.options.list).toBe(true);
202
- });
203
-
204
- it('defaults list to false', () => {
205
- const result = parseCliArgs([]);
206
- expect(result.options.list).toBe(false);
207
- });
208
-
209
- it('parses --git flag', () => {
210
- const result = parseCliArgs(['feature', '--git']);
211
- expect(result.options.git).toBe(true);
212
- });
213
-
214
- it('defaults git to false', () => {
215
- const result = parseCliArgs([]);
216
- expect(result.options.git).toBe(false);
217
- });
218
-
219
- it('parses setup-app command', () => {
220
- const result = parseCliArgs(['setup-app']);
221
- expect(result.command).toBe('setup-app');
222
- expect(result.setupAppOptions).toBeDefined();
223
- expect(result.setupAppOptions?.port).toBe(3000);
224
- expect(result.setupAppOptions?.timeout).toBe(300);
225
- expect(result.setupAppOptions?.open).toBe(true);
226
- });
227
-
228
- it('parses setup-app --org option', () => {
229
- const result = parseCliArgs(['setup-app', '--org', 'myorg']);
230
- expect(result.command).toBe('setup-app');
231
- expect(result.setupAppOptions?.org).toBe('myorg');
232
- });
233
-
234
- it('parses setup-app --port option', () => {
235
- const result = parseCliArgs(['setup-app', '--port', '8080']);
236
- expect(result.command).toBe('setup-app');
237
- expect(result.setupAppOptions?.port).toBe(8080);
238
- });
239
-
240
- it('parses setup-app --timeout option', () => {
241
- const result = parseCliArgs(['setup-app', '--timeout', '60']);
242
- expect(result.command).toBe('setup-app');
243
- expect(result.setupAppOptions?.timeout).toBe(60);
244
- });
245
-
246
- it('parses setup-app --name option', () => {
247
- const result = parseCliArgs(['setup-app', '--name', 'My Custom App']);
248
- expect(result.command).toBe('setup-app');
249
- expect(result.setupAppOptions?.name).toBe('My Custom App');
250
- });
251
-
252
- it('parses setup-app --no-open flag', () => {
253
- const result = parseCliArgs(['setup-app', '--no-open']);
254
- expect(result.command).toBe('setup-app');
255
- expect(result.setupAppOptions?.open).toBe(false);
256
- });
257
-
258
- it('parses add command with --remote flag', () => {
259
- const result = parseCliArgs(['add', '--remote', 'getsentry/skills', '--skill', 'security-review']);
260
- expect(result.command).toBe('add');
261
- expect(result.options.remote).toBe('getsentry/skills');
262
- expect(result.options.skill).toBe('security-review');
263
- });
264
-
265
- it('parses add command with pinned --remote', () => {
266
- const result = parseCliArgs(['add', '--remote', 'getsentry/skills@abc123', '--skill', 'security-review']);
267
- expect(result.command).toBe('add');
268
- expect(result.options.remote).toBe('getsentry/skills@abc123');
269
- });
270
-
271
- it('parses add command with --remote and --list', () => {
272
- const result = parseCliArgs(['add', '--remote', 'getsentry/skills', '--list']);
273
- expect(result.command).toBe('add');
274
- expect(result.options.remote).toBe('getsentry/skills');
275
- expect(result.options.list).toBe(true);
276
- });
277
-
278
- it('parses add command with --remote and positional skill name', () => {
279
- const result = parseCliArgs(['add', '--remote', 'getsentry/skills', 'security-review']);
280
- expect(result.command).toBe('add');
281
- expect(result.options.remote).toBe('getsentry/skills');
282
- expect(result.options.skill).toBe('security-review');
283
- });
284
-
285
- it('parses --offline flag', () => {
286
- const result = parseCliArgs(['--offline']);
287
- expect(result.options.offline).toBe(true);
288
- });
289
-
290
- it('defaults offline to false', () => {
291
- const result = parseCliArgs([]);
292
- expect(result.options.offline).toBe(false);
293
- });
294
-
295
- it('parses sync command', () => {
296
- const result = parseCliArgs(['sync']);
297
- expect(result.command).toBe('sync');
298
- });
299
-
300
- it('parses sync command with remote argument', () => {
301
- const result = parseCliArgs(['sync', 'getsentry/skills']);
302
- expect(result.command).toBe('sync');
303
- expect(result.options.remote).toBe('getsentry/skills');
304
- });
305
-
306
- it('parses sync command with --remote flag', () => {
307
- const result = parseCliArgs(['sync', '--remote', 'getsentry/skills']);
308
- expect(result.command).toBe('sync');
309
- expect(result.options.remote).toBe('getsentry/skills');
310
- });
311
-
312
- it('--remote flag takes precedence over positional in sync', () => {
313
- const result = parseCliArgs(['sync', 'other/repo', '--remote', 'getsentry/skills']);
314
- expect(result.command).toBe('sync');
315
- expect(result.options.remote).toBe('getsentry/skills');
316
- });
317
- });
318
-
319
- describe('CLIOptionsSchema', () => {
320
- it('validates valid severity levels', () => {
321
- const severities = ['critical', 'high', 'medium', 'low', 'info'];
322
- for (const severity of severities) {
323
- const result = CLIOptionsSchema.safeParse({ failOn: severity });
324
- expect(result.success).toBe(true);
325
- }
326
- });
327
-
328
- it('rejects invalid severity levels', () => {
329
- const result = CLIOptionsSchema.safeParse({ failOn: 'invalid' });
330
- expect(result.success).toBe(false);
331
- });
332
-
333
- it('defaults json to false', () => {
334
- const result = CLIOptionsSchema.parse({});
335
- expect(result.json).toBe(false);
336
- });
337
-
338
- it('validates positive integer for parallel', () => {
339
- const result = CLIOptionsSchema.safeParse({ parallel: 4 });
340
- expect(result.success).toBe(true);
341
- });
342
-
343
- it('rejects non-positive parallel values', () => {
344
- const result = CLIOptionsSchema.safeParse({ parallel: 0 });
345
- expect(result.success).toBe(false);
346
-
347
- const result2 = CLIOptionsSchema.safeParse({ parallel: -1 });
348
- expect(result2.success).toBe(false);
349
- });
350
-
351
- it('rejects non-integer parallel values', () => {
352
- const result = CLIOptionsSchema.safeParse({ parallel: 1.5 });
353
- expect(result.success).toBe(false);
354
- });
355
- });
356
-
357
- describe('detectTargetType', () => {
358
- const mockExistsSync = existsSync as ReturnType<typeof vi.fn>;
359
-
360
- beforeEach(() => {
361
- mockExistsSync.mockReturnValue(false);
362
- });
363
-
364
- afterEach(() => {
365
- mockExistsSync.mockReset();
366
- });
367
-
368
- it('detects git range syntax', () => {
369
- expect(detectTargetType('main..feature')).toBe('git');
370
- expect(detectTargetType('HEAD~3..HEAD')).toBe('git');
371
- expect(detectTargetType('abc123..def456')).toBe('git');
372
- });
373
-
374
- it('detects relative refs', () => {
375
- expect(detectTargetType('HEAD~3')).toBe('git');
376
- expect(detectTargetType('main^2')).toBe('git');
377
- expect(detectTargetType('feature~')).toBe('git');
378
- });
379
-
380
- it('detects common git refs', () => {
381
- expect(detectTargetType('HEAD')).toBe('git');
382
- expect(detectTargetType('FETCH_HEAD')).toBe('git');
383
- expect(detectTargetType('ORIG_HEAD')).toBe('git');
384
- });
385
-
386
- it('detects file paths', () => {
387
- expect(detectTargetType('src/auth.ts')).toBe('file');
388
- expect(detectTargetType('./file.ts')).toBe('file');
389
- expect(detectTargetType('path/to/file.js')).toBe('file');
390
- });
391
-
392
- it('detects file extensions', () => {
393
- expect(detectTargetType('file.ts')).toBe('file');
394
- expect(detectTargetType('file.js')).toBe('file');
395
- expect(detectTargetType('README.md')).toBe('file');
396
- });
397
-
398
- it('detects glob patterns', () => {
399
- expect(detectTargetType('*.ts')).toBe('file');
400
- expect(detectTargetType('src/**/*.ts')).toBe('file');
401
- expect(detectTargetType('file?.ts')).toBe('file');
402
- });
403
-
404
- it('defaults to git for ambiguous targets when path does not exist', () => {
405
- mockExistsSync.mockReturnValue(false);
406
- expect(detectTargetType('main')).toBe('git');
407
- expect(detectTargetType('feature')).toBe('git');
408
- });
409
-
410
- it('prefers file when ambiguous target exists as file/directory', () => {
411
- mockExistsSync.mockReturnValue(true);
412
- expect(detectTargetType('feature')).toBe('file');
413
- expect(detectTargetType('docs')).toBe('file');
414
- });
415
-
416
- it('uses cwd option for filesystem check', () => {
417
- mockExistsSync.mockImplementation((path: string) => path === '/custom/path/feature');
418
- expect(detectTargetType('feature', { cwd: '/custom/path' })).toBe('file');
419
- expect(mockExistsSync).toHaveBeenCalledWith('/custom/path/feature');
420
- });
421
-
422
- it('forceGit option overrides filesystem check', () => {
423
- mockExistsSync.mockReturnValue(true);
424
- expect(detectTargetType('feature', { forceGit: true })).toBe('git');
425
- });
426
-
427
- it('forceGit does not affect unambiguous targets', () => {
428
- // Git range syntax is still git
429
- expect(detectTargetType('main..feature', { forceGit: true })).toBe('git');
430
- // File paths are still file
431
- expect(detectTargetType('src/auth.ts', { forceGit: true })).toBe('file');
432
- });
433
- });
434
-
435
- describe('classifyTargets', () => {
436
- const mockExistsSync = existsSync as ReturnType<typeof vi.fn>;
437
-
438
- beforeEach(() => {
439
- mockExistsSync.mockReturnValue(false);
440
- });
441
-
442
- afterEach(() => {
443
- mockExistsSync.mockReset();
444
- });
445
-
446
- it('classifies file targets', () => {
447
- const { gitRefs, filePatterns } = classifyTargets(['src/auth.ts', 'file.js']);
448
- expect(gitRefs).toEqual([]);
449
- expect(filePatterns).toEqual(['src/auth.ts', 'file.js']);
450
- });
451
-
452
- it('classifies git targets', () => {
453
- const { gitRefs, filePatterns } = classifyTargets(['HEAD~3', 'main..feature']);
454
- expect(gitRefs).toEqual(['HEAD~3', 'main..feature']);
455
- expect(filePatterns).toEqual([]);
456
- });
457
-
458
- it('classifies mixed targets', () => {
459
- const { gitRefs, filePatterns } = classifyTargets(['HEAD~3', 'src/auth.ts']);
460
- expect(gitRefs).toEqual(['HEAD~3']);
461
- expect(filePatterns).toEqual(['src/auth.ts']);
462
- });
463
-
464
- it('classifies ambiguous target as file when path exists', () => {
465
- mockExistsSync.mockReturnValue(true);
466
- const { gitRefs, filePatterns } = classifyTargets(['feature']);
467
- expect(gitRefs).toEqual([]);
468
- expect(filePatterns).toEqual(['feature']);
469
- });
470
-
471
- it('forceGit option forces ambiguous targets to git', () => {
472
- mockExistsSync.mockReturnValue(true);
473
- const { gitRefs, filePatterns } = classifyTargets(['feature'], { forceGit: true });
474
- expect(gitRefs).toEqual(['feature']);
475
- expect(filePatterns).toEqual([]);
476
- });
477
- });