flingit 0.0.62 → 0.0.65

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 (521) hide show
  1. package/dist/cli/commands/dev.d.ts.map +1 -1
  2. package/dist/cli/commands/dev.js +9 -5
  3. package/dist/cli/commands/dev.js.map +1 -1
  4. package/dist/cli/commands/email.d.ts +2 -0
  5. package/dist/cli/commands/email.d.ts.map +1 -1
  6. package/dist/cli/commands/email.js +3 -0
  7. package/dist/cli/commands/email.js.map +1 -1
  8. package/dist/cli/commands/workflow.d.ts +51 -0
  9. package/dist/cli/commands/workflow.d.ts.map +1 -0
  10. package/dist/cli/commands/workflow.js +479 -0
  11. package/dist/cli/commands/workflow.js.map +1 -0
  12. package/dist/cli/deploy/bundler.d.ts.map +1 -1
  13. package/dist/cli/deploy/bundler.js +17 -1
  14. package/dist/cli/deploy/bundler.js.map +1 -1
  15. package/dist/cli/index.d.ts.map +1 -1
  16. package/dist/cli/index.js +2 -0
  17. package/dist/cli/index.js.map +1 -1
  18. package/dist/index.d.ts +4 -1
  19. package/dist/index.d.ts.map +1 -1
  20. package/dist/index.js +3 -1
  21. package/dist/index.js.map +1 -1
  22. package/dist/runtime/entry.d.ts +7 -0
  23. package/dist/runtime/entry.d.ts.map +1 -1
  24. package/dist/runtime/entry.js +71 -2
  25. package/dist/runtime/entry.js.map +1 -1
  26. package/dist/types/workflow.d.ts +82 -0
  27. package/dist/types/workflow.d.ts.map +1 -0
  28. package/dist/types/workflow.js +8 -0
  29. package/dist/types/workflow.js.map +1 -0
  30. package/dist/worker-runtime/d1-event-store.d.ts +22 -0
  31. package/dist/worker-runtime/d1-event-store.d.ts.map +1 -0
  32. package/dist/worker-runtime/d1-event-store.js +227 -0
  33. package/dist/worker-runtime/d1-event-store.js.map +1 -0
  34. package/dist/worker-runtime/entry-extract.d.ts.map +1 -1
  35. package/dist/worker-runtime/entry-extract.js +6 -3
  36. package/dist/worker-runtime/entry-extract.js.map +1 -1
  37. package/dist/worker-runtime/entry.d.ts.map +1 -1
  38. package/dist/worker-runtime/entry.js +105 -3
  39. package/dist/worker-runtime/entry.js.map +1 -1
  40. package/dist/worker-runtime/index.d.ts +2 -0
  41. package/dist/worker-runtime/index.d.ts.map +1 -1
  42. package/dist/worker-runtime/index.js +5 -0
  43. package/dist/worker-runtime/index.js.map +1 -1
  44. package/dist/workflow/runtime.d.ts +56 -0
  45. package/dist/workflow/runtime.d.ts.map +1 -0
  46. package/dist/workflow/runtime.js +450 -0
  47. package/dist/workflow/runtime.js.map +1 -0
  48. package/node_modules/@glideapps/ts-necessities/LICENSE +21 -0
  49. package/node_modules/@glideapps/ts-necessities/README.md +16 -0
  50. package/node_modules/@glideapps/ts-necessities/dist/branded-strings.d.ts +39 -0
  51. package/node_modules/@glideapps/ts-necessities/dist/default-map.d.ts +53 -0
  52. package/node_modules/@glideapps/ts-necessities/dist/index.d.mts +113 -0
  53. package/node_modules/@glideapps/ts-necessities/dist/index.d.ts +113 -0
  54. package/node_modules/@glideapps/ts-necessities/dist/index.js +237 -0
  55. package/node_modules/@glideapps/ts-necessities/dist/index.mjs +189 -0
  56. package/node_modules/@glideapps/ts-necessities/package.json +52 -0
  57. package/node_modules/@rollup/rollup-linux-x64-gnu/README.md +3 -0
  58. package/node_modules/@rollup/rollup-linux-x64-gnu/package.json +25 -0
  59. package/node_modules/@rollup/rollup-linux-x64-gnu/rollup.linux-x64-gnu.node +0 -0
  60. package/node_modules/base64-js/LICENSE +21 -0
  61. package/node_modules/base64-js/README.md +34 -0
  62. package/node_modules/base64-js/base64js.min.js +1 -0
  63. package/node_modules/base64-js/index.d.ts +3 -0
  64. package/node_modules/base64-js/index.js +150 -0
  65. package/node_modules/base64-js/package.json +47 -0
  66. package/node_modules/better-sqlite3/LICENSE +21 -0
  67. package/node_modules/better-sqlite3/README.md +99 -0
  68. package/node_modules/better-sqlite3/binding.gyp +38 -0
  69. package/node_modules/better-sqlite3/deps/common.gypi +68 -0
  70. package/node_modules/better-sqlite3/deps/copy.js +31 -0
  71. package/node_modules/better-sqlite3/deps/defines.gypi +41 -0
  72. package/node_modules/better-sqlite3/deps/download.sh +122 -0
  73. package/node_modules/better-sqlite3/deps/patches/1208.patch +15 -0
  74. package/node_modules/better-sqlite3/deps/sqlite3/sqlite3.c +265994 -0
  75. package/node_modules/better-sqlite3/deps/sqlite3/sqlite3.h +13968 -0
  76. package/node_modules/better-sqlite3/deps/sqlite3/sqlite3ext.h +730 -0
  77. package/node_modules/better-sqlite3/deps/sqlite3.gyp +80 -0
  78. package/node_modules/better-sqlite3/deps/test_extension.c +21 -0
  79. package/node_modules/better-sqlite3/lib/database.js +90 -0
  80. package/node_modules/better-sqlite3/lib/index.js +3 -0
  81. package/node_modules/better-sqlite3/lib/methods/aggregate.js +43 -0
  82. package/node_modules/better-sqlite3/lib/methods/backup.js +67 -0
  83. package/node_modules/better-sqlite3/lib/methods/function.js +31 -0
  84. package/node_modules/better-sqlite3/lib/methods/inspect.js +7 -0
  85. package/node_modules/better-sqlite3/lib/methods/pragma.js +12 -0
  86. package/node_modules/better-sqlite3/lib/methods/serialize.js +16 -0
  87. package/node_modules/better-sqlite3/lib/methods/table.js +189 -0
  88. package/node_modules/better-sqlite3/lib/methods/transaction.js +78 -0
  89. package/node_modules/better-sqlite3/lib/methods/wrappers.js +54 -0
  90. package/node_modules/better-sqlite3/lib/sqlite-error.js +20 -0
  91. package/node_modules/better-sqlite3/lib/util.js +12 -0
  92. package/node_modules/better-sqlite3/package.json +59 -0
  93. package/node_modules/better-sqlite3/src/addon.cpp +47 -0
  94. package/node_modules/better-sqlite3/src/better_sqlite3.cpp +74 -0
  95. package/node_modules/better-sqlite3/src/objects/backup.cpp +120 -0
  96. package/node_modules/better-sqlite3/src/objects/backup.hpp +36 -0
  97. package/node_modules/better-sqlite3/src/objects/database.cpp +417 -0
  98. package/node_modules/better-sqlite3/src/objects/database.hpp +103 -0
  99. package/node_modules/better-sqlite3/src/objects/statement-iterator.cpp +113 -0
  100. package/node_modules/better-sqlite3/src/objects/statement-iterator.hpp +50 -0
  101. package/node_modules/better-sqlite3/src/objects/statement.cpp +383 -0
  102. package/node_modules/better-sqlite3/src/objects/statement.hpp +58 -0
  103. package/node_modules/better-sqlite3/src/util/bind-map.cpp +73 -0
  104. package/node_modules/better-sqlite3/src/util/binder.cpp +193 -0
  105. package/node_modules/better-sqlite3/src/util/constants.cpp +172 -0
  106. package/node_modules/better-sqlite3/src/util/custom-aggregate.cpp +121 -0
  107. package/node_modules/better-sqlite3/src/util/custom-function.cpp +59 -0
  108. package/node_modules/better-sqlite3/src/util/custom-table.cpp +409 -0
  109. package/node_modules/better-sqlite3/src/util/data-converter.cpp +17 -0
  110. package/node_modules/better-sqlite3/src/util/data.cpp +194 -0
  111. package/node_modules/better-sqlite3/src/util/helpers.cpp +109 -0
  112. package/node_modules/better-sqlite3/src/util/macros.cpp +83 -0
  113. package/node_modules/better-sqlite3/src/util/query-macros.cpp +71 -0
  114. package/node_modules/better-sqlite3/src/util/row-builder.cpp +49 -0
  115. package/node_modules/bindings/LICENSE.md +22 -0
  116. package/node_modules/bindings/README.md +98 -0
  117. package/node_modules/bindings/bindings.js +221 -0
  118. package/node_modules/bindings/package.json +28 -0
  119. package/node_modules/bl/.travis.yml +17 -0
  120. package/node_modules/bl/BufferList.js +396 -0
  121. package/node_modules/bl/LICENSE.md +13 -0
  122. package/node_modules/bl/README.md +247 -0
  123. package/node_modules/bl/bl.js +84 -0
  124. package/node_modules/bl/package.json +37 -0
  125. package/node_modules/bl/test/convert.js +21 -0
  126. package/node_modules/bl/test/indexOf.js +492 -0
  127. package/node_modules/bl/test/isBufferList.js +32 -0
  128. package/node_modules/bl/test/test.js +869 -0
  129. package/node_modules/buffer/AUTHORS.md +70 -0
  130. package/node_modules/buffer/LICENSE +21 -0
  131. package/node_modules/buffer/README.md +410 -0
  132. package/node_modules/buffer/index.d.ts +186 -0
  133. package/node_modules/buffer/index.js +1817 -0
  134. package/node_modules/buffer/package.json +96 -0
  135. package/node_modules/chownr/LICENSE +15 -0
  136. package/node_modules/chownr/README.md +3 -0
  137. package/node_modules/chownr/chownr.js +167 -0
  138. package/node_modules/chownr/package.json +29 -0
  139. package/node_modules/decompress-response/index.d.ts +22 -0
  140. package/node_modules/decompress-response/index.js +58 -0
  141. package/node_modules/decompress-response/license +9 -0
  142. package/node_modules/decompress-response/package.json +56 -0
  143. package/node_modules/decompress-response/readme.md +48 -0
  144. package/node_modules/deep-extend/LICENSE +20 -0
  145. package/node_modules/deep-extend/README.md +91 -0
  146. package/node_modules/deep-extend/index.js +1 -0
  147. package/node_modules/deep-extend/lib/deep-extend.js +150 -0
  148. package/node_modules/deep-extend/package.json +62 -0
  149. package/node_modules/detect-libc/LICENSE +201 -0
  150. package/node_modules/detect-libc/README.md +163 -0
  151. package/node_modules/detect-libc/index.d.ts +14 -0
  152. package/node_modules/detect-libc/lib/detect-libc.js +313 -0
  153. package/node_modules/detect-libc/lib/elf.js +39 -0
  154. package/node_modules/detect-libc/lib/filesystem.js +51 -0
  155. package/node_modules/detect-libc/lib/process.js +24 -0
  156. package/node_modules/detect-libc/package.json +44 -0
  157. package/node_modules/determined/LICENSE +18 -0
  158. package/node_modules/determined/README.md +317 -0
  159. package/node_modules/determined/dist/index.cjs +370 -0
  160. package/node_modules/determined/dist/index.d.cts +110 -0
  161. package/node_modules/determined/dist/index.d.ts +110 -0
  162. package/node_modules/determined/dist/index.js +332 -0
  163. package/node_modules/determined/package.json +45 -0
  164. package/node_modules/end-of-stream/LICENSE +21 -0
  165. package/node_modules/end-of-stream/README.md +54 -0
  166. package/node_modules/end-of-stream/index.js +96 -0
  167. package/node_modules/end-of-stream/package.json +37 -0
  168. package/node_modules/expand-template/.travis.yml +6 -0
  169. package/node_modules/expand-template/LICENSE +21 -0
  170. package/node_modules/expand-template/README.md +43 -0
  171. package/node_modules/expand-template/index.js +26 -0
  172. package/node_modules/expand-template/package.json +29 -0
  173. package/node_modules/expand-template/test.js +67 -0
  174. package/node_modules/file-uri-to-path/.npmignore +1 -0
  175. package/node_modules/file-uri-to-path/.travis.yml +30 -0
  176. package/node_modules/file-uri-to-path/History.md +21 -0
  177. package/node_modules/file-uri-to-path/LICENSE +20 -0
  178. package/node_modules/file-uri-to-path/README.md +74 -0
  179. package/node_modules/file-uri-to-path/index.d.ts +2 -0
  180. package/node_modules/file-uri-to-path/index.js +66 -0
  181. package/node_modules/file-uri-to-path/package.json +32 -0
  182. package/node_modules/file-uri-to-path/test/test.js +24 -0
  183. package/node_modules/file-uri-to-path/test/tests.json +13 -0
  184. package/node_modules/flingflow/.nvmrc +1 -0
  185. package/node_modules/flingflow/AGENTS.md +5 -0
  186. package/node_modules/flingflow/README.md +679 -0
  187. package/node_modules/flingflow/SPEC.md +554 -0
  188. package/node_modules/flingflow/TESTING.md +506 -0
  189. package/node_modules/flingflow/dist/backoff.d.ts +9 -0
  190. package/node_modules/flingflow/dist/backoff.js +14 -0
  191. package/node_modules/flingflow/dist/backoff.js.map +1 -0
  192. package/node_modules/flingflow/dist/clock.d.ts +13 -0
  193. package/node_modules/flingflow/dist/clock.js +21 -0
  194. package/node_modules/flingflow/dist/clock.js.map +1 -0
  195. package/node_modules/flingflow/dist/context.d.ts +8 -0
  196. package/node_modules/flingflow/dist/context.js +45 -0
  197. package/node_modules/flingflow/dist/context.js.map +1 -0
  198. package/node_modules/flingflow/dist/engine.d.ts +29 -0
  199. package/node_modules/flingflow/dist/engine.js +306 -0
  200. package/node_modules/flingflow/dist/engine.js.map +1 -0
  201. package/node_modules/flingflow/dist/index.d.ts +18 -0
  202. package/node_modules/flingflow/dist/index.js +14 -0
  203. package/node_modules/flingflow/dist/index.js.map +1 -0
  204. package/node_modules/flingflow/dist/recovery.d.ts +16 -0
  205. package/node_modules/flingflow/dist/recovery.js +118 -0
  206. package/node_modules/flingflow/dist/recovery.js.map +1 -0
  207. package/node_modules/flingflow/dist/registry.d.ts +24 -0
  208. package/node_modules/flingflow/dist/registry.js +29 -0
  209. package/node_modules/flingflow/dist/registry.js.map +1 -0
  210. package/node_modules/flingflow/dist/store-memory.d.ts +29 -0
  211. package/node_modules/flingflow/dist/store-memory.js +349 -0
  212. package/node_modules/flingflow/dist/store-memory.js.map +1 -0
  213. package/node_modules/flingflow/dist/store-sqlite.d.ts +30 -0
  214. package/node_modules/flingflow/dist/store-sqlite.js +400 -0
  215. package/node_modules/flingflow/dist/store-sqlite.js.map +1 -0
  216. package/node_modules/flingflow/dist/store.d.ts +39 -0
  217. package/node_modules/flingflow/dist/store.js +21 -0
  218. package/node_modules/flingflow/dist/store.js.map +1 -0
  219. package/node_modules/flingflow/dist/stress.d.ts +1 -0
  220. package/node_modules/flingflow/dist/stress.js +377 -0
  221. package/node_modules/flingflow/dist/stress.js.map +1 -0
  222. package/node_modules/flingflow/dist/transitions.d.ts +14 -0
  223. package/node_modules/flingflow/dist/transitions.js +28 -0
  224. package/node_modules/flingflow/dist/transitions.js.map +1 -0
  225. package/node_modules/flingflow/dist/types.d.ts +114 -0
  226. package/node_modules/flingflow/dist/types.js +10 -0
  227. package/node_modules/flingflow/dist/types.js.map +1 -0
  228. package/node_modules/flingflow/eslint.config.js +94 -0
  229. package/node_modules/flingflow/package.json +66 -0
  230. package/node_modules/flingflow/src/backoff.ts +14 -0
  231. package/node_modules/flingflow/src/clock.ts +29 -0
  232. package/node_modules/flingflow/src/context.ts +60 -0
  233. package/node_modules/flingflow/src/engine.ts +367 -0
  234. package/node_modules/flingflow/src/index.ts +52 -0
  235. package/node_modules/flingflow/src/recovery.ts +144 -0
  236. package/node_modules/flingflow/src/registry.ts +52 -0
  237. package/node_modules/flingflow/src/store-memory.ts +378 -0
  238. package/node_modules/flingflow/src/store-sqlite.ts +451 -0
  239. package/node_modules/flingflow/src/store.ts +55 -0
  240. package/node_modules/flingflow/src/stress.ts +423 -0
  241. package/node_modules/flingflow/src/transitions.ts +38 -0
  242. package/node_modules/flingflow/src/types.ts +84 -0
  243. package/node_modules/flingflow/test/backoff.test.ts +54 -0
  244. package/node_modules/flingflow/test/context.test.ts +94 -0
  245. package/node_modules/flingflow/test/engine.test.ts +362 -0
  246. package/node_modules/flingflow/test/fixtures.ts +58 -0
  247. package/node_modules/flingflow/test/recovery.test.ts +176 -0
  248. package/node_modules/flingflow/test/simulation.test.ts +395 -0
  249. package/node_modules/flingflow/test/store-conformance.ts +344 -0
  250. package/node_modules/flingflow/test/store-memory.test.ts +8 -0
  251. package/node_modules/flingflow/test/store-sqlite.test.ts +8 -0
  252. package/node_modules/flingflow/tsconfig.json +18 -0
  253. package/node_modules/flingflow/tsconfig.lint.json +5 -0
  254. package/node_modules/flingflow/tsconfig.typecheck.json +20 -0
  255. package/node_modules/flingflow/vitest.config.ts +10 -0
  256. package/node_modules/fs-constants/LICENSE +21 -0
  257. package/node_modules/fs-constants/README.md +26 -0
  258. package/node_modules/fs-constants/browser.js +1 -0
  259. package/node_modules/fs-constants/index.js +1 -0
  260. package/node_modules/fs-constants/package.json +19 -0
  261. package/node_modules/github-from-package/.travis.yml +4 -0
  262. package/node_modules/github-from-package/LICENSE +18 -0
  263. package/node_modules/github-from-package/example/package.json +8 -0
  264. package/node_modules/github-from-package/example/url.js +3 -0
  265. package/node_modules/github-from-package/index.js +17 -0
  266. package/node_modules/github-from-package/package.json +30 -0
  267. package/node_modules/github-from-package/readme.markdown +53 -0
  268. package/node_modules/github-from-package/test/a.json +8 -0
  269. package/node_modules/github-from-package/test/b.json +5 -0
  270. package/node_modules/github-from-package/test/c.json +5 -0
  271. package/node_modules/github-from-package/test/d.json +7 -0
  272. package/node_modules/github-from-package/test/e.json +5 -0
  273. package/node_modules/github-from-package/test/url.js +19 -0
  274. package/node_modules/ieee754/LICENSE +11 -0
  275. package/node_modules/ieee754/README.md +51 -0
  276. package/node_modules/ieee754/index.d.ts +10 -0
  277. package/node_modules/ieee754/index.js +85 -0
  278. package/node_modules/ieee754/package.json +52 -0
  279. package/node_modules/inherits/LICENSE +16 -0
  280. package/node_modules/inherits/README.md +42 -0
  281. package/node_modules/inherits/inherits.js +9 -0
  282. package/node_modules/inherits/inherits_browser.js +27 -0
  283. package/node_modules/inherits/package.json +29 -0
  284. package/node_modules/ini/LICENSE +15 -0
  285. package/node_modules/ini/README.md +102 -0
  286. package/node_modules/ini/ini.js +206 -0
  287. package/node_modules/ini/package.json +33 -0
  288. package/node_modules/mimic-response/index.d.ts +17 -0
  289. package/node_modules/mimic-response/index.js +77 -0
  290. package/node_modules/mimic-response/license +9 -0
  291. package/node_modules/mimic-response/package.json +42 -0
  292. package/node_modules/mimic-response/readme.md +78 -0
  293. package/node_modules/minimist/.eslintrc +29 -0
  294. package/node_modules/minimist/.github/FUNDING.yml +12 -0
  295. package/node_modules/minimist/.nycrc +14 -0
  296. package/node_modules/minimist/CHANGELOG.md +298 -0
  297. package/node_modules/minimist/LICENSE +18 -0
  298. package/node_modules/minimist/README.md +121 -0
  299. package/node_modules/minimist/example/parse.js +4 -0
  300. package/node_modules/minimist/index.js +263 -0
  301. package/node_modules/minimist/package.json +75 -0
  302. package/node_modules/minimist/test/all_bool.js +34 -0
  303. package/node_modules/minimist/test/bool.js +177 -0
  304. package/node_modules/minimist/test/dash.js +43 -0
  305. package/node_modules/minimist/test/default_bool.js +37 -0
  306. package/node_modules/minimist/test/dotted.js +24 -0
  307. package/node_modules/minimist/test/kv_short.js +32 -0
  308. package/node_modules/minimist/test/long.js +33 -0
  309. package/node_modules/minimist/test/num.js +38 -0
  310. package/node_modules/minimist/test/parse.js +209 -0
  311. package/node_modules/minimist/test/parse_modified.js +11 -0
  312. package/node_modules/minimist/test/proto.js +64 -0
  313. package/node_modules/minimist/test/short.js +69 -0
  314. package/node_modules/minimist/test/stop_early.js +17 -0
  315. package/node_modules/minimist/test/unknown.js +104 -0
  316. package/node_modules/minimist/test/whitespace.js +10 -0
  317. package/node_modules/mkdirp-classic/LICENSE +21 -0
  318. package/node_modules/mkdirp-classic/README.md +18 -0
  319. package/node_modules/mkdirp-classic/index.js +98 -0
  320. package/node_modules/mkdirp-classic/package.json +18 -0
  321. package/node_modules/napi-build-utils/.github/workflows/run-npm-tests.yml +31 -0
  322. package/node_modules/napi-build-utils/LICENSE +21 -0
  323. package/node_modules/napi-build-utils/README.md +52 -0
  324. package/node_modules/napi-build-utils/index.js +214 -0
  325. package/node_modules/napi-build-utils/index.md +0 -0
  326. package/node_modules/napi-build-utils/package.json +42 -0
  327. package/node_modules/neverthrow/LICENSE +22 -0
  328. package/node_modules/neverthrow/README.md +1683 -0
  329. package/node_modules/neverthrow/dist/index.cjs.js +510 -0
  330. package/node_modules/neverthrow/dist/index.d.ts +408 -0
  331. package/node_modules/neverthrow/dist/index.es.js +497 -0
  332. package/node_modules/neverthrow/package.json +64 -0
  333. package/node_modules/node-abi/LICENSE +21 -0
  334. package/node_modules/node-abi/README.md +54 -0
  335. package/node_modules/node-abi/abi_registry.json +425 -0
  336. package/node_modules/node-abi/index.js +179 -0
  337. package/node_modules/node-abi/package.json +45 -0
  338. package/node_modules/once/LICENSE +15 -0
  339. package/node_modules/once/README.md +79 -0
  340. package/node_modules/once/once.js +42 -0
  341. package/node_modules/once/package.json +33 -0
  342. package/node_modules/prebuild-install/CHANGELOG.md +131 -0
  343. package/node_modules/prebuild-install/CONTRIBUTING.md +6 -0
  344. package/node_modules/prebuild-install/LICENSE +21 -0
  345. package/node_modules/prebuild-install/README.md +163 -0
  346. package/node_modules/prebuild-install/asset.js +44 -0
  347. package/node_modules/prebuild-install/bin.js +78 -0
  348. package/node_modules/prebuild-install/download.js +142 -0
  349. package/node_modules/prebuild-install/error.js +14 -0
  350. package/node_modules/prebuild-install/help.txt +16 -0
  351. package/node_modules/prebuild-install/index.js +1 -0
  352. package/node_modules/prebuild-install/log.js +33 -0
  353. package/node_modules/prebuild-install/package.json +67 -0
  354. package/node_modules/prebuild-install/proxy.js +35 -0
  355. package/node_modules/prebuild-install/rc.js +64 -0
  356. package/node_modules/prebuild-install/util.js +143 -0
  357. package/node_modules/pump/.github/FUNDING.yml +2 -0
  358. package/node_modules/pump/.travis.yml +5 -0
  359. package/node_modules/pump/LICENSE +21 -0
  360. package/node_modules/pump/README.md +74 -0
  361. package/node_modules/pump/SECURITY.md +5 -0
  362. package/node_modules/pump/index.js +86 -0
  363. package/node_modules/pump/package.json +24 -0
  364. package/node_modules/pump/test-browser.js +66 -0
  365. package/node_modules/pump/test-node.js +53 -0
  366. package/node_modules/rc/LICENSE.APACHE2 +15 -0
  367. package/node_modules/rc/LICENSE.BSD +26 -0
  368. package/node_modules/rc/LICENSE.MIT +24 -0
  369. package/node_modules/rc/README.md +227 -0
  370. package/node_modules/rc/browser.js +7 -0
  371. package/node_modules/rc/cli.js +4 -0
  372. package/node_modules/rc/index.js +53 -0
  373. package/node_modules/rc/lib/utils.js +104 -0
  374. package/node_modules/rc/package.json +29 -0
  375. package/node_modules/rc/test/ini.js +16 -0
  376. package/node_modules/rc/test/nested-env-vars.js +50 -0
  377. package/node_modules/rc/test/test.js +59 -0
  378. package/node_modules/readable-stream/CONTRIBUTING.md +38 -0
  379. package/node_modules/readable-stream/GOVERNANCE.md +136 -0
  380. package/node_modules/readable-stream/LICENSE +47 -0
  381. package/node_modules/readable-stream/README.md +106 -0
  382. package/node_modules/readable-stream/errors-browser.js +127 -0
  383. package/node_modules/readable-stream/errors.js +116 -0
  384. package/node_modules/readable-stream/experimentalWarning.js +17 -0
  385. package/node_modules/readable-stream/lib/_stream_duplex.js +126 -0
  386. package/node_modules/readable-stream/lib/_stream_passthrough.js +37 -0
  387. package/node_modules/readable-stream/lib/_stream_readable.js +1027 -0
  388. package/node_modules/readable-stream/lib/_stream_transform.js +190 -0
  389. package/node_modules/readable-stream/lib/_stream_writable.js +641 -0
  390. package/node_modules/readable-stream/lib/internal/streams/async_iterator.js +180 -0
  391. package/node_modules/readable-stream/lib/internal/streams/buffer_list.js +183 -0
  392. package/node_modules/readable-stream/lib/internal/streams/destroy.js +96 -0
  393. package/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +86 -0
  394. package/node_modules/readable-stream/lib/internal/streams/from-browser.js +3 -0
  395. package/node_modules/readable-stream/lib/internal/streams/from.js +52 -0
  396. package/node_modules/readable-stream/lib/internal/streams/pipeline.js +86 -0
  397. package/node_modules/readable-stream/lib/internal/streams/state.js +22 -0
  398. package/node_modules/readable-stream/lib/internal/streams/stream-browser.js +1 -0
  399. package/node_modules/readable-stream/lib/internal/streams/stream.js +1 -0
  400. package/node_modules/readable-stream/package.json +68 -0
  401. package/node_modules/readable-stream/readable-browser.js +9 -0
  402. package/node_modules/readable-stream/readable.js +16 -0
  403. package/node_modules/safe-buffer/LICENSE +21 -0
  404. package/node_modules/safe-buffer/README.md +584 -0
  405. package/node_modules/safe-buffer/index.d.ts +187 -0
  406. package/node_modules/safe-buffer/index.js +65 -0
  407. package/node_modules/safe-buffer/package.json +51 -0
  408. package/node_modules/semver/LICENSE +15 -0
  409. package/node_modules/semver/README.md +664 -0
  410. package/node_modules/semver/bin/semver.js +191 -0
  411. package/node_modules/semver/classes/comparator.js +143 -0
  412. package/node_modules/semver/classes/index.js +7 -0
  413. package/node_modules/semver/classes/range.js +557 -0
  414. package/node_modules/semver/classes/semver.js +333 -0
  415. package/node_modules/semver/functions/clean.js +8 -0
  416. package/node_modules/semver/functions/cmp.js +54 -0
  417. package/node_modules/semver/functions/coerce.js +62 -0
  418. package/node_modules/semver/functions/compare-build.js +9 -0
  419. package/node_modules/semver/functions/compare-loose.js +5 -0
  420. package/node_modules/semver/functions/compare.js +7 -0
  421. package/node_modules/semver/functions/diff.js +60 -0
  422. package/node_modules/semver/functions/eq.js +5 -0
  423. package/node_modules/semver/functions/gt.js +5 -0
  424. package/node_modules/semver/functions/gte.js +5 -0
  425. package/node_modules/semver/functions/inc.js +21 -0
  426. package/node_modules/semver/functions/lt.js +5 -0
  427. package/node_modules/semver/functions/lte.js +5 -0
  428. package/node_modules/semver/functions/major.js +5 -0
  429. package/node_modules/semver/functions/minor.js +5 -0
  430. package/node_modules/semver/functions/neq.js +5 -0
  431. package/node_modules/semver/functions/parse.js +18 -0
  432. package/node_modules/semver/functions/patch.js +5 -0
  433. package/node_modules/semver/functions/prerelease.js +8 -0
  434. package/node_modules/semver/functions/rcompare.js +5 -0
  435. package/node_modules/semver/functions/rsort.js +5 -0
  436. package/node_modules/semver/functions/satisfies.js +12 -0
  437. package/node_modules/semver/functions/sort.js +5 -0
  438. package/node_modules/semver/functions/valid.js +8 -0
  439. package/node_modules/semver/index.js +91 -0
  440. package/node_modules/semver/internal/constants.js +37 -0
  441. package/node_modules/semver/internal/debug.js +11 -0
  442. package/node_modules/semver/internal/identifiers.js +29 -0
  443. package/node_modules/semver/internal/lrucache.js +42 -0
  444. package/node_modules/semver/internal/parse-options.js +17 -0
  445. package/node_modules/semver/internal/re.js +223 -0
  446. package/node_modules/semver/package.json +78 -0
  447. package/node_modules/semver/preload.js +4 -0
  448. package/node_modules/semver/range.bnf +16 -0
  449. package/node_modules/semver/ranges/gtr.js +6 -0
  450. package/node_modules/semver/ranges/intersects.js +9 -0
  451. package/node_modules/semver/ranges/ltr.js +6 -0
  452. package/node_modules/semver/ranges/max-satisfying.js +27 -0
  453. package/node_modules/semver/ranges/min-satisfying.js +26 -0
  454. package/node_modules/semver/ranges/min-version.js +63 -0
  455. package/node_modules/semver/ranges/outside.js +82 -0
  456. package/node_modules/semver/ranges/simplify.js +49 -0
  457. package/node_modules/semver/ranges/subset.js +249 -0
  458. package/node_modules/semver/ranges/to-comparators.js +10 -0
  459. package/node_modules/semver/ranges/valid.js +13 -0
  460. package/node_modules/simple-concat/.travis.yml +3 -0
  461. package/node_modules/simple-concat/LICENSE +20 -0
  462. package/node_modules/simple-concat/README.md +44 -0
  463. package/node_modules/simple-concat/index.js +15 -0
  464. package/node_modules/simple-concat/package.json +47 -0
  465. package/node_modules/simple-concat/test/basic.js +41 -0
  466. package/node_modules/simple-get/.github/dependabot.yml +15 -0
  467. package/node_modules/simple-get/.github/workflows/ci.yml +23 -0
  468. package/node_modules/simple-get/LICENSE +20 -0
  469. package/node_modules/simple-get/README.md +333 -0
  470. package/node_modules/simple-get/index.js +108 -0
  471. package/node_modules/simple-get/package.json +67 -0
  472. package/node_modules/string_decoder/LICENSE +48 -0
  473. package/node_modules/string_decoder/README.md +47 -0
  474. package/node_modules/string_decoder/lib/string_decoder.js +296 -0
  475. package/node_modules/string_decoder/package.json +34 -0
  476. package/node_modules/strip-json-comments/index.js +70 -0
  477. package/node_modules/strip-json-comments/license +21 -0
  478. package/node_modules/strip-json-comments/package.json +42 -0
  479. package/node_modules/strip-json-comments/readme.md +64 -0
  480. package/node_modules/tar-fs/.travis.yml +6 -0
  481. package/node_modules/tar-fs/LICENSE +21 -0
  482. package/node_modules/tar-fs/README.md +165 -0
  483. package/node_modules/tar-fs/index.js +363 -0
  484. package/node_modules/tar-fs/package.json +41 -0
  485. package/node_modules/tar-fs/test/fixtures/a/hello.txt +1 -0
  486. package/node_modules/tar-fs/test/fixtures/b/a/test.txt +1 -0
  487. package/node_modules/tar-fs/test/fixtures/d/file1 +0 -0
  488. package/node_modules/tar-fs/test/fixtures/d/file2 +0 -0
  489. package/node_modules/tar-fs/test/fixtures/d/sub-dir/file5 +0 -0
  490. package/node_modules/tar-fs/test/fixtures/d/sub-files/file3 +0 -0
  491. package/node_modules/tar-fs/test/fixtures/d/sub-files/file4 +0 -0
  492. package/node_modules/tar-fs/test/fixtures/e/directory/.ignore +0 -0
  493. package/node_modules/tar-fs/test/fixtures/e/file +0 -0
  494. package/node_modules/tar-fs/test/fixtures/invalid.tar +0 -0
  495. package/node_modules/tar-fs/test/index.js +346 -0
  496. package/node_modules/tar-stream/LICENSE +21 -0
  497. package/node_modules/tar-stream/README.md +168 -0
  498. package/node_modules/tar-stream/extract.js +257 -0
  499. package/node_modules/tar-stream/headers.js +295 -0
  500. package/node_modules/tar-stream/index.js +2 -0
  501. package/node_modules/tar-stream/pack.js +255 -0
  502. package/node_modules/tar-stream/package.json +58 -0
  503. package/node_modules/tar-stream/sandbox.js +11 -0
  504. package/node_modules/tunnel-agent/LICENSE +55 -0
  505. package/node_modules/tunnel-agent/README.md +4 -0
  506. package/node_modules/tunnel-agent/index.js +244 -0
  507. package/node_modules/tunnel-agent/package.json +22 -0
  508. package/node_modules/util-deprecate/History.md +16 -0
  509. package/node_modules/util-deprecate/LICENSE +24 -0
  510. package/node_modules/util-deprecate/README.md +53 -0
  511. package/node_modules/util-deprecate/browser.js +67 -0
  512. package/node_modules/util-deprecate/node.js +6 -0
  513. package/node_modules/util-deprecate/package.json +27 -0
  514. package/node_modules/wrappy/LICENSE +15 -0
  515. package/node_modules/wrappy/README.md +36 -0
  516. package/node_modules/wrappy/package.json +29 -0
  517. package/node_modules/wrappy/wrappy.js +33 -0
  518. package/package.json +12 -2
  519. package/templates/default/dot-claude/skills/fling/.hash +1 -1
  520. package/templates/default/dot-claude/skills/fling/SKILL.md +56 -29
  521. package/templates/default/dot-claude/skills/fling/references/WORKFLOWS.md +368 -0
@@ -0,0 +1,344 @@
1
+ import { describe, it, expect, beforeEach } from "vitest";
2
+ import { UniqueConstraintError, WorkflowAlreadyActiveError, WorkflowIdMismatchError, type EventStore } from "../src/store.js";
3
+ import type { WorkflowConfig, WorkflowEvent } from "../src/types.js";
4
+ import { noSim } from "./fixtures.js";
5
+
6
+ const TEST_CONFIG: WorkflowConfig = { maxAttempts: 5, initialBackoffMS: 1000, backoffMultiplier: 2, maxBackoffMS: 60_000, stepTimeoutMS: 300_000 };
7
+
8
+ export function storeConformanceTests(name: string, createStore: () => Promise<EventStore>) {
9
+ describe(`${name} conformance`, () => {
10
+ let store: EventStore;
11
+
12
+ beforeEach(async () => {
13
+ store = await createStore();
14
+ });
15
+
16
+ it("append + getLastEvent round-trip", async () => {
17
+ const event: WorkflowEvent = {
18
+ run_id: "run-1", workflow_id: "wf-1",
19
+ seq: 0, event_type: "workflow_created",
20
+ payload: { workflowName: "test", writes: { userId: 42 }, config: TEST_CONFIG },
21
+ created_at: 1000,
22
+ };
23
+
24
+ const result = await store.append(event, noSim);
25
+ expect(result.isOk()).toBe(true);
26
+ const last = (await store.getLastEvent("run-1", noSim))._unsafeUnwrap();
27
+ expect(last).toEqual(event);
28
+ });
29
+
30
+ it("getLastEvent returns null for unknown run", async () => {
31
+ const last = (await store.getLastEvent("nonexistent", noSim))._unsafeUnwrap();
32
+ expect(last).toBeNull();
33
+ });
34
+
35
+ it("getLastEvent returns highest seq", async () => {
36
+ (await store.append({
37
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
38
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
39
+ }, noSim))._unsafeUnwrap();
40
+ (await store.append({
41
+ run_id: "run-1", workflow_id: "wf-1", seq: 1, event_type: "step_started",
42
+ payload: { step: "start", attempt: 1 }, created_at: 1001,
43
+ }, noSim))._unsafeUnwrap();
44
+
45
+ const last = (await store.getLastEvent("run-1", noSim))._unsafeUnwrap();
46
+ expect(last!.seq).toBe(1);
47
+ expect(last!.event_type).toBe("step_started");
48
+ });
49
+
50
+ it("returns UniqueConstraintError on duplicate (run_id, seq)", async () => {
51
+ const event: WorkflowEvent = {
52
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
53
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
54
+ };
55
+ (await store.append(event, noSim))._unsafeUnwrap();
56
+ const result = await store.append(event, noSim);
57
+ expect(result.isErr()).toBe(true);
58
+ expect(result._unsafeUnwrapErr()).toBeInstanceOf(UniqueConstraintError);
59
+ });
60
+
61
+ it("appendBatch inserts multiple events atomically", async () => {
62
+ const events: WorkflowEvent[] = [
63
+ { run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created", payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000 },
64
+ { run_id: "run-1", workflow_id: "wf-1", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
65
+ ];
66
+
67
+ const result = await store.appendBatch(events, noSim);
68
+ expect(result.isOk()).toBe(true);
69
+ const all = (await store.getAllEvents("run-1", noSim))._unsafeUnwrap();
70
+ expect(all).toHaveLength(2);
71
+ });
72
+
73
+ it("appendBatch is atomic — no partial inserts on duplicate", async () => {
74
+ (await store.append({
75
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
76
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
77
+ }, noSim))._unsafeUnwrap();
78
+
79
+ const events: WorkflowEvent[] = [
80
+ { run_id: "run-1", workflow_id: "wf-1", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
81
+ { run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created", payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000 }, // dup
82
+ ];
83
+
84
+ const result = await store.appendBatch(events, noSim);
85
+ expect(result.isErr()).toBe(true);
86
+ expect(result._unsafeUnwrapErr()).toBeInstanceOf(UniqueConstraintError);
87
+
88
+ // seq=1 should NOT be present since batch is atomic
89
+ const all = (await store.getAllEvents("run-1", noSim))._unsafeUnwrap();
90
+ expect(all).toHaveLength(1);
91
+ expect(all[0].seq).toBe(0);
92
+ });
93
+
94
+ it("getEvent returns specific event", async () => {
95
+ (await store.append({
96
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
97
+ payload: { workflowName: "test", writes: { x: 1 }, config: TEST_CONFIG }, created_at: 1000,
98
+ }, noSim))._unsafeUnwrap();
99
+
100
+ const event = (await store.getEvent("run-1", 0, noSim))._unsafeUnwrap();
101
+ expect(event).not.toBeNull();
102
+ expect(event!.event_type).toBe("workflow_created");
103
+ expect((event!.payload as any).writes).toEqual({ x: 1 });
104
+ });
105
+
106
+ it("getEvent returns null for missing seq", async () => {
107
+ const event = (await store.getEvent("run-1", 99, noSim))._unsafeUnwrap();
108
+ expect(event).toBeNull();
109
+ });
110
+
111
+ it("getCompletedEvents returns step_completed events in seq DESC order", async () => {
112
+ (await store.appendBatch([
113
+ { run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created", payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000 },
114
+ { run_id: "run-1", workflow_id: "wf-1", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
115
+ { run_id: "run-1", workflow_id: "wf-1", seq: 2, event_type: "step_completed", payload: { step: "start", writes: { a: 1 }, next_step: "two" }, created_at: 1002 },
116
+ { run_id: "run-1", workflow_id: "wf-1", seq: 3, event_type: "step_started", payload: { step: "two", attempt: 1 }, created_at: 1003 },
117
+ { run_id: "run-1", workflow_id: "wf-1", seq: 4, event_type: "step_completed", payload: { step: "two", writes: { b: 2 } }, created_at: 1004 },
118
+ ], noSim))._unsafeUnwrap();
119
+
120
+ const completed = (await store.getCompletedEvents("run-1", noSim))._unsafeUnwrap();
121
+ expect(completed).toHaveLength(2);
122
+ expect(completed[0].seq).toBe(4); // newest first
123
+ expect(completed[1].seq).toBe(2);
124
+ });
125
+
126
+ it("getAllEvents returns events in seq ASC order", async () => {
127
+ (await store.appendBatch([
128
+ { run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created", payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000 },
129
+ { run_id: "run-1", workflow_id: "wf-1", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
130
+ ], noSim))._unsafeUnwrap();
131
+
132
+ const all = (await store.getAllEvents("run-1", noSim))._unsafeUnwrap();
133
+ expect(all).toHaveLength(2);
134
+ expect(all[0].seq).toBe(0);
135
+ expect(all[1].seq).toBe(1);
136
+ });
137
+
138
+ it("getActiveWorkflows excludes terminal workflows", async () => {
139
+ // Active workflow
140
+ (await store.append({
141
+ run_id: "run-active", workflow_id: "wf-active", seq: 0, event_type: "workflow_created",
142
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
143
+ }, noSim))._unsafeUnwrap();
144
+
145
+ // Completed workflow
146
+ (await store.appendBatch([
147
+ { run_id: "run-done", workflow_id: "wf-done", seq: 0, event_type: "workflow_created", payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000 },
148
+ { run_id: "run-done", workflow_id: "wf-done", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
149
+ { run_id: "run-done", workflow_id: "wf-done", seq: 2, event_type: "step_completed", payload: { step: "start", writes: {} }, created_at: 1002 },
150
+ { run_id: "run-done", workflow_id: "wf-done", seq: 3, event_type: "workflow_completed", payload: { result: "ok" }, created_at: 1003 },
151
+ ], noSim))._unsafeUnwrap();
152
+
153
+ // Failed workflow
154
+ (await store.appendBatch([
155
+ { run_id: "run-fail", workflow_id: "wf-fail", seq: 0, event_type: "workflow_created", payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000 },
156
+ { run_id: "run-fail", workflow_id: "wf-fail", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
157
+ { run_id: "run-fail", workflow_id: "wf-fail", seq: 2, event_type: "step_failed", payload: { step: "start", attempt: 1, reason: "boom", retryable: false }, created_at: 1002 },
158
+ { run_id: "run-fail", workflow_id: "wf-fail", seq: 3, event_type: "workflow_failed", payload: { reason: "boom", cause: "non_retryable" }, created_at: 1003 },
159
+ ], noSim))._unsafeUnwrap();
160
+
161
+ const active = (await store.getActiveWorkflows(noSim))._unsafeUnwrap();
162
+ expect(active).toHaveLength(1);
163
+ expect(active[0].run_id).toBe("run-active");
164
+ });
165
+
166
+ it("JSON round-trips payloads correctly", async () => {
167
+ const payload = {
168
+ workflowName: "test",
169
+ writes: { nested: { arr: [1, "two", null, true], num: 3.14 } },
170
+ config: TEST_CONFIG,
171
+ };
172
+ (await store.append({
173
+ run_id: "run-json", workflow_id: "wf-json", seq: 0, event_type: "workflow_created",
174
+ payload, created_at: 1000,
175
+ }, noSim))._unsafeUnwrap();
176
+
177
+ const retrieved = (await store.getEvent("run-json", 0, noSim))._unsafeUnwrap();
178
+ expect(retrieved!.payload).toEqual(payload);
179
+ expect(retrieved!.payload).not.toBe(payload);
180
+ });
181
+
182
+ it("isolates events between different runs", async () => {
183
+ (await store.append({
184
+ run_id: "run-a", workflow_id: "wf-a", seq: 0, event_type: "workflow_created",
185
+ payload: { workflowName: "a", writes: {}, config: TEST_CONFIG }, created_at: 1000,
186
+ }, noSim))._unsafeUnwrap();
187
+ (await store.append({
188
+ run_id: "run-b", workflow_id: "wf-b", seq: 0, event_type: "workflow_created",
189
+ payload: { workflowName: "b", writes: {}, config: TEST_CONFIG }, created_at: 1000,
190
+ }, noSim))._unsafeUnwrap();
191
+
192
+ const allA = (await store.getAllEvents("run-a", noSim))._unsafeUnwrap();
193
+ const allB = (await store.getAllEvents("run-b", noSim))._unsafeUnwrap();
194
+ expect(allA).toHaveLength(1);
195
+ expect(allB).toHaveLength(1);
196
+ expect((allA[0].payload as any).workflowName).toBe("a");
197
+ expect((allB[0].payload as any).workflowName).toBe("b");
198
+ });
199
+
200
+ // --- appendIfNoActiveWorkflow tests ---
201
+
202
+ it("appendIfNoActiveWorkflow succeeds when no active run", async () => {
203
+ const event: WorkflowEvent = {
204
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
205
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
206
+ };
207
+ const result = await store.appendIfNoActiveWorkflow("wf-1", event, noSim);
208
+ expect(result.isOk()).toBe(true);
209
+
210
+ const last = (await store.getLastEvent("run-1", noSim))._unsafeUnwrap();
211
+ expect(last).toEqual(event);
212
+ });
213
+
214
+ it("appendIfNoActiveWorkflow rejects when active run exists", async () => {
215
+ (await store.appendIfNoActiveWorkflow("wf-1", {
216
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
217
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
218
+ }, noSim))._unsafeUnwrap();
219
+
220
+ const result = await store.appendIfNoActiveWorkflow("wf-1", {
221
+ run_id: "run-2", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
222
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 2000,
223
+ }, noSim);
224
+
225
+ expect(result.isErr()).toBe(true);
226
+ expect(result._unsafeUnwrapErr()).toBeInstanceOf(WorkflowAlreadyActiveError);
227
+ });
228
+
229
+ it("appendIfNoActiveWorkflow allows after terminal event", async () => {
230
+ // Create and complete a workflow
231
+ (await store.appendIfNoActiveWorkflow("wf-1", {
232
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
233
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
234
+ }, noSim))._unsafeUnwrap();
235
+ (await store.appendBatch([
236
+ { run_id: "run-1", workflow_id: "wf-1", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
237
+ { run_id: "run-1", workflow_id: "wf-1", seq: 2, event_type: "step_completed", payload: { step: "start", writes: {} }, created_at: 1002 },
238
+ { run_id: "run-1", workflow_id: "wf-1", seq: 3, event_type: "workflow_completed", payload: { result: "ok" }, created_at: 1003 },
239
+ ], noSim))._unsafeUnwrap();
240
+
241
+ // Now a new run with the same workflow_id should succeed
242
+ const result = await store.appendIfNoActiveWorkflow("wf-1", {
243
+ run_id: "run-2", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
244
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 2000,
245
+ }, noSim);
246
+ expect(result.isOk()).toBe(true);
247
+ });
248
+
249
+ // --- getRecentRuns tests ---
250
+
251
+ it("getRecentRuns returns workflow_created events ordered by created_at DESC", async () => {
252
+ (await store.appendBatch([
253
+ { run_id: "run-old", workflow_id: "wf-old", seq: 0, event_type: "workflow_created", payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000 },
254
+ { run_id: "run-old", workflow_id: "wf-old", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
255
+ { run_id: "run-old", workflow_id: "wf-old", seq: 2, event_type: "step_completed", payload: { step: "start", writes: {} }, created_at: 1002 },
256
+ { run_id: "run-old", workflow_id: "wf-old", seq: 3, event_type: "workflow_completed", payload: { result: "ok" }, created_at: 1003 },
257
+ ], noSim))._unsafeUnwrap();
258
+
259
+ (await store.append({
260
+ run_id: "run-new", workflow_id: "wf-new", seq: 0, event_type: "workflow_created",
261
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 2000,
262
+ }, noSim))._unsafeUnwrap();
263
+
264
+ (await store.append({
265
+ run_id: "run-mid", workflow_id: "wf-mid", seq: 0, event_type: "workflow_created",
266
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1500,
267
+ }, noSim))._unsafeUnwrap();
268
+
269
+ const runs = (await store.getRecentRuns(10, noSim))._unsafeUnwrap();
270
+ expect(runs).toHaveLength(3);
271
+ expect(runs[0].run_id).toBe("run-new");
272
+ expect(runs[1].run_id).toBe("run-mid");
273
+ expect(runs[2].run_id).toBe("run-old");
274
+ // All should be seq=0 (workflow_created)
275
+ for (const run of runs) {
276
+ expect(run.seq).toBe(0);
277
+ expect(run.event_type).toBe("workflow_created");
278
+ }
279
+ });
280
+
281
+ it("getRecentRuns respects limit", async () => {
282
+ (await store.append({
283
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
284
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
285
+ }, noSim))._unsafeUnwrap();
286
+ (await store.append({
287
+ run_id: "run-2", workflow_id: "wf-2", seq: 0, event_type: "workflow_created",
288
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 2000,
289
+ }, noSim))._unsafeUnwrap();
290
+ (await store.append({
291
+ run_id: "run-3", workflow_id: "wf-3", seq: 0, event_type: "workflow_created",
292
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 3000,
293
+ }, noSim))._unsafeUnwrap();
294
+
295
+ const runs = (await store.getRecentRuns(2, noSim))._unsafeUnwrap();
296
+ expect(runs).toHaveLength(2);
297
+ expect(runs[0].run_id).toBe("run-3");
298
+ expect(runs[1].run_id).toBe("run-2");
299
+ });
300
+
301
+ it("getRecentRuns returns empty array when no runs exist", async () => {
302
+ const runs = (await store.getRecentRuns(10, noSim))._unsafeUnwrap();
303
+ expect(runs).toHaveLength(0);
304
+ });
305
+
306
+ it("getRecentRuns includes both active and completed workflows", async () => {
307
+ // Active workflow
308
+ (await store.append({
309
+ run_id: "run-active", workflow_id: "wf-active", seq: 0, event_type: "workflow_created",
310
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 2000,
311
+ }, noSim))._unsafeUnwrap();
312
+
313
+ // Completed workflow
314
+ (await store.appendBatch([
315
+ { run_id: "run-done", workflow_id: "wf-done", seq: 0, event_type: "workflow_created", payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000 },
316
+ { run_id: "run-done", workflow_id: "wf-done", seq: 1, event_type: "step_started", payload: { step: "start", attempt: 1 }, created_at: 1001 },
317
+ { run_id: "run-done", workflow_id: "wf-done", seq: 2, event_type: "step_completed", payload: { step: "start", writes: {} }, created_at: 1002 },
318
+ { run_id: "run-done", workflow_id: "wf-done", seq: 3, event_type: "workflow_completed", payload: { result: "ok" }, created_at: 1003 },
319
+ ], noSim))._unsafeUnwrap();
320
+
321
+ const runs = (await store.getRecentRuns(10, noSim))._unsafeUnwrap();
322
+ expect(runs).toHaveLength(2);
323
+ // Both active and completed should appear
324
+ const runIds = runs.map(r => r.run_id);
325
+ expect(runIds).toContain("run-active");
326
+ expect(runIds).toContain("run-done");
327
+ });
328
+
329
+ it("rejects appending event with mismatched workflow_id for existing run_id", async () => {
330
+ (await store.append({
331
+ run_id: "run-1", workflow_id: "wf-1", seq: 0, event_type: "workflow_created",
332
+ payload: { workflowName: "test", writes: {}, config: TEST_CONFIG }, created_at: 1000,
333
+ }, noSim))._unsafeUnwrap();
334
+
335
+ const result = await store.append({
336
+ run_id: "run-1", workflow_id: "wf-WRONG", seq: 1, event_type: "step_started",
337
+ payload: { step: "start", attempt: 1 }, created_at: 1001,
338
+ }, noSim);
339
+
340
+ expect(result.isErr()).toBe(true);
341
+ expect(result._unsafeUnwrapErr()).toBeInstanceOf(WorkflowIdMismatchError);
342
+ });
343
+ });
344
+ }
@@ -0,0 +1,8 @@
1
+ import { storeConformanceTests } from "./store-conformance.js";
2
+ import { MemoryEventStore } from "../src/store-memory.js";
3
+
4
+ storeConformanceTests("MemoryEventStore", async () => {
5
+ const store = new MemoryEventStore();
6
+ (await store.initialize())._unsafeUnwrap();
7
+ return store;
8
+ });
@@ -0,0 +1,8 @@
1
+ import { storeConformanceTests } from "./store-conformance.js";
2
+ import { SqliteEventStore } from "../src/store-sqlite.js";
3
+
4
+ storeConformanceTests("SqliteEventStore", async () => {
5
+ const store = new SqliteEventStore(":memory:");
6
+ (await store.initialize())._unsafeUnwrap();
7
+ return store;
8
+ });
@@ -0,0 +1,18 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2022",
4
+ "module": "ES2022",
5
+ "moduleResolution": "bundler",
6
+ "declaration": true,
7
+ "outDir": "dist",
8
+ "rootDir": "src",
9
+ "strict": true,
10
+ "esModuleInterop": true,
11
+ "skipLibCheck": true,
12
+ "forceConsistentCasingInFileNames": true,
13
+ "resolveJsonModule": true,
14
+ "sourceMap": true
15
+ },
16
+ "include": ["src/**/*.ts"],
17
+ "exclude": ["node_modules", "dist", "test"]
18
+ }
@@ -0,0 +1,5 @@
1
+ {
2
+ "extends": "./tsconfig.typecheck.json",
3
+ "include": ["src/**/*.ts", "test/**/*.ts", "vitest.config.ts"],
4
+ "exclude": ["node_modules", "dist"]
5
+ }
@@ -0,0 +1,20 @@
1
+ {
2
+ "extends": "./tsconfig.json",
3
+ "compilerOptions": {
4
+ "noEmit": true,
5
+ "rootDir": ".",
6
+ "strict": true,
7
+ "noUnusedLocals": true,
8
+ "noUnusedParameters": true,
9
+ "exactOptionalPropertyTypes": true,
10
+ "noImplicitReturns": true,
11
+ "noFallthroughCasesInSwitch": true,
12
+ "noUncheckedIndexedAccess": true,
13
+ "noImplicitOverride": true,
14
+ "noPropertyAccessFromIndexSignature": true,
15
+ "allowUnusedLabels": false,
16
+ "allowUnreachableCode": false
17
+ },
18
+ "include": ["src/**/*.ts"],
19
+ "exclude": ["node_modules", "dist"]
20
+ }
@@ -0,0 +1,10 @@
1
+ import { defineConfig } from "vitest/config";
2
+
3
+ export default defineConfig({
4
+ test: {
5
+ globals: true,
6
+ environment: "node",
7
+ include: ["test/**/*.test.ts"],
8
+ exclude: ["**/node_modules/**", "**/dist/**"],
9
+ },
10
+ });
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2018 Mathias Buus
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
@@ -0,0 +1,26 @@
1
+ # fs-constants
2
+
3
+ Small module that allows you to get the fs constants across
4
+ Node and the browser.
5
+
6
+ ```
7
+ npm install fs-constants
8
+ ```
9
+
10
+ Previously you would use `require('constants')` for this in node but that has been
11
+ deprecated and changed to `require('fs').constants` which does not browserify.
12
+
13
+ This module uses `require('constants')` in the browser and `require('fs').constants` in node to work around this
14
+
15
+
16
+ ## Usage
17
+
18
+ ``` js
19
+ var constants = require('fs-constants')
20
+
21
+ console.log('constants:', constants)
22
+ ```
23
+
24
+ ## License
25
+
26
+ MIT
@@ -0,0 +1 @@
1
+ module.exports = require('constants')
@@ -0,0 +1 @@
1
+ module.exports = require('fs').constants || require('constants')
@@ -0,0 +1,19 @@
1
+ {
2
+ "name": "fs-constants",
3
+ "version": "1.0.0",
4
+ "description": "Require constants across node and the browser",
5
+ "main": "index.js",
6
+ "browser": "browser.js",
7
+ "dependencies": {},
8
+ "devDependencies": {},
9
+ "repository": {
10
+ "type": "git",
11
+ "url": "https://github.com/mafintosh/fs-constants.git"
12
+ },
13
+ "author": "Mathias Buus (@mafintosh)",
14
+ "license": "MIT",
15
+ "bugs": {
16
+ "url": "https://github.com/mafintosh/fs-constants/issues"
17
+ },
18
+ "homepage": "https://github.com/mafintosh/fs-constants"
19
+ }
@@ -0,0 +1,4 @@
1
+ language: node_js
2
+ node_js:
3
+ - 0.6
4
+ - 0.8
@@ -0,0 +1,18 @@
1
+ This software is released under the MIT license:
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining a copy of
4
+ this software and associated documentation files (the "Software"), to deal in
5
+ the Software without restriction, including without limitation the rights to
6
+ use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
7
+ the Software, and to permit persons to whom the Software is furnished to do so,
8
+ subject to the following conditions:
9
+
10
+ The above copyright notice and this permission notice shall be included in all
11
+ copies or substantial portions of the Software.
12
+
13
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
15
+ FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
16
+ COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
17
+ IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
18
+ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "beep-boop",
3
+ "version": "1.2.3",
4
+ "repository" : {
5
+ "type" : "git",
6
+ "url": "git@github.com:substack/beep-boop.git"
7
+ }
8
+ }
@@ -0,0 +1,3 @@
1
+ var github = require('../');
2
+ var url = github(require('./package.json'));
3
+ console.log(url);
@@ -0,0 +1,17 @@
1
+ module.exports = function (pkg) {
2
+ var m;
3
+ if (m = match(JSON.stringify(pkg.repository))) {
4
+ return m;
5
+ }
6
+ else if (m = match(JSON.stringify(pkg))) {
7
+ return m;
8
+ }
9
+ return undefined;
10
+ };
11
+
12
+ function match (str) {
13
+ var m = /\bgithub.com[:\/]([^\/"]+)\/([^\/"]+)/.exec(str);
14
+ if (m) {
15
+ return 'https://github.com/' + m[1] + '/' + m[2].replace(/\.git$/, '');
16
+ }
17
+ }
@@ -0,0 +1,30 @@
1
+ {
2
+ "name" : "github-from-package",
3
+ "version" : "0.0.0",
4
+ "description" : "return the github url from a package.json file",
5
+ "main" : "index.js",
6
+ "devDependencies" : {
7
+ "tap" : "~0.3.0",
8
+ "tape" : "~0.1.5"
9
+ },
10
+ "scripts" : {
11
+ "test" : "tap test/*.js"
12
+ },
13
+ "repository" : {
14
+ "type" : "git",
15
+ "url" : "git://github.com/substack/github-from-package.git"
16
+ },
17
+ "homepage" : "https://github.com/substack/github-from-package",
18
+ "keywords" : [
19
+ "github",
20
+ "package.json",
21
+ "npm",
22
+ "repository"
23
+ ],
24
+ "author" : {
25
+ "name" : "James Halliday",
26
+ "email" : "mail@substack.net",
27
+ "url" : "http://substack.net"
28
+ },
29
+ "license" : "MIT"
30
+ }
@@ -0,0 +1,53 @@
1
+ # github-from-package
2
+
3
+ return the github url from a package.json file
4
+
5
+ [![build status](https://secure.travis-ci.org/substack/github-from-package.png)](http://travis-ci.org/substack/github-from-package)
6
+
7
+ # example
8
+
9
+ For the `./package.json` file:
10
+
11
+ ``` json
12
+ {
13
+ "name": "beep-boop",
14
+ "version": "1.2.3",
15
+ "repository" : {
16
+ "type" : "git",
17
+ "url": "git@github.com:substack/beep-boop.git"
18
+ }
19
+ }
20
+ ```
21
+
22
+ ``` js
23
+ var github = require('github-from-package');
24
+ var url = github(require('./package.json'));
25
+ console.log(url);
26
+ ```
27
+
28
+ ```
29
+ https://github.com/substack/beep-boop
30
+ ```
31
+
32
+ # methods
33
+
34
+ ``` js
35
+ var github = require('github-from-package')
36
+ ```
37
+
38
+ ## var url = github(pkg)
39
+
40
+ Return the most likely github url from the package.json contents `pkg`. If no
41
+ github url can be determined, return `undefined`.
42
+
43
+ # install
44
+
45
+ With [npm](https://npmjs.org) do:
46
+
47
+ ```
48
+ npm install github-from-package
49
+ ```
50
+
51
+ # license
52
+
53
+ MIT
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "beep-boop",
3
+ "version": "1.2.3",
4
+ "repository" : {
5
+ "type" : "git",
6
+ "url": "git@github.com:substack/beep-boop.git"
7
+ }
8
+ }
@@ -0,0 +1,5 @@
1
+ {
2
+ "name": "beep-boop",
3
+ "version": "1.2.3",
4
+ "repository" : "git@github.com:substack/beep-boop.git"
5
+ }