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,423 @@
1
+ import {
2
+ SimulationImpl,
3
+ NoSimulationTask,
4
+ type EntropySource,
5
+ type SimulationTask,
6
+ type TaskSpec,
7
+ } from "determined";
8
+ import { defined } from "@glideapps/ts-necessities";
9
+ import { Engine } from "./engine.js";
10
+ import { MemoryEventStore } from "./store-memory.js";
11
+ import { SqliteEventStore } from "./store-sqlite.js";
12
+ import { WorkflowRegistry } from "./registry.js";
13
+ import { ManualClock } from "./clock.js";
14
+ import { runRecovery } from "./recovery.js";
15
+ import type { EventStore, EventStoreCheck } from "./store.js";
16
+ import type { Continuation, Ctx, StepFailedPayload, WorkflowEvent } from "./types.js";
17
+
18
+ // ---------------------------------------------------------------------------
19
+ // CLI argument parsing
20
+ // ---------------------------------------------------------------------------
21
+
22
+ const args = process.argv.slice(2);
23
+
24
+ function getArg(name: string, defaultValue: string): string {
25
+ const idx = args.indexOf(name);
26
+ if (idx === -1 || idx + 1 >= args.length) return defaultValue;
27
+ return defined(args[idx + 1]);
28
+ }
29
+
30
+ const count = parseInt(getArg("--count", "10"));
31
+ const storeType = getArg("--store", "memory") as "memory" | "sqlite";
32
+ const numWorkers = parseInt(getArg("--workers", "4"));
33
+ const numSeeds = parseInt(getArg("--seeds", "50"));
34
+ const failureProbability = parseFloat(getArg("--failure", "0.1"));
35
+ const maxAttempts = parseInt(getArg("--max-attempts", "5"));
36
+ const stepTimeoutMs = 5_000;
37
+
38
+ // ---------------------------------------------------------------------------
39
+ // Seeded entropy source (LCG)
40
+ // ---------------------------------------------------------------------------
41
+
42
+ function seededEntropy(seed: number): EntropySource {
43
+ let state = seed | 0;
44
+ return {
45
+ random(_reason: string): number {
46
+ state = (Math.imul(state, 1664525) + 1013904223) | 0;
47
+ return (state >>> 0) / 0x100000000;
48
+ },
49
+ };
50
+ }
51
+
52
+ // ---------------------------------------------------------------------------
53
+ // In-memory key-value store with failpoints
54
+ // ---------------------------------------------------------------------------
55
+
56
+ const noSim = new NoSimulationTask("kv", false);
57
+
58
+ class SimKV {
59
+ private data = new Map<string, unknown>();
60
+
61
+ async get(key: string, sim: SimulationTask): Promise<unknown> {
62
+ await sim.failpoint("kv.get:before", key);
63
+ const value = this.data.get(key);
64
+ await sim.failpoint("kv.get:after", key);
65
+ return value;
66
+ }
67
+
68
+ async set(key: string, value: unknown, sim: SimulationTask): Promise<void> {
69
+ await sim.failpoint("kv.set:before", key);
70
+ this.data.set(key, value);
71
+ await sim.failpoint("kv.set:after", key);
72
+ }
73
+ }
74
+
75
+ // ---------------------------------------------------------------------------
76
+ // Event-log consistency check (called on every store mutation)
77
+ // ---------------------------------------------------------------------------
78
+
79
+ const validTransitions: Partial<Record<string, string[]>> = {
80
+ workflow_created: ["step_started"],
81
+ step_started: ["step_completed", "step_failed"],
82
+ step_completed: ["step_started", "workflow_completed"],
83
+ step_failed: ["step_started", "workflow_failed"],
84
+ };
85
+
86
+ function makeCheck(): EventStoreCheck {
87
+ return (runId: string, events: WorkflowEvent[]) => {
88
+ if (events.length === 0) return;
89
+ for (let i = 0; i < events.length; i++) {
90
+ const event = defined(events[i]);
91
+ if (event.seq !== i) {
92
+ throw new Error(`Check [${runId}]: expected seq ${i}, got ${event.seq}`);
93
+ }
94
+ }
95
+ if (defined(events[0]).event_type !== "workflow_created") {
96
+ throw new Error(`Check [${runId}]: first event is ${defined(events[0]).event_type}`);
97
+ }
98
+ for (let i = 0; i < events.length - 1; i++) {
99
+ const from = defined(events[i]).event_type;
100
+ const to = defined(events[i + 1]).event_type;
101
+ const allowed = validTransitions[from];
102
+ if (!allowed?.includes(to)) {
103
+ throw new Error(`Check [${runId}]: invalid transition ${from} → ${to} at seq ${i}→${i + 1}`);
104
+ }
105
+ }
106
+ const terminals = events.filter(
107
+ (e) => e.event_type === "workflow_completed" || e.event_type === "workflow_failed",
108
+ );
109
+ if (terminals.length > 1) {
110
+ throw new Error(`Check [${runId}]: ${terminals.length} terminal events`);
111
+ }
112
+ };
113
+ }
114
+
115
+ // ---------------------------------------------------------------------------
116
+ // Sum-of-squares workflow
117
+ // ---------------------------------------------------------------------------
118
+
119
+ function parseStep(step: string): { phase: "set" | "sum-init" | "add"; index: number } {
120
+ if (step === "start") return { phase: "set", index: 1 };
121
+ if (step === "sum-init") return { phase: "sum-init", index: 0 };
122
+ if (step.startsWith("set-")) return { phase: "set", index: parseInt(step.slice(4)) };
123
+ if (step.startsWith("add-")) return { phase: "add", index: parseInt(step.slice(4)) };
124
+ throw new Error(`Unknown step: ${step}`);
125
+ }
126
+
127
+ function makeSumOfSquaresWorkflow(kv: SimKV): (ctx: Ctx) => Promise<Continuation> {
128
+ return async (ctx: Ctx): Promise<Continuation> => {
129
+ const sim: SimulationTask = ctx.sim;
130
+ const n = await ctx.get("count") as number;
131
+ const parsed = parseStep(ctx.step);
132
+
133
+ switch (parsed.phase) {
134
+ case "set": {
135
+ const i = parsed.index;
136
+ await kv.set(String(i), i * i, sim);
137
+ if (i < n) return { step: `set-${i + 1}` };
138
+ return { step: "sum-init" };
139
+ }
140
+ case "sum-init": {
141
+ ctx.set("sum", 0);
142
+ return { step: "add-1" };
143
+ }
144
+ case "add": {
145
+ const i = parsed.index;
146
+ const value = (await kv.get(String(i), sim)) as number;
147
+ const sum = ((await ctx.get("sum")) as number) + value;
148
+ ctx.set("sum", sum);
149
+ if (i < n) return { step: `add-${i + 1}` };
150
+ return { done: true, result: { sum } };
151
+ }
152
+ }
153
+ };
154
+ }
155
+
156
+ // ---------------------------------------------------------------------------
157
+ // Store factory
158
+ // ---------------------------------------------------------------------------
159
+
160
+ function createStore(check: EventStoreCheck): EventStore {
161
+ if (storeType === "sqlite") {
162
+ return new SqliteEventStore(":memory:", { check });
163
+ }
164
+ return new MemoryEventStore({ check });
165
+ }
166
+
167
+ // ---------------------------------------------------------------------------
168
+ // Run a single seed
169
+ // ---------------------------------------------------------------------------
170
+
171
+ async function runSeed(seed: number): Promise<{ ok: boolean; detail?: string }> {
172
+ const kv = new SimKV();
173
+ const store = createStore(makeCheck());
174
+ const initResult = await store.initialize();
175
+ if (initResult.isErr()) {
176
+ return { ok: false, detail: `initialize failed: ${initResult.error.message}` };
177
+ }
178
+
179
+ const registry = new WorkflowRegistry();
180
+ registry.register({
181
+ name: "sum-of-squares",
182
+ fn: makeSumOfSquaresWorkflow(kv),
183
+ maxAttempts,
184
+ initialBackoffMS: 0,
185
+ stepTimeoutMS: stepTimeoutMs,
186
+ });
187
+
188
+ const clock = new ManualClock(1_000_000);
189
+ let idCounter = 0;
190
+
191
+ const engine = new Engine({
192
+ store,
193
+ registry,
194
+ clock,
195
+ generateId: () => `run-${++idCounter}`,
196
+ });
197
+
198
+ const createResult = await engine.createWorkflow("sum-of-squares-wf", "sum-of-squares", { count }, noSim);
199
+ if (createResult.isErr()) {
200
+ return { ok: false, detail: `createWorkflow failed: ${createResult.error.message}` };
201
+ }
202
+ const runId = createResult.value;
203
+
204
+ // Total steps: count (set) + 1 (sum-init) + count (add) = 2*count + 1
205
+ // ~16 failpoints per step attempt (store reads/writes + engine + kv).
206
+ // Scale iterations so we have enough budget at higher failure rates.
207
+ const totalSteps = 2 * count + 1;
208
+ const failpointsPerStep = 16;
209
+ const attemptsPerStep = Math.ceil(1 / Math.pow(1 - failureProbability, failpointsPerStep));
210
+ const iterationsPerWorker = Math.max(1000, totalSteps * attemptsPerStep * 5);
211
+
212
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
213
+ const logger = { log: () => {}, error: () => {} };
214
+ const entropy = seededEntropy(seed);
215
+ const sim = new SimulationImpl(logger, entropy, failureProbability);
216
+
217
+ const specs: TaskSpec<void>[] = [];
218
+
219
+ for (let i = 0; i < numWorkers; i++) {
220
+ specs.push({
221
+ name: `worker-${i}`,
222
+ f: async (task: SimulationTask) => {
223
+ for (let j = 0; j < iterationsPerWorker; j++) {
224
+ try {
225
+ const stepResult = await engine.executeStep(runId, task);
226
+ if (stepResult.isErr()) {
227
+ // Result error — treat as crash, keep going
228
+ continue;
229
+ }
230
+ const ran = stepResult.value;
231
+ if (ran === false) {
232
+ // Nothing claimable — workflow may be done. Check.
233
+ const lastResult = await store.getLastEvent(runId, task);
234
+ if (lastResult.isErr()) continue; // treat as crash
235
+ const last = lastResult.value;
236
+ if (
237
+ last?.event_type === "workflow_completed" ||
238
+ last?.event_type === "workflow_failed"
239
+ ) {
240
+ break;
241
+ }
242
+ }
243
+ } catch {
244
+ // failpoint crash — keep going
245
+ }
246
+ }
247
+ },
248
+ });
249
+ }
250
+
251
+ specs.push({
252
+ name: "recovery",
253
+ f: async (task: SimulationTask) => {
254
+ for (;;) {
255
+ try {
256
+ const lastResult = await store.getLastEvent(runId, task);
257
+ if (lastResult.isErr()) continue; // treat as crash
258
+ const last = lastResult.value;
259
+ if (
260
+ last?.event_type === "workflow_completed" ||
261
+ last?.event_type === "workflow_failed"
262
+ ) {
263
+ break;
264
+ }
265
+ // Advance the clock so that timed-out steps get detected.
266
+ // This is always safe: recovery only acts on genuinely
267
+ // stuck workflows (timed-out step_started, or states
268
+ // where the next step should have been claimed but wasn't).
269
+ clock.advance(stepTimeoutMs + 1000);
270
+ const recoveryResult = await runRecovery({ store, registry, clock }, task);
271
+ if (recoveryResult.isErr()) continue; // treat as crash
272
+ const recovered = recoveryResult.value;
273
+ for (const r of recovered) {
274
+ const reasonChar: Record<string, string> = {
275
+ timeout: "T",
276
+ stuck_created: "C",
277
+ stuck_completed: "N",
278
+ stuck_failed: "F",
279
+ stuck_terminal: "X",
280
+ };
281
+ process.stderr.write(reasonChar[r.reason] ?? "?");
282
+ try {
283
+ const execResult = await engine.executeStep(r.runId, task);
284
+ if (execResult.isErr()) {
285
+ // failpoint — treat as crash
286
+ }
287
+ } catch {
288
+ // failpoint
289
+ }
290
+ }
291
+ } catch {
292
+ // failpoint in recovery store ops
293
+ }
294
+ }
295
+ },
296
+ });
297
+
298
+ await sim.runTasks(specs as readonly TaskSpec<void>[]);
299
+
300
+ // Validate result
301
+ const eventsResult = await store.getAllEvents(runId, noSim);
302
+ if (eventsResult.isErr()) {
303
+ return { ok: false, detail: `getAllEvents failed: ${eventsResult.error.message}` };
304
+ }
305
+ const events = eventsResult.value;
306
+ if (events.length === 0) {
307
+ return { ok: false, detail: "no events" };
308
+ }
309
+
310
+ // Validate the trace structure: sequential numbering
311
+ for (let i = 0; i < events.length; i++) {
312
+ if (defined(events[i]).seq !== i) {
313
+ return { ok: false, detail: `seq gap at ${i}` };
314
+ }
315
+ }
316
+
317
+ // Validate transitions
318
+ for (let i = 0; i < events.length - 1; i++) {
319
+ const from = defined(events[i]).event_type;
320
+ const to = defined(events[i + 1]).event_type;
321
+ const allowed = validTransitions[from];
322
+ if (!allowed?.includes(to)) {
323
+ return { ok: false, detail: `invalid transition ${from} → ${to} at ${i}` };
324
+ }
325
+ }
326
+
327
+ // Validate per-step retry chains: attempt numbers must be sequential
328
+ // and never exceed maxAttempts
329
+ for (let i = 0; i < events.length; i++) {
330
+ const event = defined(events[i]);
331
+ if (event.event_type !== "step_started") continue;
332
+ const payload = event.payload;
333
+
334
+ if (payload.attempt > maxAttempts) {
335
+ return { ok: false, detail: `step "${payload.step}" attempt ${payload.attempt} exceeds maxAttempts ${maxAttempts} at seq ${i}` };
336
+ }
337
+
338
+ // Check that the attempt number is consistent with the preceding event
339
+ const prev = defined(events[i - 1]);
340
+ if (prev.event_type === "workflow_created" || prev.event_type === "step_completed") {
341
+ if (payload.attempt !== 1) {
342
+ return { ok: false, detail: `step "${payload.step}" should start at attempt 1 after ${prev.event_type}, got ${payload.attempt} at seq ${i}` };
343
+ }
344
+ } else if (prev.event_type === "step_failed") {
345
+ const prevPayload = prev.payload;
346
+ if (payload.attempt !== prevPayload.attempt + 1) {
347
+ return { ok: false, detail: `step "${payload.step}" attempt ${payload.attempt} should be ${prevPayload.attempt + 1} after step_failed at seq ${i}` };
348
+ }
349
+ }
350
+ }
351
+
352
+ // Check terminal event
353
+ const last = defined(events[events.length - 1]);
354
+
355
+ if (last.event_type === "workflow_failed") {
356
+ const payload = last.payload;
357
+ if (payload.cause === "max_attempts_exceeded") {
358
+ // Find the most recent step_failed event
359
+ let lastStepFailed: WorkflowEvent | undefined;
360
+ for (let i = events.length - 1; i >= 0; i--) {
361
+ if (defined(events[i]).event_type === "step_failed") {
362
+ lastStepFailed = defined(events[i]);
363
+ break;
364
+ }
365
+ }
366
+ if (lastStepFailed === undefined) {
367
+ return { ok: false, detail: "workflow_failed with max_attempts_exceeded but no step_failed found" };
368
+ }
369
+ const failedPayload = lastStepFailed.payload as StepFailedPayload;
370
+ if (failedPayload.attempt !== maxAttempts) {
371
+ return { ok: false, detail: `workflow_failed with max_attempts_exceeded but last step_failed attempt is ${failedPayload.attempt}, expected ${maxAttempts}` };
372
+ }
373
+ return { ok: true };
374
+ }
375
+ return { ok: false, detail: `workflow failed: ${payload.reason} (cause: ${payload.cause})` };
376
+ }
377
+
378
+ if (last.event_type !== "workflow_completed") {
379
+ return { ok: false, detail: `not terminal (last=${last.event_type}, ${events.length} events)` };
380
+ }
381
+
382
+ const result = last.payload.result as { sum: number };
383
+ const expected = (count * (count + 1) * (2 * count + 1)) / 6;
384
+ if (result.sum !== expected) {
385
+ return { ok: false, detail: `wrong result: got ${result.sum}, expected ${expected}` };
386
+ }
387
+
388
+ return { ok: true };
389
+ }
390
+
391
+ // ---------------------------------------------------------------------------
392
+ // Main
393
+ // ---------------------------------------------------------------------------
394
+
395
+ async function main(): Promise<void> {
396
+ console.log(
397
+ `stress test: count=${count} store=${storeType} workers=${numWorkers} ` +
398
+ `seeds=${numSeeds} failure=${failureProbability}`,
399
+ );
400
+
401
+ let passed = 0;
402
+ let failed = 0;
403
+
404
+ for (let seed = 0; seed < numSeeds; seed++) {
405
+ const { ok, detail } = await runSeed(seed);
406
+ if (ok) {
407
+ passed++;
408
+ process.stdout.write(".");
409
+ } else {
410
+ failed++;
411
+ process.stdout.write("\n");
412
+ console.error(` FAIL seed ${seed}: ${detail}`);
413
+ }
414
+ }
415
+
416
+ console.log(`\n\n${passed} passed, ${failed} failed (${numSeeds} seeds)`);
417
+ if (failed > 0) process.exit(1);
418
+ }
419
+
420
+ main().catch((err: unknown) => {
421
+ console.error(err);
422
+ process.exit(1);
423
+ });
@@ -0,0 +1,38 @@
1
+ import type { WorkflowEvent } from "./types.js";
2
+
3
+ export type TransitionResult =
4
+ | { action: "start_step"; step: string; attempt: number }
5
+ | { action: "complete_workflow" }
6
+ | { action: "fail_workflow"; reason: string }
7
+ | { action: "none" };
8
+
9
+ export function resolveTransition(lastEvent: WorkflowEvent, maxAttempts: number): TransitionResult {
10
+ switch (lastEvent.event_type) {
11
+ case "workflow_created":
12
+ return { action: "start_step", step: "start", attempt: 1 };
13
+
14
+ case "step_completed": {
15
+ const { next_step } = lastEvent.payload;
16
+ if (next_step !== undefined) {
17
+ return { action: "start_step", step: next_step, attempt: 1 };
18
+ }
19
+ return { action: "complete_workflow" };
20
+ }
21
+
22
+ case "step_failed": {
23
+ const { retryable, attempt, step } = lastEvent.payload;
24
+ if (!retryable) {
25
+ return { action: "fail_workflow", reason: lastEvent.payload.reason };
26
+ }
27
+ if (attempt >= maxAttempts) {
28
+ return { action: "fail_workflow", reason: `max attempts (${maxAttempts}) exceeded: ${lastEvent.payload.reason}` };
29
+ }
30
+ return { action: "start_step", step, attempt: attempt + 1 };
31
+ }
32
+
33
+ case "step_started":
34
+ case "workflow_completed":
35
+ case "workflow_failed":
36
+ return { action: "none" };
37
+ }
38
+ }
@@ -0,0 +1,84 @@
1
+ import { ApplicationFailure, isApplicationFailure, type SimulationTask } from "determined";
2
+
3
+ // Re-export determined types used by consumers
4
+ export type { SimulationTask };
5
+ export { ApplicationFailure, isApplicationFailure };
6
+
7
+ export class NonRetryableError extends ApplicationFailure {
8
+ constructor(message: string) {
9
+ super(message, undefined, true);
10
+ }
11
+ }
12
+
13
+ // --- Workflow config (sealed into workflow_created event) ---
14
+
15
+ export interface WorkflowConfig {
16
+ maxAttempts: number;
17
+ initialBackoffMS: number;
18
+ backoffMultiplier: number;
19
+ maxBackoffMS: number;
20
+ stepTimeoutMS: number;
21
+ }
22
+
23
+ // --- Step outcome (returned by executeStep) ---
24
+
25
+ export type StepOutcome =
26
+ | false // nothing to claim (terminal/done)
27
+ | true // step executed, continue immediately
28
+ | { backoffMS: number }; // step failed (retryable), wait before retry (backoffMS > 0)
29
+
30
+ // --- Core workflow types ---
31
+
32
+ export type Continuation =
33
+ | { step: string }
34
+ | { done: true; result: unknown };
35
+
36
+ export interface Ctx {
37
+ workflowId: string;
38
+ runId: string;
39
+ step: string;
40
+ sim: SimulationTask;
41
+ get(key: string): Promise<unknown>;
42
+ set(key: string, value: unknown): void;
43
+ }
44
+
45
+ export type WorkflowFn = (ctx: Ctx) => Promise<Continuation>;
46
+
47
+ // --- Typed event payloads ---
48
+
49
+ export interface WorkflowCreatedPayload { workflowName: string; writes: Record<string, unknown>; config: WorkflowConfig }
50
+ export interface StepStartedPayload { step: string; attempt: number }
51
+ export interface StepCompletedPayload { step: string; writes: Record<string, unknown>; next_step?: string }
52
+ export interface StepFailedPayload { step: string; attempt: number; reason: string; retryable: boolean }
53
+ export interface WorkflowCompletedPayload { result: unknown }
54
+ export type WorkflowFailureCause = "max_attempts_exceeded" | "non_retryable";
55
+ export interface WorkflowFailedPayload { reason: string; cause: WorkflowFailureCause }
56
+
57
+ // --- Discriminated union for WorkflowEvent ---
58
+
59
+ export type WorkflowEvent =
60
+ | { run_id: string; workflow_id: string; seq: number; event_type: "workflow_created"; payload: WorkflowCreatedPayload; created_at: number }
61
+ | { run_id: string; workflow_id: string; seq: number; event_type: "step_started"; payload: StepStartedPayload; created_at: number }
62
+ | { run_id: string; workflow_id: string; seq: number; event_type: "step_completed"; payload: StepCompletedPayload; created_at: number }
63
+ | { run_id: string; workflow_id: string; seq: number; event_type: "step_failed"; payload: StepFailedPayload; created_at: number }
64
+ | { run_id: string; workflow_id: string; seq: number; event_type: "workflow_completed"; payload: WorkflowCompletedPayload; created_at: number }
65
+ | { run_id: string; workflow_id: string; seq: number; event_type: "workflow_failed"; payload: WorkflowFailedPayload; created_at: number };
66
+
67
+ export type EventType = WorkflowEvent["event_type"];
68
+
69
+ // --- Terminal event types ---
70
+
71
+ export const TERMINAL_EVENT_TYPES: readonly string[] = ["workflow_completed", "workflow_failed"];
72
+
73
+ // --- Claim result ---
74
+
75
+ export interface ClaimResult {
76
+ workflowId: string;
77
+ runId: string;
78
+ workflowName: string;
79
+ step: string;
80
+ attempt: number;
81
+ seq: number;
82
+ initialWrites: Record<string, unknown>;
83
+ config: WorkflowConfig;
84
+ }
@@ -0,0 +1,54 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import { calculateBackoffMS } from "../src/backoff.js";
3
+ import type { WorkflowConfig } from "../src/types.js";
4
+
5
+ const config: WorkflowConfig = {
6
+ maxAttempts: 5,
7
+ initialBackoffMS: 1000,
8
+ backoffMultiplier: 2,
9
+ maxBackoffMS: 60_000,
10
+ stepTimeoutMS: 300_000,
11
+ };
12
+
13
+ describe("calculateBackoffMS", () => {
14
+ it("returns 0 for attempt 1 (first try)", () => {
15
+ expect(calculateBackoffMS(config, 1)).toBe(0);
16
+ });
17
+
18
+ it("returns initialBackoffMS for attempt 2", () => {
19
+ expect(calculateBackoffMS(config, 2)).toBe(1000);
20
+ });
21
+
22
+ it("returns initialBackoffMS * multiplier for attempt 3", () => {
23
+ expect(calculateBackoffMS(config, 3)).toBe(2000);
24
+ });
25
+
26
+ it("grows exponentially", () => {
27
+ expect(calculateBackoffMS(config, 4)).toBe(4000);
28
+ expect(calculateBackoffMS(config, 5)).toBe(8000);
29
+ });
30
+
31
+ it("caps at maxBackoffMS", () => {
32
+ // With multiplier 2 and initial 1000: attempt 8 → 1000 * 2^6 = 64000, capped at 60000
33
+ expect(calculateBackoffMS(config, 8)).toBe(60_000);
34
+ expect(calculateBackoffMS(config, 20)).toBe(60_000);
35
+ });
36
+
37
+ it("returns 0 for attempt <= 0", () => {
38
+ expect(calculateBackoffMS(config, 0)).toBe(0);
39
+ expect(calculateBackoffMS(config, -1)).toBe(0);
40
+ });
41
+
42
+ it("works with initialBackoffMS: 0 (no backoff)", () => {
43
+ const noBackoff = { ...config, initialBackoffMS: 0 };
44
+ expect(calculateBackoffMS(noBackoff, 2)).toBe(0);
45
+ expect(calculateBackoffMS(noBackoff, 5)).toBe(0);
46
+ });
47
+
48
+ it("works with backoffMultiplier: 1 (constant delay)", () => {
49
+ const constant = { ...config, backoffMultiplier: 1 };
50
+ expect(calculateBackoffMS(constant, 2)).toBe(1000);
51
+ expect(calculateBackoffMS(constant, 3)).toBe(1000);
52
+ expect(calculateBackoffMS(constant, 10)).toBe(1000);
53
+ });
54
+ });