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