bullmq 4.0.0-beta.2 → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (820) hide show
  1. package/README.md +153 -19
  2. package/dist/cjs/classes/async-fifo-queue.js +90 -0
  3. package/dist/cjs/classes/async-fifo-queue.js.map +1 -0
  4. package/dist/{classes → cjs/classes}/backoffs.js +10 -9
  5. package/dist/cjs/classes/backoffs.js.map +1 -0
  6. package/dist/cjs/classes/child-pool.js +64 -0
  7. package/dist/cjs/classes/child-pool.js.map +1 -0
  8. package/dist/cjs/classes/child-processor.js +150 -0
  9. package/dist/cjs/classes/child-processor.js.map +1 -0
  10. package/dist/cjs/classes/child.js +216 -0
  11. package/dist/cjs/classes/child.js.map +1 -0
  12. package/dist/cjs/classes/delayed-error.js +19 -0
  13. package/dist/cjs/classes/delayed-error.js.map +1 -0
  14. package/dist/cjs/classes/flow-producer.js +283 -0
  15. package/dist/cjs/classes/flow-producer.js.map +1 -0
  16. package/dist/{classes → cjs/classes}/index.js +11 -3
  17. package/dist/cjs/classes/index.js.map +1 -0
  18. package/dist/cjs/classes/job.js +768 -0
  19. package/dist/cjs/classes/job.js.map +1 -0
  20. package/dist/cjs/classes/main-base.js +45 -0
  21. package/dist/cjs/classes/main-base.js.map +1 -0
  22. package/dist/cjs/classes/main-worker.js +10 -0
  23. package/dist/cjs/classes/main-worker.js.map +1 -0
  24. package/dist/cjs/classes/main.js +10 -0
  25. package/dist/cjs/classes/main.js.map +1 -0
  26. package/dist/cjs/classes/queue-base.js +135 -0
  27. package/dist/cjs/classes/queue-base.js.map +1 -0
  28. package/dist/cjs/classes/queue-events.js +120 -0
  29. package/dist/cjs/classes/queue-events.js.map +1 -0
  30. package/dist/cjs/classes/queue-getters.js +347 -0
  31. package/dist/cjs/classes/queue-getters.js.map +1 -0
  32. package/dist/cjs/classes/queue-keys.js +45 -0
  33. package/dist/cjs/classes/queue-keys.js.map +1 -0
  34. package/dist/cjs/classes/queue.js +275 -0
  35. package/dist/cjs/classes/queue.js.map +1 -0
  36. package/dist/cjs/classes/redis-connection.js +207 -0
  37. package/dist/cjs/classes/redis-connection.js.map +1 -0
  38. package/dist/cjs/classes/repeat.js +149 -0
  39. package/dist/cjs/classes/repeat.js.map +1 -0
  40. package/dist/{classes → cjs/classes}/sandbox.js +18 -14
  41. package/dist/cjs/classes/sandbox.js.map +1 -0
  42. package/dist/cjs/classes/scripts.js +658 -0
  43. package/dist/cjs/classes/scripts.js.map +1 -0
  44. package/dist/cjs/classes/unrecoverable-error.js +19 -0
  45. package/dist/cjs/classes/unrecoverable-error.js.map +1 -0
  46. package/dist/cjs/classes/waiting-children-error.js +19 -0
  47. package/dist/cjs/classes/waiting-children-error.js.map +1 -0
  48. package/dist/cjs/classes/worker.js +577 -0
  49. package/dist/cjs/classes/worker.js.map +1 -0
  50. package/dist/cjs/commands/addJob-9.lua +170 -0
  51. package/dist/cjs/commands/changeDelay-3.lua +40 -0
  52. package/dist/cjs/commands/changePriority-5.lua +52 -0
  53. package/dist/cjs/commands/cleanJobsInSet-2.lua +48 -0
  54. package/dist/cjs/commands/drain-4.lua +26 -0
  55. package/dist/{commands → cjs/commands}/extendLock-2.lua +1 -0
  56. package/dist/cjs/commands/getCounts-1.lua +35 -0
  57. package/dist/cjs/commands/getRanges-1.lua +69 -0
  58. package/dist/cjs/commands/getState-8.lua +66 -0
  59. package/dist/cjs/commands/getStateV2-8.lua +59 -0
  60. package/dist/cjs/commands/includes/addDelayMarkerIfNeeded.lua +15 -0
  61. package/dist/cjs/commands/includes/addJobWithPriority.lua +15 -0
  62. package/dist/cjs/commands/includes/addPriorityMarkerIfNeeded.lua +12 -0
  63. package/dist/cjs/commands/includes/batches.lua +18 -0
  64. package/dist/cjs/commands/includes/checkItemInList.lua +12 -0
  65. package/dist/cjs/commands/includes/checkStalledJobs.lua +139 -0
  66. package/dist/cjs/commands/includes/cleanList.lua +47 -0
  67. package/dist/cjs/commands/includes/cleanSet.lua +39 -0
  68. package/dist/cjs/commands/includes/collectMetrics.lua +46 -0
  69. package/dist/cjs/commands/includes/destructureJobKey.lua +12 -0
  70. package/dist/cjs/commands/includes/getJobsInZset.lua +12 -0
  71. package/dist/cjs/commands/includes/getNextDelayedTimestamp.lua +13 -0
  72. package/dist/cjs/commands/includes/getRateLimitTTL.lua +17 -0
  73. package/dist/cjs/commands/includes/getTargetQueueList.lua +12 -0
  74. package/dist/cjs/commands/includes/getTimestamp.lua +19 -0
  75. package/dist/cjs/commands/includes/getZSetItems.lua +7 -0
  76. package/dist/cjs/commands/includes/isLocked.lua +31 -0
  77. package/dist/cjs/commands/includes/moveJobFromPriorityToActive.lua +14 -0
  78. package/dist/cjs/commands/includes/moveParentFromWaitingChildrenToFailed.lua +28 -0
  79. package/dist/cjs/commands/includes/prepareJobForProcessing.lua +74 -0
  80. package/dist/cjs/commands/includes/promoteDelayedJobs.lua +39 -0
  81. package/dist/cjs/commands/includes/pushBackJobWithPriority.lua +9 -0
  82. package/dist/cjs/commands/includes/removeJob.lua +13 -0
  83. package/dist/cjs/commands/includes/removeJobFromAnyState.lua +35 -0
  84. package/dist/cjs/commands/includes/removeJobs.lua +25 -0
  85. package/dist/cjs/commands/includes/removeJobsByMaxAge.lua +15 -0
  86. package/dist/cjs/commands/includes/removeJobsByMaxCount.lua +15 -0
  87. package/dist/cjs/commands/includes/removeParentDependencyKey.lua +77 -0
  88. package/dist/cjs/commands/includes/removeZSetJobs.lua +15 -0
  89. package/dist/cjs/commands/includes/trimEvents.lua +12 -0
  90. package/dist/cjs/commands/includes/updateParentDepsIfNeeded.lua +40 -0
  91. package/dist/cjs/commands/index.js +10 -0
  92. package/dist/cjs/commands/index.js.map +1 -0
  93. package/dist/cjs/commands/isFinished-3.lua +48 -0
  94. package/dist/cjs/commands/isJobInList-1.lua +16 -0
  95. package/dist/cjs/commands/moveJobFromActiveToWait-9.lua +53 -0
  96. package/dist/cjs/commands/moveStalledJobsToWait-8.lua +24 -0
  97. package/dist/cjs/commands/moveToActive-10.lua +116 -0
  98. package/dist/cjs/commands/moveToDelayed-8.lua +66 -0
  99. package/dist/cjs/commands/moveToFinished-13.lua +250 -0
  100. package/dist/cjs/commands/moveToWaitingChildren-4.lua +62 -0
  101. package/dist/cjs/commands/obliterate-2.lua +102 -0
  102. package/dist/cjs/commands/pause-5.lua +36 -0
  103. package/dist/cjs/commands/promote-7.lua +57 -0
  104. package/dist/cjs/commands/releaseLock-1.lua +19 -0
  105. package/dist/cjs/commands/removeJob-1.lua +71 -0
  106. package/{src → dist/cjs}/commands/removeRepeatable-2.lua +13 -1
  107. package/dist/cjs/commands/reprocessJob-6.lua +43 -0
  108. package/dist/cjs/commands/retryJob-9.lua +69 -0
  109. package/dist/cjs/commands/retryJobs-6.lua +53 -0
  110. package/dist/cjs/commands/saveStacktrace-1.lua +22 -0
  111. package/dist/cjs/commands/script-loader.js +408 -0
  112. package/dist/cjs/commands/script-loader.js.map +1 -0
  113. package/dist/cjs/commands/updateData-1.lua +20 -0
  114. package/dist/cjs/commands/updateProgress-2.lua +26 -0
  115. package/dist/cjs/enums/error-code.enum.js +13 -0
  116. package/dist/cjs/enums/error-code.enum.js.map +1 -0
  117. package/dist/cjs/enums/index.js +6 -0
  118. package/dist/cjs/enums/index.js.map +1 -0
  119. package/dist/cjs/enums/metrics-time.js +15 -0
  120. package/dist/cjs/enums/metrics-time.js.map +1 -0
  121. package/dist/{index.js → cjs/index.js} +2 -0
  122. package/dist/cjs/index.js.map +1 -0
  123. package/dist/cjs/interfaces/advanced-options.js +3 -0
  124. package/dist/cjs/interfaces/advanced-options.js.map +1 -0
  125. package/dist/cjs/interfaces/backoff-options.js.map +1 -0
  126. package/dist/cjs/interfaces/base-job-options.js +3 -0
  127. package/dist/cjs/interfaces/base-job-options.js.map +1 -0
  128. package/dist/cjs/interfaces/child-command.js +10 -0
  129. package/dist/cjs/interfaces/child-command.js.map +1 -0
  130. package/dist/cjs/interfaces/child-message.js +3 -0
  131. package/dist/cjs/interfaces/child-message.js.map +1 -0
  132. package/dist/{interfaces/jobs-options.js → cjs/interfaces/connection.js} +1 -1
  133. package/dist/cjs/interfaces/connection.js.map +1 -0
  134. package/dist/cjs/interfaces/flow-job.js +3 -0
  135. package/dist/cjs/interfaces/flow-job.js.map +1 -0
  136. package/dist/cjs/interfaces/index.js +28 -0
  137. package/dist/cjs/interfaces/index.js.map +1 -0
  138. package/dist/cjs/interfaces/ioredis-events.js +3 -0
  139. package/dist/cjs/interfaces/ioredis-events.js.map +1 -0
  140. package/dist/cjs/interfaces/job-json.js +3 -0
  141. package/dist/cjs/interfaces/job-json.js.map +1 -0
  142. package/dist/cjs/interfaces/keep-jobs.js +3 -0
  143. package/dist/cjs/interfaces/keep-jobs.js.map +1 -0
  144. package/dist/cjs/interfaces/metrics-options.js +3 -0
  145. package/dist/cjs/interfaces/metrics-options.js.map +1 -0
  146. package/dist/cjs/interfaces/metrics.js +3 -0
  147. package/dist/cjs/interfaces/metrics.js.map +1 -0
  148. package/dist/cjs/interfaces/minimal-job.js +3 -0
  149. package/dist/cjs/interfaces/minimal-job.js.map +1 -0
  150. package/dist/cjs/interfaces/parent-command.js +15 -0
  151. package/dist/cjs/interfaces/parent-command.js.map +1 -0
  152. package/dist/cjs/interfaces/parent-message.js +3 -0
  153. package/dist/cjs/interfaces/parent-message.js.map +1 -0
  154. package/dist/cjs/interfaces/parent.js +3 -0
  155. package/dist/cjs/interfaces/parent.js.map +1 -0
  156. package/dist/{interfaces → cjs/interfaces}/queue-options.js +1 -0
  157. package/dist/cjs/interfaces/queue-options.js.map +1 -0
  158. package/dist/cjs/interfaces/rate-limiter-options.js.map +1 -0
  159. package/dist/cjs/interfaces/redis-options.js.map +1 -0
  160. package/dist/cjs/interfaces/redis-streams.js +3 -0
  161. package/dist/cjs/interfaces/redis-streams.js.map +1 -0
  162. package/dist/cjs/interfaces/repeat-options.js.map +1 -0
  163. package/dist/{interfaces/queue-scheduler-options.js → cjs/interfaces/sandboxed-job-processor.js} +1 -1
  164. package/dist/cjs/interfaces/sandboxed-job-processor.js.map +1 -0
  165. package/dist/cjs/interfaces/sandboxed-job.js +3 -0
  166. package/dist/cjs/interfaces/sandboxed-job.js.map +1 -0
  167. package/dist/cjs/interfaces/worker-options.js.map +1 -0
  168. package/dist/cjs/scripts/addJob-9.js +252 -0
  169. package/dist/cjs/scripts/addJob-9.js.map +1 -0
  170. package/dist/cjs/scripts/changeDelay-3.js +41 -0
  171. package/dist/cjs/scripts/changeDelay-3.js.map +1 -0
  172. package/dist/cjs/scripts/changePriority-5.js +87 -0
  173. package/dist/cjs/scripts/changePriority-5.js.map +1 -0
  174. package/dist/cjs/scripts/cleanJobsInSet-2.js +259 -0
  175. package/dist/cjs/scripts/cleanJobsInSet-2.js.map +1 -0
  176. package/dist/cjs/scripts/drain-4.js +178 -0
  177. package/dist/cjs/scripts/drain-4.js.map +1 -0
  178. package/dist/cjs/scripts/extendLock-2.js +30 -0
  179. package/dist/cjs/scripts/extendLock-2.js.map +1 -0
  180. package/dist/cjs/scripts/getCounts-1.js +41 -0
  181. package/dist/cjs/scripts/getCounts-1.js.map +1 -0
  182. package/dist/cjs/scripts/getRanges-1.js +72 -0
  183. package/dist/cjs/scripts/getRanges-1.js.map +1 -0
  184. package/dist/cjs/scripts/getState-8.js +74 -0
  185. package/dist/cjs/scripts/getState-8.js.map +1 -0
  186. package/dist/cjs/scripts/getStateV2-8.js +58 -0
  187. package/dist/cjs/scripts/getStateV2-8.js.map +1 -0
  188. package/dist/cjs/scripts/index.js +34 -0
  189. package/dist/cjs/scripts/index.js.map +1 -0
  190. package/dist/cjs/scripts/isFinished-3.js +49 -0
  191. package/dist/cjs/scripts/isFinished-3.js.map +1 -0
  192. package/dist/cjs/scripts/isJobInList-1.js +32 -0
  193. package/dist/cjs/scripts/isJobInList-1.js.map +1 -0
  194. package/dist/cjs/scripts/moveJobFromActiveToWait-9.js +70 -0
  195. package/dist/cjs/scripts/moveJobFromActiveToWait-9.js.map +1 -0
  196. package/dist/cjs/scripts/moveStalledJobsToWait-8.js +289 -0
  197. package/dist/cjs/scripts/moveStalledJobsToWait-8.js.map +1 -0
  198. package/dist/cjs/scripts/moveToActive-10.js +269 -0
  199. package/dist/cjs/scripts/moveToActive-10.js.map +1 -0
  200. package/dist/cjs/scripts/moveToDelayed-8.js +152 -0
  201. package/dist/cjs/scripts/moveToDelayed-8.js.map +1 -0
  202. package/dist/cjs/scripts/moveToFinished-13.js +624 -0
  203. package/dist/cjs/scripts/moveToFinished-13.js.map +1 -0
  204. package/dist/cjs/scripts/moveToWaitingChildren-4.js +59 -0
  205. package/dist/cjs/scripts/moveToWaitingChildren-4.js.map +1 -0
  206. package/dist/cjs/scripts/obliterate-2.js +244 -0
  207. package/dist/cjs/scripts/obliterate-2.js.map +1 -0
  208. package/dist/cjs/scripts/pause-5.js +48 -0
  209. package/dist/cjs/scripts/pause-5.js.map +1 -0
  210. package/dist/cjs/scripts/promote-7.js +87 -0
  211. package/dist/cjs/scripts/promote-7.js.map +1 -0
  212. package/dist/cjs/scripts/releaseLock-1.js +25 -0
  213. package/dist/cjs/scripts/releaseLock-1.js.map +1 -0
  214. package/dist/cjs/scripts/removeJob-1.js +210 -0
  215. package/dist/cjs/scripts/removeJob-1.js.map +1 -0
  216. package/dist/cjs/scripts/removeRepeatable-2.js +38 -0
  217. package/dist/cjs/scripts/removeRepeatable-2.js.map +1 -0
  218. package/dist/cjs/scripts/reprocessJob-6.js +56 -0
  219. package/dist/cjs/scripts/reprocessJob-6.js.map +1 -0
  220. package/dist/cjs/scripts/retryJob-9.js +128 -0
  221. package/dist/cjs/scripts/retryJob-9.js.map +1 -0
  222. package/dist/cjs/scripts/retryJobs-6.js +76 -0
  223. package/dist/cjs/scripts/retryJobs-6.js.map +1 -0
  224. package/dist/cjs/scripts/saveStacktrace-1.js +27 -0
  225. package/dist/cjs/scripts/saveStacktrace-1.js.map +1 -0
  226. package/dist/cjs/scripts/updateData-1.js +26 -0
  227. package/dist/cjs/scripts/updateData-1.js.map +1 -0
  228. package/dist/cjs/scripts/updateProgress-2.js +31 -0
  229. package/dist/cjs/scripts/updateProgress-2.js.map +1 -0
  230. package/dist/cjs/tsconfig-cjs.tsbuildinfo +1 -0
  231. package/dist/cjs/types/backoff-strategy.js +3 -0
  232. package/dist/cjs/types/backoff-strategy.js.map +1 -0
  233. package/dist/cjs/types/finished-status.js +3 -0
  234. package/dist/cjs/types/finished-status.js.map +1 -0
  235. package/dist/cjs/types/index.js +11 -0
  236. package/dist/cjs/types/index.js.map +1 -0
  237. package/dist/cjs/types/job-json-sandbox.js +3 -0
  238. package/dist/cjs/types/job-json-sandbox.js.map +1 -0
  239. package/dist/cjs/types/job-options.js +3 -0
  240. package/dist/cjs/types/job-options.js.map +1 -0
  241. package/dist/cjs/types/job-type.js +3 -0
  242. package/dist/cjs/types/job-type.js.map +1 -0
  243. package/dist/cjs/types/minimal-queue.js +3 -0
  244. package/dist/cjs/types/minimal-queue.js.map +1 -0
  245. package/dist/cjs/types/repeat-strategy.js +3 -0
  246. package/dist/cjs/types/repeat-strategy.js.map +1 -0
  247. package/dist/cjs/utils.js +152 -0
  248. package/dist/cjs/utils.js.map +1 -0
  249. package/dist/esm/classes/async-fifo-queue.d.ts +31 -0
  250. package/dist/esm/classes/async-fifo-queue.js +86 -0
  251. package/dist/esm/classes/async-fifo-queue.js.map +1 -0
  252. package/dist/esm/classes/backoffs.d.ts +10 -0
  253. package/dist/esm/classes/backoffs.js +44 -0
  254. package/dist/esm/classes/backoffs.js.map +1 -0
  255. package/dist/esm/classes/child-pool.d.ts +23 -0
  256. package/dist/esm/classes/child-pool.js +60 -0
  257. package/dist/esm/classes/child-pool.js.map +1 -0
  258. package/dist/esm/classes/child-processor.d.ts +26 -0
  259. package/dist/esm/classes/child-processor.js +146 -0
  260. package/dist/esm/classes/child-processor.js.map +1 -0
  261. package/dist/esm/classes/child.d.ts +36 -0
  262. package/dist/esm/classes/child.js +212 -0
  263. package/dist/esm/classes/child.js.map +1 -0
  264. package/dist/esm/classes/delayed-error.d.ts +10 -0
  265. package/dist/esm/classes/delayed-error.js +15 -0
  266. package/dist/esm/classes/delayed-error.js.map +1 -0
  267. package/dist/esm/classes/flow-producer.d.ts +163 -0
  268. package/dist/esm/classes/flow-producer.js +279 -0
  269. package/dist/esm/classes/flow-producer.js.map +1 -0
  270. package/dist/{classes → esm/classes}/index.d.ts +9 -3
  271. package/dist/esm/classes/index.js +22 -0
  272. package/dist/esm/classes/index.js.map +1 -0
  273. package/dist/esm/classes/job.d.ts +355 -0
  274. package/dist/esm/classes/job.js +764 -0
  275. package/dist/esm/classes/job.js.map +1 -0
  276. package/dist/esm/classes/main-base.d.ts +4 -0
  277. package/dist/esm/classes/main-base.js +43 -0
  278. package/dist/esm/classes/main-base.js.map +1 -0
  279. package/dist/esm/classes/main-worker.js +8 -0
  280. package/dist/esm/classes/main-worker.js.map +1 -0
  281. package/dist/esm/classes/main.js +8 -0
  282. package/dist/esm/classes/main.js.map +1 -0
  283. package/dist/esm/classes/queue-base.d.ts +67 -0
  284. package/dist/esm/classes/queue-base.js +131 -0
  285. package/dist/esm/classes/queue-base.js.map +1 -0
  286. package/dist/esm/classes/queue-events.d.ts +179 -0
  287. package/dist/esm/classes/queue-events.js +116 -0
  288. package/dist/esm/classes/queue-events.js.map +1 -0
  289. package/dist/esm/classes/queue-getters.d.ts +164 -0
  290. package/dist/esm/classes/queue-getters.js +344 -0
  291. package/dist/esm/classes/queue-getters.js.map +1 -0
  292. package/dist/esm/classes/queue-keys.d.ts +10 -0
  293. package/dist/esm/classes/queue-keys.js +41 -0
  294. package/dist/esm/classes/queue-keys.js.map +1 -0
  295. package/dist/esm/classes/queue.d.ts +236 -0
  296. package/dist/esm/classes/queue.js +271 -0
  297. package/dist/esm/classes/queue.js.map +1 -0
  298. package/dist/esm/classes/redis-connection.d.ts +37 -0
  299. package/dist/esm/classes/redis-connection.js +203 -0
  300. package/dist/esm/classes/redis-connection.js.map +1 -0
  301. package/dist/esm/classes/repeat.d.ts +25 -0
  302. package/dist/esm/classes/repeat.js +144 -0
  303. package/dist/esm/classes/repeat.js.map +1 -0
  304. package/dist/esm/classes/sandbox.d.ts +4 -0
  305. package/dist/esm/classes/sandbox.js +58 -0
  306. package/dist/esm/classes/sandbox.js.map +1 -0
  307. package/dist/esm/classes/scripts.d.ts +106 -0
  308. package/dist/esm/classes/scripts.js +654 -0
  309. package/dist/esm/classes/scripts.js.map +1 -0
  310. package/dist/esm/classes/unrecoverable-error.d.ts +10 -0
  311. package/dist/esm/classes/unrecoverable-error.js +15 -0
  312. package/dist/esm/classes/unrecoverable-error.js.map +1 -0
  313. package/dist/esm/classes/waiting-children-error.d.ts +10 -0
  314. package/dist/esm/classes/waiting-children-error.js +15 -0
  315. package/dist/esm/classes/waiting-children-error.js.map +1 -0
  316. package/dist/esm/classes/worker.d.ts +215 -0
  317. package/dist/esm/classes/worker.js +573 -0
  318. package/dist/esm/classes/worker.js.map +1 -0
  319. package/dist/esm/commands/addJob-9.lua +170 -0
  320. package/dist/esm/commands/changeDelay-3.lua +40 -0
  321. package/dist/esm/commands/changePriority-5.lua +52 -0
  322. package/dist/esm/commands/cleanJobsInSet-2.lua +48 -0
  323. package/dist/esm/commands/drain-4.lua +26 -0
  324. package/{src → dist/esm}/commands/extendLock-2.lua +1 -0
  325. package/dist/esm/commands/getCounts-1.lua +35 -0
  326. package/dist/esm/commands/getRanges-1.lua +69 -0
  327. package/dist/esm/commands/getState-8.lua +66 -0
  328. package/dist/esm/commands/getStateV2-8.lua +59 -0
  329. package/dist/esm/commands/includes/addDelayMarkerIfNeeded.lua +15 -0
  330. package/dist/esm/commands/includes/addJobWithPriority.lua +15 -0
  331. package/dist/esm/commands/includes/addPriorityMarkerIfNeeded.lua +12 -0
  332. package/dist/esm/commands/includes/batches.lua +18 -0
  333. package/dist/esm/commands/includes/checkItemInList.lua +12 -0
  334. package/dist/esm/commands/includes/checkStalledJobs.lua +139 -0
  335. package/dist/esm/commands/includes/cleanList.lua +47 -0
  336. package/dist/esm/commands/includes/cleanSet.lua +39 -0
  337. package/dist/esm/commands/includes/collectMetrics.lua +46 -0
  338. package/dist/esm/commands/includes/destructureJobKey.lua +12 -0
  339. package/dist/esm/commands/includes/getJobsInZset.lua +12 -0
  340. package/dist/esm/commands/includes/getNextDelayedTimestamp.lua +13 -0
  341. package/dist/esm/commands/includes/getRateLimitTTL.lua +17 -0
  342. package/dist/esm/commands/includes/getTargetQueueList.lua +12 -0
  343. package/dist/esm/commands/includes/getTimestamp.lua +19 -0
  344. package/dist/esm/commands/includes/getZSetItems.lua +7 -0
  345. package/dist/esm/commands/includes/isLocked.lua +31 -0
  346. package/dist/esm/commands/includes/moveJobFromPriorityToActive.lua +14 -0
  347. package/dist/esm/commands/includes/moveParentFromWaitingChildrenToFailed.lua +28 -0
  348. package/dist/esm/commands/includes/prepareJobForProcessing.lua +74 -0
  349. package/dist/esm/commands/includes/promoteDelayedJobs.lua +39 -0
  350. package/dist/esm/commands/includes/pushBackJobWithPriority.lua +9 -0
  351. package/dist/esm/commands/includes/removeJob.lua +13 -0
  352. package/dist/esm/commands/includes/removeJobFromAnyState.lua +35 -0
  353. package/dist/esm/commands/includes/removeJobs.lua +25 -0
  354. package/dist/esm/commands/includes/removeJobsByMaxAge.lua +15 -0
  355. package/dist/esm/commands/includes/removeJobsByMaxCount.lua +15 -0
  356. package/dist/esm/commands/includes/removeParentDependencyKey.lua +77 -0
  357. package/dist/esm/commands/includes/removeZSetJobs.lua +15 -0
  358. package/dist/esm/commands/includes/trimEvents.lua +12 -0
  359. package/dist/esm/commands/includes/updateParentDepsIfNeeded.lua +40 -0
  360. package/dist/esm/commands/index.d.ts +4 -0
  361. package/dist/esm/commands/index.js +5 -0
  362. package/dist/esm/commands/index.js.map +1 -0
  363. package/dist/esm/commands/isFinished-3.lua +48 -0
  364. package/dist/esm/commands/isJobInList-1.lua +16 -0
  365. package/dist/esm/commands/moveJobFromActiveToWait-9.lua +53 -0
  366. package/dist/esm/commands/moveStalledJobsToWait-8.lua +24 -0
  367. package/dist/esm/commands/moveToActive-10.lua +116 -0
  368. package/dist/esm/commands/moveToDelayed-8.lua +66 -0
  369. package/dist/esm/commands/moveToFinished-13.lua +250 -0
  370. package/dist/esm/commands/moveToWaitingChildren-4.lua +62 -0
  371. package/dist/esm/commands/obliterate-2.lua +102 -0
  372. package/dist/esm/commands/pause-5.lua +36 -0
  373. package/dist/esm/commands/promote-7.lua +57 -0
  374. package/dist/esm/commands/releaseLock-1.lua +19 -0
  375. package/dist/esm/commands/removeJob-1.lua +71 -0
  376. package/dist/{commands → esm/commands}/removeRepeatable-2.lua +13 -1
  377. package/dist/esm/commands/reprocessJob-6.lua +43 -0
  378. package/dist/esm/commands/retryJob-9.lua +69 -0
  379. package/dist/esm/commands/retryJobs-6.lua +53 -0
  380. package/dist/esm/commands/saveStacktrace-1.lua +22 -0
  381. package/dist/esm/commands/script-loader.d.ts +119 -0
  382. package/dist/esm/commands/script-loader.js +403 -0
  383. package/dist/esm/commands/script-loader.js.map +1 -0
  384. package/dist/esm/commands/updateData-1.lua +20 -0
  385. package/dist/esm/commands/updateProgress-2.lua +26 -0
  386. package/dist/esm/enums/error-code.enum.d.ts +8 -0
  387. package/dist/esm/enums/error-code.enum.js +10 -0
  388. package/dist/esm/enums/error-code.enum.js.map +1 -0
  389. package/dist/esm/enums/index.d.ts +2 -0
  390. package/dist/esm/enums/index.js +3 -0
  391. package/dist/esm/enums/index.js.map +1 -0
  392. package/dist/esm/enums/metrics-time.d.ts +10 -0
  393. package/dist/esm/enums/metrics-time.js +12 -0
  394. package/dist/esm/enums/metrics-time.js.map +1 -0
  395. package/dist/{index.d.ts → esm/index.d.ts} +2 -0
  396. package/{src/index.ts → dist/esm/index.js} +7 -4
  397. package/dist/esm/index.js.map +1 -0
  398. package/dist/esm/interfaces/advanced-options.d.ts +13 -0
  399. package/dist/esm/interfaces/advanced-options.js +2 -0
  400. package/dist/esm/interfaces/advanced-options.js.map +1 -0
  401. package/dist/esm/interfaces/backoff-options.d.ts +15 -0
  402. package/dist/esm/interfaces/backoff-options.js +2 -0
  403. package/dist/esm/interfaces/backoff-options.js.map +1 -0
  404. package/dist/esm/interfaces/base-job-options.d.ts +97 -0
  405. package/dist/esm/interfaces/base-job-options.js +2 -0
  406. package/dist/esm/interfaces/base-job-options.js.map +1 -0
  407. package/dist/esm/interfaces/child-command.d.ts +5 -0
  408. package/dist/esm/interfaces/child-command.js +7 -0
  409. package/dist/esm/interfaces/child-command.js.map +1 -0
  410. package/dist/esm/interfaces/child-message.d.ts +6 -0
  411. package/dist/esm/interfaces/child-message.js +2 -0
  412. package/dist/esm/interfaces/child-message.js.map +1 -0
  413. package/dist/esm/interfaces/connection.d.ts +8 -0
  414. package/dist/esm/interfaces/connection.js +2 -0
  415. package/dist/esm/interfaces/connection.js.map +1 -0
  416. package/dist/esm/interfaces/flow-job.d.ts +19 -0
  417. package/dist/esm/interfaces/flow-job.js +2 -0
  418. package/dist/esm/interfaces/flow-job.js.map +1 -0
  419. package/dist/esm/interfaces/index.d.ts +24 -0
  420. package/dist/esm/interfaces/index.js +25 -0
  421. package/dist/esm/interfaces/index.js.map +1 -0
  422. package/dist/esm/interfaces/ioredis-events.d.ts +8 -0
  423. package/dist/esm/interfaces/ioredis-events.js +2 -0
  424. package/dist/esm/interfaces/ioredis-events.js.map +1 -0
  425. package/dist/esm/interfaces/job-json.d.ts +37 -0
  426. package/dist/esm/interfaces/job-json.js +2 -0
  427. package/dist/esm/interfaces/job-json.js.map +1 -0
  428. package/dist/esm/interfaces/keep-jobs.d.ts +17 -0
  429. package/dist/esm/interfaces/keep-jobs.js +2 -0
  430. package/dist/esm/interfaces/keep-jobs.js.map +1 -0
  431. package/dist/esm/interfaces/metrics-options.d.ts +12 -0
  432. package/dist/esm/interfaces/metrics-options.js +2 -0
  433. package/dist/esm/interfaces/metrics-options.js.map +1 -0
  434. package/dist/esm/interfaces/metrics.d.ts +9 -0
  435. package/dist/esm/interfaces/metrics.js +2 -0
  436. package/dist/esm/interfaces/metrics.js.map +1 -0
  437. package/dist/esm/interfaces/minimal-job.d.ts +129 -0
  438. package/dist/esm/interfaces/minimal-job.js +2 -0
  439. package/dist/esm/interfaces/minimal-job.js.map +1 -0
  440. package/dist/esm/interfaces/parent-command.d.ts +10 -0
  441. package/dist/esm/interfaces/parent-command.js +12 -0
  442. package/dist/esm/interfaces/parent-command.js.map +1 -0
  443. package/dist/esm/interfaces/parent-message.d.ts +8 -0
  444. package/dist/esm/interfaces/parent-message.js +2 -0
  445. package/dist/esm/interfaces/parent-message.js.map +1 -0
  446. package/dist/esm/interfaces/parent.d.ts +20 -0
  447. package/dist/esm/interfaces/parent.js +2 -0
  448. package/dist/esm/interfaces/parent.js.map +1 -0
  449. package/dist/esm/interfaces/queue-options.d.ts +74 -0
  450. package/dist/esm/interfaces/queue-options.js +6 -0
  451. package/dist/esm/interfaces/queue-options.js.map +1 -0
  452. package/dist/esm/interfaces/rate-limiter-options.d.ts +12 -0
  453. package/dist/esm/interfaces/rate-limiter-options.js +2 -0
  454. package/dist/esm/interfaces/rate-limiter-options.js.map +1 -0
  455. package/dist/esm/interfaces/redis-options.d.ts +7 -0
  456. package/dist/esm/interfaces/redis-options.js +2 -0
  457. package/dist/esm/interfaces/redis-options.js.map +1 -0
  458. package/dist/esm/interfaces/redis-streams.d.ts +4 -0
  459. package/dist/esm/interfaces/redis-streams.js +2 -0
  460. package/dist/esm/interfaces/redis-streams.js.map +1 -0
  461. package/dist/esm/interfaces/repeat-options.d.ts +33 -0
  462. package/dist/esm/interfaces/repeat-options.js +2 -0
  463. package/dist/esm/interfaces/repeat-options.js.map +1 -0
  464. package/dist/esm/interfaces/sandboxed-job-processor.d.ts +5 -0
  465. package/dist/esm/interfaces/sandboxed-job-processor.js +2 -0
  466. package/dist/esm/interfaces/sandboxed-job-processor.js.map +1 -0
  467. package/dist/esm/interfaces/sandboxed-job.d.ts +13 -0
  468. package/dist/esm/interfaces/sandboxed-job.js +2 -0
  469. package/dist/esm/interfaces/sandboxed-job.js.map +1 -0
  470. package/dist/esm/interfaces/worker-options.d.ts +123 -0
  471. package/dist/esm/interfaces/worker-options.js +2 -0
  472. package/dist/esm/interfaces/worker-options.js.map +1 -0
  473. package/dist/esm/scripts/addJob-9.d.ts +5 -0
  474. package/dist/esm/scripts/addJob-9.js +249 -0
  475. package/dist/esm/scripts/addJob-9.js.map +1 -0
  476. package/dist/esm/scripts/changeDelay-3.d.ts +5 -0
  477. package/dist/esm/scripts/changeDelay-3.js +38 -0
  478. package/dist/esm/scripts/changeDelay-3.js.map +1 -0
  479. package/dist/esm/scripts/changePriority-5.d.ts +5 -0
  480. package/dist/esm/scripts/changePriority-5.js +84 -0
  481. package/dist/esm/scripts/changePriority-5.js.map +1 -0
  482. package/dist/esm/scripts/cleanJobsInSet-2.d.ts +5 -0
  483. package/dist/esm/scripts/cleanJobsInSet-2.js +256 -0
  484. package/dist/esm/scripts/cleanJobsInSet-2.js.map +1 -0
  485. package/dist/esm/scripts/drain-4.d.ts +5 -0
  486. package/dist/esm/scripts/drain-4.js +175 -0
  487. package/dist/esm/scripts/drain-4.js.map +1 -0
  488. package/dist/esm/scripts/extendLock-2.d.ts +5 -0
  489. package/dist/esm/scripts/extendLock-2.js +27 -0
  490. package/dist/esm/scripts/extendLock-2.js.map +1 -0
  491. package/dist/esm/scripts/getCounts-1.d.ts +5 -0
  492. package/dist/esm/scripts/getCounts-1.js +38 -0
  493. package/dist/esm/scripts/getCounts-1.js.map +1 -0
  494. package/dist/esm/scripts/getRanges-1.d.ts +5 -0
  495. package/dist/esm/scripts/getRanges-1.js +69 -0
  496. package/dist/esm/scripts/getRanges-1.js.map +1 -0
  497. package/dist/esm/scripts/getState-8.d.ts +5 -0
  498. package/dist/esm/scripts/getState-8.js +71 -0
  499. package/dist/esm/scripts/getState-8.js.map +1 -0
  500. package/dist/esm/scripts/getStateV2-8.d.ts +5 -0
  501. package/dist/esm/scripts/getStateV2-8.js +55 -0
  502. package/dist/esm/scripts/getStateV2-8.js.map +1 -0
  503. package/dist/esm/scripts/index.d.ts +30 -0
  504. package/dist/esm/scripts/index.js +31 -0
  505. package/dist/esm/scripts/index.js.map +1 -0
  506. package/dist/esm/scripts/isFinished-3.d.ts +5 -0
  507. package/dist/esm/scripts/isFinished-3.js +46 -0
  508. package/dist/esm/scripts/isFinished-3.js.map +1 -0
  509. package/dist/esm/scripts/isJobInList-1.d.ts +5 -0
  510. package/dist/esm/scripts/isJobInList-1.js +29 -0
  511. package/dist/esm/scripts/isJobInList-1.js.map +1 -0
  512. package/dist/esm/scripts/moveJobFromActiveToWait-9.d.ts +5 -0
  513. package/dist/esm/scripts/moveJobFromActiveToWait-9.js +67 -0
  514. package/dist/esm/scripts/moveJobFromActiveToWait-9.js.map +1 -0
  515. package/dist/esm/scripts/moveStalledJobsToWait-8.d.ts +5 -0
  516. package/dist/esm/scripts/moveStalledJobsToWait-8.js +286 -0
  517. package/dist/esm/scripts/moveStalledJobsToWait-8.js.map +1 -0
  518. package/dist/esm/scripts/moveToActive-10.d.ts +5 -0
  519. package/dist/esm/scripts/moveToActive-10.js +266 -0
  520. package/dist/esm/scripts/moveToActive-10.js.map +1 -0
  521. package/dist/esm/scripts/moveToDelayed-8.d.ts +5 -0
  522. package/dist/esm/scripts/moveToDelayed-8.js +149 -0
  523. package/dist/esm/scripts/moveToDelayed-8.js.map +1 -0
  524. package/dist/esm/scripts/moveToFinished-13.d.ts +5 -0
  525. package/dist/esm/scripts/moveToFinished-13.js +621 -0
  526. package/dist/esm/scripts/moveToFinished-13.js.map +1 -0
  527. package/dist/esm/scripts/moveToWaitingChildren-4.d.ts +5 -0
  528. package/dist/esm/scripts/moveToWaitingChildren-4.js +56 -0
  529. package/dist/esm/scripts/moveToWaitingChildren-4.js.map +1 -0
  530. package/dist/esm/scripts/obliterate-2.d.ts +5 -0
  531. package/dist/esm/scripts/obliterate-2.js +241 -0
  532. package/dist/esm/scripts/obliterate-2.js.map +1 -0
  533. package/dist/esm/scripts/pause-5.d.ts +5 -0
  534. package/dist/esm/scripts/pause-5.js +45 -0
  535. package/dist/esm/scripts/pause-5.js.map +1 -0
  536. package/dist/esm/scripts/promote-7.d.ts +5 -0
  537. package/dist/esm/scripts/promote-7.js +84 -0
  538. package/dist/esm/scripts/promote-7.js.map +1 -0
  539. package/dist/esm/scripts/releaseLock-1.d.ts +5 -0
  540. package/dist/esm/scripts/releaseLock-1.js +22 -0
  541. package/dist/esm/scripts/releaseLock-1.js.map +1 -0
  542. package/dist/esm/scripts/removeJob-1.d.ts +5 -0
  543. package/dist/esm/scripts/removeJob-1.js +207 -0
  544. package/dist/esm/scripts/removeJob-1.js.map +1 -0
  545. package/dist/esm/scripts/removeRepeatable-2.d.ts +5 -0
  546. package/dist/esm/scripts/removeRepeatable-2.js +35 -0
  547. package/dist/esm/scripts/removeRepeatable-2.js.map +1 -0
  548. package/dist/esm/scripts/reprocessJob-6.d.ts +5 -0
  549. package/dist/esm/scripts/reprocessJob-6.js +53 -0
  550. package/dist/esm/scripts/reprocessJob-6.js.map +1 -0
  551. package/dist/esm/scripts/retryJob-9.d.ts +5 -0
  552. package/dist/esm/scripts/retryJob-9.js +125 -0
  553. package/dist/esm/scripts/retryJob-9.js.map +1 -0
  554. package/dist/esm/scripts/retryJobs-6.d.ts +5 -0
  555. package/dist/esm/scripts/retryJobs-6.js +73 -0
  556. package/dist/esm/scripts/retryJobs-6.js.map +1 -0
  557. package/dist/esm/scripts/saveStacktrace-1.d.ts +5 -0
  558. package/dist/esm/scripts/saveStacktrace-1.js +24 -0
  559. package/dist/esm/scripts/saveStacktrace-1.js.map +1 -0
  560. package/dist/esm/scripts/updateData-1.d.ts +5 -0
  561. package/dist/esm/scripts/updateData-1.js +23 -0
  562. package/dist/esm/scripts/updateData-1.js.map +1 -0
  563. package/dist/esm/scripts/updateProgress-2.d.ts +5 -0
  564. package/dist/esm/scripts/updateProgress-2.js +28 -0
  565. package/dist/esm/scripts/updateProgress-2.js.map +1 -0
  566. package/dist/esm/tsconfig.tsbuildinfo +1 -0
  567. package/dist/esm/types/backoff-strategy.d.ts +2 -0
  568. package/dist/esm/types/backoff-strategy.js +2 -0
  569. package/dist/esm/types/backoff-strategy.js.map +1 -0
  570. package/dist/esm/types/finished-status.d.ts +2 -0
  571. package/dist/esm/types/finished-status.js +2 -0
  572. package/dist/esm/types/finished-status.js.map +1 -0
  573. package/dist/esm/types/index.d.ts +7 -0
  574. package/dist/esm/types/index.js +8 -0
  575. package/dist/esm/types/index.js.map +1 -0
  576. package/dist/esm/types/job-json-sandbox.d.ts +5 -0
  577. package/dist/esm/types/job-json-sandbox.js +2 -0
  578. package/dist/esm/types/job-json-sandbox.js.map +1 -0
  579. package/dist/esm/types/job-options.d.ts +20 -0
  580. package/dist/esm/types/job-options.js +2 -0
  581. package/dist/esm/types/job-options.js.map +1 -0
  582. package/dist/esm/types/job-type.d.ts +3 -0
  583. package/dist/esm/types/job-type.js +2 -0
  584. package/dist/esm/types/job-type.js.map +1 -0
  585. package/dist/esm/types/minimal-queue.d.ts +2 -0
  586. package/dist/esm/types/minimal-queue.js +2 -0
  587. package/dist/esm/types/minimal-queue.js.map +1 -0
  588. package/dist/esm/types/repeat-strategy.d.ts +2 -0
  589. package/dist/esm/types/repeat-strategy.js +2 -0
  590. package/dist/esm/types/repeat-strategy.js.map +1 -0
  591. package/dist/esm/utils.d.ts +42 -0
  592. package/dist/esm/utils.js +134 -0
  593. package/dist/esm/utils.js.map +1 -0
  594. package/package.json +180 -60
  595. package/.travis.yml +0 -32
  596. package/SUMMARY.md +0 -4
  597. package/commitlint.config.js +0 -1
  598. package/dist/classes/backoffs.d.ts +0 -14
  599. package/dist/classes/backoffs.js.map +0 -1
  600. package/dist/classes/child-pool.d.ts +0 -22
  601. package/dist/classes/child-pool.js +0 -98
  602. package/dist/classes/child-pool.js.map +0 -1
  603. package/dist/classes/compat.d.ts +0 -315
  604. package/dist/classes/compat.js +0 -671
  605. package/dist/classes/compat.js.map +0 -1
  606. package/dist/classes/index.js.map +0 -1
  607. package/dist/classes/job.d.ts +0 -93
  608. package/dist/classes/job.js +0 -353
  609. package/dist/classes/job.js.map +0 -1
  610. package/dist/classes/master.js +0 -112
  611. package/dist/classes/master.js.map +0 -1
  612. package/dist/classes/queue-base.d.ts +0 -22
  613. package/dist/classes/queue-base.js +0 -66
  614. package/dist/classes/queue-base.js.map +0 -1
  615. package/dist/classes/queue-events.d.ts +0 -8
  616. package/dist/classes/queue-events.js +0 -59
  617. package/dist/classes/queue-events.js.map +0 -1
  618. package/dist/classes/queue-getters.d.ts +0 -38
  619. package/dist/classes/queue-getters.js +0 -183
  620. package/dist/classes/queue-getters.js.map +0 -1
  621. package/dist/classes/queue-scheduler.d.ts +0 -25
  622. package/dist/classes/queue-scheduler.js +0 -97
  623. package/dist/classes/queue-scheduler.js.map +0 -1
  624. package/dist/classes/queue.d.ts +0 -56
  625. package/dist/classes/queue.js +0 -130
  626. package/dist/classes/queue.js.map +0 -1
  627. package/dist/classes/redis-connection.d.ts +0 -22
  628. package/dist/classes/redis-connection.js +0 -108
  629. package/dist/classes/redis-connection.js.map +0 -1
  630. package/dist/classes/repeat.d.ts +0 -26
  631. package/dist/classes/repeat.js +0 -129
  632. package/dist/classes/repeat.js.map +0 -1
  633. package/dist/classes/sandbox.d.ts +0 -2
  634. package/dist/classes/sandbox.js.map +0 -1
  635. package/dist/classes/scripts.d.ts +0 -43
  636. package/dist/classes/scripts.js +0 -307
  637. package/dist/classes/scripts.js.map +0 -1
  638. package/dist/classes/worker.d.ts +0 -40
  639. package/dist/classes/worker.js +0 -246
  640. package/dist/classes/worker.js.map +0 -1
  641. package/dist/commands/addJob-8.lua +0 -106
  642. package/dist/commands/cleanJobsInSet-1.lua +0 -48
  643. package/dist/commands/index.d.ts +0 -2
  644. package/dist/commands/index.js +0 -42
  645. package/dist/commands/index.js.map +0 -1
  646. package/dist/commands/isFinished-2.lua +0 -22
  647. package/dist/commands/isJobInList-1.lua +0 -20
  648. package/dist/commands/moveStalledJobsToWait-8.lua +0 -91
  649. package/dist/commands/moveToActive-8.lua +0 -79
  650. package/dist/commands/moveToDelayed-5.lua +0 -39
  651. package/dist/commands/moveToFinished-7.lua +0 -92
  652. package/dist/commands/pause-4.lua +0 -27
  653. package/dist/commands/promote-4.lua +0 -49
  654. package/dist/commands/releaseLock-1.lua +0 -19
  655. package/dist/commands/removeJob-10.lua +0 -37
  656. package/dist/commands/reprocessJob-4.lua +0 -36
  657. package/dist/commands/retryJob-4.lua +0 -34
  658. package/dist/commands/takeLock-1.lua +0 -17
  659. package/dist/commands/updateDelaySet-7.lua +0 -71
  660. package/dist/commands/updateProgress-2.lua +0 -15
  661. package/dist/enums/index.d.ts +0 -1
  662. package/dist/enums/index.js +0 -5
  663. package/dist/enums/index.js.map +0 -1
  664. package/dist/enums/retry-errors.enum.d.ts +0 -5
  665. package/dist/enums/retry-errors.enum.js +0 -9
  666. package/dist/enums/retry-errors.enum.js.map +0 -1
  667. package/dist/index.js.map +0 -1
  668. package/dist/interfaces/advanced-options.d.ts +0 -9
  669. package/dist/interfaces/advanced-options.js +0 -11
  670. package/dist/interfaces/advanced-options.js.map +0 -1
  671. package/dist/interfaces/backoff-options.d.ts +0 -4
  672. package/dist/interfaces/backoff-options.js.map +0 -1
  673. package/dist/interfaces/index.d.ts +0 -9
  674. package/dist/interfaces/index.js +0 -6
  675. package/dist/interfaces/index.js.map +0 -1
  676. package/dist/interfaces/jobs-options.d.ts +0 -16
  677. package/dist/interfaces/jobs-options.js.map +0 -1
  678. package/dist/interfaces/queue-options.d.ts +0 -24
  679. package/dist/interfaces/queue-options.js.map +0 -1
  680. package/dist/interfaces/queue-scheduler-options.d.ts +0 -5
  681. package/dist/interfaces/queue-scheduler-options.js.map +0 -1
  682. package/dist/interfaces/rate-limiter-options.d.ts +0 -4
  683. package/dist/interfaces/rate-limiter-options.js.map +0 -1
  684. package/dist/interfaces/redis-options.d.ts +0 -5
  685. package/dist/interfaces/redis-options.js.map +0 -1
  686. package/dist/interfaces/repeat-options.d.ts +0 -11
  687. package/dist/interfaces/repeat-options.js.map +0 -1
  688. package/dist/interfaces/worker-options.d.ts +0 -11
  689. package/dist/interfaces/worker-options.js.map +0 -1
  690. package/dist/test/test_bulk.js +0 -55
  691. package/dist/test/test_bulk.js.map +0 -1
  692. package/dist/test/test_child-pool.js +0 -81
  693. package/dist/test/test_child-pool.js.map +0 -1
  694. package/dist/test/test_clean.js +0 -124
  695. package/dist/test/test_clean.js.map +0 -1
  696. package/dist/test/test_compat.d.ts +0 -1
  697. package/dist/test/test_compat.js +0 -533
  698. package/dist/test/test_compat.js.map +0 -1
  699. package/dist/test/test_connection.d.ts +0 -1
  700. package/dist/test/test_connection.js +0 -142
  701. package/dist/test/test_connection.js.map +0 -1
  702. package/dist/test/test_delay.d.ts +0 -1
  703. package/dist/test/test_delay.js +0 -188
  704. package/dist/test/test_delay.js.map +0 -1
  705. package/dist/test/test_events.d.ts +0 -1
  706. package/dist/test/test_events.js +0 -148
  707. package/dist/test/test_events.js.map +0 -1
  708. package/dist/test/test_getters.d.ts +0 -1
  709. package/dist/test/test_getters.js +0 -293
  710. package/dist/test/test_getters.js.map +0 -1
  711. package/dist/test/test_job.d.ts +0 -1
  712. package/dist/test/test_job.js +0 -419
  713. package/dist/test/test_job.js.map +0 -1
  714. package/dist/test/test_pause.d.ts +0 -1
  715. package/dist/test/test_pause.js +0 -254
  716. package/dist/test/test_pause.js.map +0 -1
  717. package/dist/test/test_queue.d.ts +0 -0
  718. package/dist/test/test_queue.js +0 -72
  719. package/dist/test/test_queue.js.map +0 -1
  720. package/dist/test/test_rate_limiter.d.ts +0 -1
  721. package/dist/test/test_rate_limiter.js +0 -98
  722. package/dist/test/test_rate_limiter.js.map +0 -1
  723. package/dist/test/test_repeat.d.ts +0 -1
  724. package/dist/test/test_repeat.js +0 -604
  725. package/dist/test/test_repeat.js.map +0 -1
  726. package/dist/test/test_sandboxed_process.d.ts +0 -1
  727. package/dist/test/test_sandboxed_process.js +0 -319
  728. package/dist/test/test_sandboxed_process.js.map +0 -1
  729. package/dist/test/test_stalled_jobs.d.ts +0 -1
  730. package/dist/test/test_stalled_jobs.js +0 -107
  731. package/dist/test/test_stalled_jobs.js.map +0 -1
  732. package/dist/test/test_worker.d.ts +0 -1
  733. package/dist/test/test_worker.js +0 -1182
  734. package/dist/test/test_worker.js.map +0 -1
  735. package/dist/utils.d.ts +0 -8
  736. package/dist/utils.js +0 -31
  737. package/dist/utils.js.map +0 -1
  738. package/release.txt +0 -21
  739. package/src/classes/backoffs.ts +0 -67
  740. package/src/classes/child-pool.ts +0 -119
  741. package/src/classes/compat.ts +0 -889
  742. package/src/classes/index.ts +0 -13
  743. package/src/classes/job.ts +0 -492
  744. package/src/classes/master.ts +0 -113
  745. package/src/classes/queue-base.ts +0 -80
  746. package/src/classes/queue-events.ts +0 -78
  747. package/src/classes/queue-getters.ts +0 -213
  748. package/src/classes/queue-scheduler.ts +0 -127
  749. package/src/classes/queue.ts +0 -194
  750. package/src/classes/redis-connection.ts +0 -127
  751. package/src/classes/repeat.ts +0 -212
  752. package/src/classes/sandbox.ts +0 -60
  753. package/src/classes/scripts.ts +0 -482
  754. package/src/classes/worker.ts +0 -313
  755. package/src/commands/addJob-8.lua +0 -106
  756. package/src/commands/cleanJobsInSet-1.lua +0 -48
  757. package/src/commands/index.ts +0 -62
  758. package/src/commands/isFinished-2.lua +0 -22
  759. package/src/commands/isJobInList-1.lua +0 -20
  760. package/src/commands/moveStalledJobsToWait-8.lua +0 -91
  761. package/src/commands/moveToActive-8.lua +0 -79
  762. package/src/commands/moveToDelayed-5.lua +0 -39
  763. package/src/commands/moveToFinished-7.lua +0 -92
  764. package/src/commands/pause-4.lua +0 -27
  765. package/src/commands/promote-4.lua +0 -49
  766. package/src/commands/releaseLock-1.lua +0 -19
  767. package/src/commands/removeJob-10.lua +0 -37
  768. package/src/commands/reprocessJob-4.lua +0 -36
  769. package/src/commands/retryJob-4.lua +0 -34
  770. package/src/commands/takeLock-1.lua +0 -17
  771. package/src/commands/updateDelaySet-7.lua +0 -71
  772. package/src/commands/updateProgress-2.lua +0 -15
  773. package/src/enums/index.ts +0 -1
  774. package/src/enums/retry-errors.enum.ts +0 -5
  775. package/src/interfaces/advanced-options.ts +0 -28
  776. package/src/interfaces/backoff-options.ts +0 -4
  777. package/src/interfaces/index.ts +0 -9
  778. package/src/interfaces/jobs-options.ts +0 -53
  779. package/src/interfaces/queue-options.ts +0 -30
  780. package/src/interfaces/queue-scheduler-options.ts +0 -6
  781. package/src/interfaces/rate-limiter-options.ts +0 -7
  782. package/src/interfaces/redis-options.ts +0 -7
  783. package/src/interfaces/repeat-options.ts +0 -19
  784. package/src/interfaces/worker-options.ts +0 -13
  785. package/src/test/fixtures/fixture_processor.js +0 -13
  786. package/src/test/fixtures/fixture_processor_bar.js +0 -13
  787. package/src/test/fixtures/fixture_processor_crash.js +0 -16
  788. package/src/test/fixtures/fixture_processor_exit.js +0 -15
  789. package/src/test/fixtures/fixture_processor_fail.js +0 -13
  790. package/src/test/fixtures/fixture_processor_foo.js +0 -13
  791. package/src/test/fixtures/fixture_processor_progress.js +0 -29
  792. package/src/test/fixtures/fixture_processor_slow.js +0 -13
  793. package/src/test/test_bulk.ts +0 -59
  794. package/src/test/test_child-pool.ts +0 -88
  795. package/src/test/test_clean.ts +0 -148
  796. package/src/test/test_compat.ts +0 -640
  797. package/src/test/test_connection.ts +0 -161
  798. package/src/test/test_delay.ts +0 -221
  799. package/src/test/test_events.ts +0 -198
  800. package/src/test/test_getters.ts +0 -348
  801. package/src/test/test_job.ts +0 -524
  802. package/src/test/test_pause.ts +0 -312
  803. package/src/test/test_queue.ts +0 -70
  804. package/src/test/test_rate_limiter.ts +0 -113
  805. package/src/test/test_repeat.ts +0 -787
  806. package/src/test/test_sandboxed_process.ts +0 -380
  807. package/src/test/test_stalled_jobs.ts +0 -146
  808. package/src/test/test_worker.ts +0 -1503
  809. package/src/utils.ts +0 -28
  810. package/tsconfig.json +0 -25
  811. package/tslint.json +0 -23
  812. /package/dist/{classes/master.d.ts → cjs/classes/main-worker.d.ts} +0 -0
  813. /package/dist/{test/test_bulk.d.ts → cjs/classes/main.d.ts} +0 -0
  814. /package/dist/{interfaces → cjs/interfaces}/backoff-options.js +0 -0
  815. /package/dist/{interfaces → cjs/interfaces}/rate-limiter-options.js +0 -0
  816. /package/dist/{interfaces → cjs/interfaces}/redis-options.js +0 -0
  817. /package/dist/{interfaces → cjs/interfaces}/repeat-options.js +0 -0
  818. /package/dist/{interfaces → cjs/interfaces}/worker-options.js +0 -0
  819. /package/dist/{test/test_child-pool.d.ts → esm/classes/main-worker.d.ts} +0 -0
  820. /package/dist/{test/test_clean.d.ts → esm/classes/main.d.ts} +0 -0
@@ -1,319 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const tslib_1 = require("tslib");
4
- const chai_1 = require("chai");
5
- const ioredis_1 = tslib_1.__importDefault(require("ioredis"));
6
- const lodash_1 = require("lodash");
7
- const classes_1 = require("@src/classes");
8
- const mocha_1 = require("mocha");
9
- const node_uuid_1 = require("node-uuid");
10
- const delay = require('delay');
11
- const pReflect = require('p-reflect');
12
- const pool = require('../classes/child-pool').pool;
13
- describe('sandboxed process', () => {
14
- let queue;
15
- let queueEvents;
16
- let queueName;
17
- let client;
18
- mocha_1.beforeEach(() => {
19
- client = new ioredis_1.default();
20
- return client.flushdb();
21
- });
22
- mocha_1.beforeEach(async () => {
23
- queueName = 'test-' + node_uuid_1.v4();
24
- queue = new classes_1.Queue(queueName);
25
- queueEvents = new classes_1.QueueEvents(queueName);
26
- return queueEvents.waitUntilReady();
27
- });
28
- afterEach(async () => {
29
- await queue.close();
30
- await queueEvents.close();
31
- await client.flushall();
32
- pool.clean();
33
- return client.quit();
34
- });
35
- it('should process and complete', async () => {
36
- const processFile = __dirname + '/fixtures/fixture_processor.js';
37
- const worker = new classes_1.Worker(queueName, processFile, {
38
- drainDelay: 1,
39
- settings: {
40
- guardInterval: 300000,
41
- stalledInterval: 300000,
42
- },
43
- });
44
- const completting = new Promise((resolve, reject) => {
45
- worker.on('completed', async (job, value) => {
46
- try {
47
- chai_1.expect(job.data).to.be.eql({ foo: 'bar' });
48
- chai_1.expect(value).to.be.eql(42);
49
- chai_1.expect(Object.keys(worker['childPool'].retained)).to.have.lengthOf(0);
50
- chai_1.expect(worker['childPool'].free[processFile]).to.have.lengthOf(1);
51
- await worker.close();
52
- resolve();
53
- }
54
- catch (err) {
55
- await worker.close();
56
- reject(err);
57
- }
58
- });
59
- });
60
- await queue.add('test', { foo: 'bar' });
61
- await completting;
62
- await worker.close();
63
- });
64
- it('should process with named processor', async () => {
65
- const processFile = __dirname + '/fixtures/fixture_processor.js';
66
- const worker = new classes_1.Worker(queueName, processFile, {
67
- drainDelay: 1,
68
- settings: {
69
- guardInterval: 300000,
70
- stalledInterval: 300000,
71
- },
72
- });
73
- const completting = new Promise((resolve, reject) => {
74
- worker.on('completed', async (job, value) => {
75
- try {
76
- chai_1.expect(job.data).to.be.eql({ foo: 'bar' });
77
- chai_1.expect(value).to.be.eql(42);
78
- chai_1.expect(Object.keys(worker['childPool'].retained)).to.have.lengthOf(0);
79
- chai_1.expect(worker['childPool'].free[processFile]).to.have.lengthOf(1);
80
- await worker.close();
81
- resolve();
82
- }
83
- catch (err) {
84
- await worker.close();
85
- reject(err);
86
- }
87
- });
88
- });
89
- await queue.add('foobar', { foo: 'bar' });
90
- await completting;
91
- });
92
- it('should process with concurrent processors', async function () {
93
- this.timeout(10000);
94
- let worker;
95
- await Promise.all([
96
- queue.add('test', { foo: 'bar1' }),
97
- queue.add('test', { foo: 'bar2' }),
98
- queue.add('test', { foo: 'bar3' }),
99
- queue.add('test', { foo: 'bar4' }),
100
- ]);
101
- const processFile = __dirname + '/fixtures/fixture_processor_slow.js';
102
- worker = new classes_1.Worker(queueName, processFile, {
103
- concurrency: 4,
104
- drainDelay: 1,
105
- settings: {
106
- guardInterval: 300000,
107
- stalledInterval: 300000,
108
- },
109
- });
110
- const completing = new Promise((resolve, reject) => {
111
- const after4 = lodash_1.after(4, () => {
112
- chai_1.expect(worker['childPool'].getAllFree().length).to.eql(4);
113
- resolve();
114
- });
115
- worker.on('completed', async (job, value) => {
116
- try {
117
- chai_1.expect(value).to.be.eql(42);
118
- chai_1.expect(Object.keys(worker['childPool'].retained).length +
119
- worker['childPool'].getAllFree().length).to.eql(4);
120
- after4();
121
- }
122
- catch (err) {
123
- await worker.close();
124
- reject(err);
125
- }
126
- });
127
- });
128
- await completing;
129
- await worker.close();
130
- });
131
- it('should reuse process with single processors', async function () {
132
- this.timeout(30000);
133
- let worker;
134
- const processFile = __dirname + '/fixtures/fixture_processor_slow.js';
135
- worker = new classes_1.Worker(queueName, processFile, {
136
- concurrency: 1,
137
- drainDelay: 1,
138
- settings: {
139
- guardInterval: 300000,
140
- stalledInterval: 300000,
141
- },
142
- });
143
- await Promise.all([
144
- queue.add('1', { foo: 'bar1' }),
145
- queue.add('2', { foo: 'bar2' }),
146
- queue.add('3', { foo: 'bar3' }),
147
- queue.add('4', { foo: 'bar4' }),
148
- ]);
149
- const completting = new Promise((resolve, reject) => {
150
- const after4 = lodash_1.after(4, async () => {
151
- chai_1.expect(worker['childPool'].getAllFree().length).to.eql(1);
152
- await worker.close();
153
- resolve();
154
- });
155
- worker.on('completed', async (job, value) => {
156
- try {
157
- chai_1.expect(value).to.be.eql(42);
158
- chai_1.expect(Object.keys(worker['childPool'].retained).length +
159
- worker['childPool'].getAllFree().length).to.eql(1);
160
- await after4();
161
- }
162
- catch (err) {
163
- await worker.close();
164
- reject(err);
165
- }
166
- });
167
- });
168
- await completting;
169
- });
170
- it('should process and update progress', async () => {
171
- const processFile = __dirname + '/fixtures/fixture_processor_progress.js';
172
- const worker = new classes_1.Worker(queueName, processFile, {
173
- drainDelay: 1,
174
- settings: {
175
- guardInterval: 300000,
176
- stalledInterval: 300000,
177
- },
178
- });
179
- const progresses = [];
180
- const completting = new Promise((resolve, reject) => {
181
- worker.on('completed', (job, value) => {
182
- try {
183
- chai_1.expect(job.data).to.be.eql({ foo: 'bar' });
184
- chai_1.expect(value).to.be.eql(37);
185
- chai_1.expect(job.progress).to.be.eql(100);
186
- chai_1.expect(progresses).to.be.eql([10, 27, 78, 100]);
187
- chai_1.expect(Object.keys(worker['childPool'].retained)).to.have.lengthOf(0);
188
- chai_1.expect(worker['childPool'].getAllFree()).to.have.lengthOf(1);
189
- resolve();
190
- }
191
- catch (err) {
192
- reject(err);
193
- }
194
- });
195
- });
196
- worker.on('progress', (job, progress) => {
197
- progresses.push(progress);
198
- });
199
- await queue.add('test', { foo: 'bar' });
200
- await completting;
201
- await worker.close();
202
- });
203
- it('should process and fail', async () => {
204
- const processFile = __dirname + '/fixtures/fixture_processor_fail.js';
205
- const worker = new classes_1.Worker(queueName, processFile, {
206
- drainDelay: 1,
207
- settings: {
208
- guardInterval: 300000,
209
- stalledInterval: 300000,
210
- },
211
- });
212
- const failing = new Promise((resolve, reject) => {
213
- worker.on('failed', async (job, err) => {
214
- try {
215
- chai_1.expect(job.data).eql({ foo: 'bar' });
216
- chai_1.expect(job.failedReason).eql('Manually failed processor');
217
- chai_1.expect(err.message).eql('Manually failed processor');
218
- chai_1.expect(err.stack).include('fixture_processor_fail.js');
219
- chai_1.expect(Object.keys(worker['childPool'].retained)).to.have.lengthOf(0);
220
- chai_1.expect(worker['childPool'].getAllFree()).to.have.lengthOf(1);
221
- resolve();
222
- }
223
- catch (err) {
224
- await worker.close();
225
- reject(err);
226
- }
227
- });
228
- });
229
- await queue.add('test', { foo: 'bar' });
230
- await failing;
231
- await worker.close();
232
- });
233
- it('should error if processor file is missing', async () => {
234
- let worker;
235
- let didThrow = false;
236
- try {
237
- const missingProcessFile = __dirname + '/fixtures/missing_processor.js';
238
- worker = new classes_1.Worker(queueName, missingProcessFile, {});
239
- }
240
- catch (err) {
241
- didThrow = true;
242
- }
243
- worker && (await worker.close());
244
- if (!didThrow) {
245
- throw new Error('did not throw error');
246
- }
247
- });
248
- it('should fail if the process crashes', async () => {
249
- const processFile = __dirname + '/fixtures/fixture_processor_crash.js';
250
- const worker = new classes_1.Worker(queueName, processFile, {
251
- drainDelay: 1,
252
- settings: {
253
- guardInterval: 300000,
254
- stalledInterval: 300000,
255
- },
256
- });
257
- const job = await queue.add('test', {});
258
- const inspection = await pReflect(Promise.resolve(job.waitUntilFinished(queueEvents)));
259
- chai_1.expect(inspection.isRejected).to.be.eql(true);
260
- chai_1.expect(inspection.reason.message).to.be.eql('boom!');
261
- });
262
- it('should fail if the process exits 0', async () => {
263
- const processFile = __dirname + '/fixtures/fixture_processor_crash.js';
264
- new classes_1.Worker(queueName, processFile, {
265
- drainDelay: 1,
266
- settings: {
267
- guardInterval: 300000,
268
- stalledInterval: 300000,
269
- },
270
- });
271
- const job = await queue.add('test', { exitCode: 0 });
272
- const inspection = await pReflect(Promise.resolve(job.waitUntilFinished(queueEvents)));
273
- chai_1.expect(inspection.isRejected).to.be.eql(true);
274
- chai_1.expect(inspection.reason.message).to.be.eql('Unexpected exit code: 0 signal: null');
275
- });
276
- it('should fail if the process exits non-0', async () => {
277
- const processFile = __dirname + '/fixtures/fixture_processor_crash.js';
278
- new classes_1.Worker(queueName, processFile, {
279
- drainDelay: 1,
280
- settings: {
281
- guardInterval: 300000,
282
- stalledInterval: 300000,
283
- },
284
- });
285
- const job = await queue.add('test', { exitCode: 1 });
286
- const inspection = await pReflect(Promise.resolve(job.waitUntilFinished(queueEvents)));
287
- chai_1.expect(inspection.isRejected).to.be.eql(true);
288
- chai_1.expect(inspection.reason.message).to.be.eql('Unexpected exit code: 1 signal: null');
289
- });
290
- it('should remove exited process', async () => {
291
- const processFile = __dirname + '/fixtures/fixture_processor_exit.js';
292
- const worker = new classes_1.Worker(queueName, processFile, {
293
- drainDelay: 1,
294
- settings: {
295
- guardInterval: 300000,
296
- stalledInterval: 300000,
297
- },
298
- });
299
- const completting = new Promise((resolve, reject) => {
300
- worker.on('completed', async () => {
301
- try {
302
- chai_1.expect(Object.keys(worker['childPool'].retained)).to.have.lengthOf(0);
303
- chai_1.expect(worker['childPool'].getAllFree()).to.have.lengthOf(1);
304
- await delay(500);
305
- chai_1.expect(Object.keys(worker['childPool'].retained)).to.have.lengthOf(0);
306
- chai_1.expect(worker['childPool'].getAllFree()).to.have.lengthOf(0);
307
- resolve();
308
- }
309
- catch (err) {
310
- reject(err);
311
- }
312
- });
313
- });
314
- await queue.add('test', { foo: 'bar' });
315
- await completting;
316
- await worker.close();
317
- });
318
- });
319
- //# sourceMappingURL=test_sandboxed_process.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"test_sandboxed_process.js","sourceRoot":"","sources":["../../src/test/test_sandboxed_process.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- export {};
@@ -1,107 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const tslib_1 = require("tslib");
4
- const classes_1 = require("@src/classes");
5
- const bluebird_1 = require("bluebird");
6
- const ioredis_1 = tslib_1.__importDefault(require("ioredis"));
7
- const lodash_1 = require("lodash");
8
- const mocha_1 = require("mocha");
9
- const node_uuid_1 = require("node-uuid");
10
- mocha_1.describe('stalled jobs', function () {
11
- let queue;
12
- let queueName;
13
- let client;
14
- mocha_1.beforeEach(function () {
15
- client = new ioredis_1.default();
16
- return client.flushdb();
17
- });
18
- mocha_1.beforeEach(async function () {
19
- queueName = 'test-' + node_uuid_1.v4();
20
- queue = new classes_1.Queue(queueName);
21
- });
22
- afterEach(async function () {
23
- await queue.close();
24
- return client.quit();
25
- });
26
- mocha_1.it('process stalled jobs when starting a queue', async function () {
27
- this.timeout(10000);
28
- const queueEvents = new classes_1.QueueEvents(queueName);
29
- await queueEvents.waitUntilReady();
30
- const concurrency = 4;
31
- const worker = new classes_1.Worker(queueName, async (job) => {
32
- return bluebird_1.delay(10000);
33
- }, {
34
- settings: {
35
- stalledInterval: 1000,
36
- },
37
- concurrency,
38
- });
39
- const allActive = new Promise(resolve => {
40
- worker.on('active', lodash_1.after(concurrency, resolve));
41
- });
42
- await worker.waitUntilReady();
43
- const jobs = await Promise.all([
44
- queue.add('test', { bar: 'baz' }),
45
- queue.add('test', { bar1: 'baz1' }),
46
- queue.add('test', { bar2: 'baz2' }),
47
- queue.add('test', { bar3: 'baz3' }),
48
- ]);
49
- await allActive;
50
- const queueScheduler = new classes_1.QueueScheduler(queueName, {
51
- stalledInterval: 100,
52
- });
53
- await queueScheduler.waitUntilReady();
54
- const allStalled = new Promise(resolve => {
55
- queueScheduler.on('stalled', lodash_1.after(concurrency, resolve));
56
- });
57
- const allStalledGlobalEvent = new Promise(resolve => {
58
- queueEvents.on('stalled', lodash_1.after(concurrency, resolve));
59
- });
60
- await allStalled;
61
- await allStalledGlobalEvent;
62
- await worker.close(true);
63
- const worker2 = new classes_1.Worker(queueName, async (job) => { }, { concurrency });
64
- const allCompleted = new Promise(resolve => {
65
- worker2.on('completed', lodash_1.after(concurrency, resolve));
66
- });
67
- await allCompleted;
68
- await queueEvents.close();
69
- await queueScheduler.close();
70
- await worker2.close();
71
- });
72
- mocha_1.it('fail stalled jobs that stall more than allowable stalled limit', async function () {
73
- this.timeout(6000);
74
- const concurrency = 4;
75
- const worker = new classes_1.Worker(queueName, async (job) => {
76
- return bluebird_1.delay(10000);
77
- }, {
78
- settings: {
79
- stalledInterval: 100,
80
- },
81
- concurrency,
82
- });
83
- const allActive = new Promise(resolve => {
84
- worker.on('active', lodash_1.after(concurrency, resolve));
85
- });
86
- await worker.waitUntilReady();
87
- const jobs = await Promise.all([
88
- queue.add('test', { bar: 'baz' }),
89
- queue.add('test', { bar1: 'baz1' }),
90
- queue.add('test', { bar2: 'baz2' }),
91
- queue.add('test', { bar3: 'baz3' }),
92
- ]);
93
- await allActive;
94
- const queueScheduler = new classes_1.QueueScheduler(queueName, {
95
- stalledInterval: 100,
96
- maxStalledCount: 0,
97
- });
98
- await queueScheduler.waitUntilReady();
99
- const allFailed = new Promise(resolve => {
100
- queueScheduler.on('failed', lodash_1.after(concurrency, resolve));
101
- });
102
- await allFailed;
103
- await worker.close(true);
104
- await queueScheduler.close();
105
- });
106
- });
107
- //# sourceMappingURL=test_stalled_jobs.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"test_stalled_jobs.js","sourceRoot":"","sources":["../../src/test/test_stalled_jobs.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- export {};