@daiso-tech/core 0.40.0 → 0.41.1

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 (672) hide show
  1. package/README.md +8 -1
  2. package/dist/backoff-policies/_module-exports.d.ts +5 -0
  3. package/dist/backoff-policies/_module-exports.js +6 -0
  4. package/dist/backoff-policies/_module-exports.js.map +1 -0
  5. package/dist/{async/backof-policies → backoff-policies}/_shared.d.ts +6 -7
  6. package/dist/{async/backof-policies → backoff-policies}/_shared.js +1 -1
  7. package/dist/backoff-policies/_shared.js.map +1 -0
  8. package/dist/backoff-policies/constant-backoff-policy/_module.d.ts +1 -0
  9. package/dist/backoff-policies/constant-backoff-policy/_module.js +2 -0
  10. package/dist/backoff-policies/constant-backoff-policy/_module.js.map +1 -0
  11. package/dist/{async/backof-policies → backoff-policies}/constant-backoff-policy/constant-backoff-policy.d.ts +6 -8
  12. package/dist/{async/backof-policies → backoff-policies}/constant-backoff-policy/constant-backoff-policy.js +8 -10
  13. package/dist/backoff-policies/constant-backoff-policy/constant-backoff-policy.js.map +1 -0
  14. package/dist/backoff-policies/exponential-backoff-policy/_module.d.ts +1 -0
  15. package/dist/backoff-policies/exponential-backoff-policy/_module.js +2 -0
  16. package/dist/backoff-policies/exponential-backoff-policy/_module.js.map +1 -0
  17. package/dist/{async/backof-policies → backoff-policies}/exponential-backoff-policy/exponential-backoff-policy.d.ts +7 -9
  18. package/dist/backoff-policies/exponential-backoff-policy/exponential-backoff-policy.js +30 -0
  19. package/dist/backoff-policies/exponential-backoff-policy/exponential-backoff-policy.js.map +1 -0
  20. package/dist/backoff-policies/linear-backoff-policy/_module.d.ts +1 -0
  21. package/dist/backoff-policies/linear-backoff-policy/_module.js +2 -0
  22. package/dist/backoff-policies/linear-backoff-policy/_module.js.map +1 -0
  23. package/dist/{async/backof-policies → backoff-policies}/linear-backoff-policy/linear-backoff-policy.d.ts +7 -9
  24. package/dist/backoff-policies/linear-backoff-policy/linear-backoff-policy.js +30 -0
  25. package/dist/backoff-policies/linear-backoff-policy/linear-backoff-policy.js.map +1 -0
  26. package/dist/backoff-policies/polynomial-backoff-policy/_module.d.ts +1 -0
  27. package/dist/backoff-policies/polynomial-backoff-policy/_module.js +2 -0
  28. package/dist/backoff-policies/polynomial-backoff-policy/_module.js.map +1 -0
  29. package/dist/{async/backof-policies → backoff-policies}/polynomial-backoff-policy/polynomial-backoff-policy.d.ts +7 -9
  30. package/dist/backoff-policies/polynomial-backoff-policy/polynomial-backoff-policy.js +30 -0
  31. package/dist/backoff-policies/polynomial-backoff-policy/polynomial-backoff-policy.js.map +1 -0
  32. package/dist/cache/contracts/cache-adapter.contract.d.ts +3 -3
  33. package/dist/cache/contracts/cache.contract.d.ts +22 -22
  34. package/dist/cache/contracts/cache.errors.d.ts +7 -14
  35. package/dist/cache/contracts/cache.errors.js +12 -24
  36. package/dist/cache/contracts/cache.errors.js.map +1 -1
  37. package/dist/cache/contracts/cache.events.d.ts +1 -1
  38. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.d.ts +1 -1
  39. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.js +4 -4
  40. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.js.map +1 -1
  41. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.d.ts +1 -1
  42. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js +2 -2
  43. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js.map +1 -1
  44. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.d.ts +3 -2
  45. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js +3 -3
  46. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js.map +1 -1
  47. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.d.ts +1 -1
  48. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.d.ts +1 -1
  49. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js +2 -2
  50. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js.map +1 -1
  51. package/dist/cache/implementations/derivables/cache/cache.d.ts +38 -43
  52. package/dist/cache/implementations/derivables/cache/cache.js +106 -101
  53. package/dist/cache/implementations/derivables/cache/cache.js.map +1 -1
  54. package/dist/cache/implementations/derivables/cache/database-cache-adapter.d.ts +1 -1
  55. package/dist/cache/implementations/derivables/cache/database-cache-adapter.js +3 -3
  56. package/dist/cache/implementations/derivables/cache/database-cache-adapter.js.map +1 -1
  57. package/dist/cache/implementations/derivables/cache-factory/cache-factory.d.ts +6 -8
  58. package/dist/cache/implementations/derivables/cache-factory/cache-factory.js +5 -15
  59. package/dist/cache/implementations/derivables/cache-factory/cache-factory.js.map +1 -1
  60. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.d.ts +1 -1
  61. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js +48 -48
  62. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js.map +1 -1
  63. package/dist/cache/implementations/test-utilities/cache.test-suite.js +107 -107
  64. package/dist/cache/implementations/test-utilities/cache.test-suite.js.map +1 -1
  65. package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.js +2 -1
  66. package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.js.map +1 -1
  67. package/dist/collection/contracts/async-collection.contract.d.ts +43 -43
  68. package/dist/collection/contracts/collection.contract.d.ts +15 -1
  69. package/dist/collection/contracts/collection.contract.js +1 -3
  70. package/dist/collection/contracts/collection.contract.js.map +1 -1
  71. package/dist/collection/contracts/collection.errors.d.ts +4 -13
  72. package/dist/collection/contracts/collection.errors.js +4 -16
  73. package/dist/collection/contracts/collection.errors.js.map +1 -1
  74. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.d.ts +6 -0
  75. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.js +3 -0
  76. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.js.map +1 -1
  77. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.d.ts +40 -51
  78. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.js +31 -37
  79. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.js.map +1 -1
  80. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.d.ts +3 -0
  81. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.js +6 -0
  82. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.js.map +1 -1
  83. package/dist/collection/implementations/iterable-collection/iterable-collection.d.ts +3 -3
  84. package/dist/collection/implementations/iterable-collection/iterable-collection.js +5 -2
  85. package/dist/collection/implementations/iterable-collection/iterable-collection.js.map +1 -1
  86. package/dist/collection/implementations/list-collection/list-collection.d.ts +3 -3
  87. package/dist/collection/implementations/list-collection/list-collection.js +5 -2
  88. package/dist/collection/implementations/list-collection/list-collection.js.map +1 -1
  89. package/dist/event-bus/contracts/event-bus.contract.d.ts +10 -10
  90. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.d.ts +3 -6
  91. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js +7 -9
  92. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js.map +1 -1
  93. package/dist/event-bus/implementations/derivables/event-bus/event-bus.d.ts +17 -24
  94. package/dist/event-bus/implementations/derivables/event-bus/event-bus.js +32 -32
  95. package/dist/event-bus/implementations/derivables/event-bus/event-bus.js.map +1 -1
  96. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.d.ts +1 -3
  97. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js +4 -8
  98. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js.map +1 -1
  99. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.js +34 -32
  100. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.js.map +1 -1
  101. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.js +195 -190
  102. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.js.map +1 -1
  103. package/dist/hooks/_module-exports.d.ts +3 -0
  104. package/dist/hooks/_module-exports.js +4 -0
  105. package/dist/hooks/_module-exports.js.map +1 -0
  106. package/dist/{utilities/classes/hooks → hooks}/async-hooks.d.ts +15 -26
  107. package/dist/{utilities/classes/hooks → hooks}/async-hooks.js +4 -6
  108. package/dist/hooks/async-hooks.js.map +1 -0
  109. package/dist/{utilities/classes/hooks → hooks}/hooks.d.ts +11 -18
  110. package/dist/{utilities/classes/hooks → hooks}/hooks.js +4 -5
  111. package/dist/hooks/hooks.js.map +1 -0
  112. package/dist/{utilities/classes/hooks → hooks}/types.d.ts +2 -3
  113. package/dist/hooks/types.js +5 -0
  114. package/dist/hooks/types.js.map +1 -0
  115. package/dist/lock/contracts/_module-exports.d.ts +4 -2
  116. package/dist/lock/contracts/_module-exports.js +4 -2
  117. package/dist/lock/contracts/_module-exports.js.map +1 -1
  118. package/dist/lock/contracts/database-lock-adapter.contract.d.ts +24 -17
  119. package/dist/lock/contracts/lock-adapter.contract.d.ts +15 -24
  120. package/dist/lock/contracts/lock-adapter.contract.js +1 -10
  121. package/dist/lock/contracts/lock-adapter.contract.js.map +1 -1
  122. package/dist/lock/contracts/lock-provider.contract.d.ts +5 -5
  123. package/dist/lock/contracts/lock-state.contract.d.ts +52 -0
  124. package/dist/lock/contracts/lock-state.contract.js +14 -0
  125. package/dist/lock/contracts/lock-state.contract.js.map +1 -0
  126. package/dist/lock/contracts/lock.contract.d.ts +64 -55
  127. package/dist/lock/contracts/lock.errors.d.ts +13 -20
  128. package/dist/lock/contracts/lock.errors.js +19 -26
  129. package/dist/lock/contracts/lock.errors.js.map +1 -1
  130. package/dist/lock/contracts/lock.events.d.ts +21 -49
  131. package/dist/lock/contracts/lock.events.js +2 -3
  132. package/dist/lock/contracts/lock.events.js.map +1 -1
  133. package/dist/lock/contracts/types.d.ts +11 -0
  134. package/dist/lock/contracts/types.js +5 -0
  135. package/dist/lock/contracts/types.js.map +1 -0
  136. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.d.ts +21 -19
  137. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js +92 -61
  138. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js.map +1 -1
  139. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.d.ts +8 -5
  140. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js +33 -13
  141. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js.map +1 -1
  142. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.d.ts +7 -8
  143. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js +33 -20
  144. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js.map +1 -1
  145. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.d.ts +6 -5
  146. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.js +7 -5
  147. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.js.map +1 -1
  148. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.d.ts +26 -8
  149. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js +61 -28
  150. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js.map +1 -1
  151. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.d.ts +6 -5
  152. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.js +33 -33
  153. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.js.map +1 -1
  154. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.d.ts +2 -2
  155. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.js +4 -6
  156. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.js.map +1 -1
  157. package/dist/lock/implementations/derivables/lock-provider/lock-provider.d.ts +29 -39
  158. package/dist/lock/implementations/derivables/lock-provider/lock-provider.js +31 -35
  159. package/dist/lock/implementations/derivables/lock-provider/lock-provider.js.map +1 -1
  160. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.d.ts +5 -8
  161. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js +27 -23
  162. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js.map +1 -1
  163. package/dist/lock/implementations/derivables/lock-provider/lock.d.ts +38 -34
  164. package/dist/lock/implementations/derivables/lock-provider/lock.js +182 -257
  165. package/dist/lock/implementations/derivables/lock-provider/lock.js.map +1 -1
  166. package/dist/lock/implementations/derivables/lock-provider/resolve-database-lock-adapter.d.ts +9 -0
  167. package/dist/lock/implementations/derivables/lock-provider/resolve-database-lock-adapter.js +12 -0
  168. package/dist/lock/implementations/derivables/lock-provider/resolve-database-lock-adapter.js.map +1 -0
  169. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.d.ts +12 -13
  170. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js +7 -16
  171. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js.map +1 -1
  172. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.js +310 -207
  173. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.js.map +1 -1
  174. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.d.ts +1 -1
  175. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.js +376 -292
  176. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.js.map +1 -1
  177. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.d.ts +15 -5
  178. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.js +3285 -2976
  179. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.js.map +1 -1
  180. package/dist/namespace/_module-exports.d.ts +1 -0
  181. package/dist/namespace/_module-exports.js +2 -0
  182. package/dist/namespace/_module-exports.js.map +1 -0
  183. package/dist/namespace/namespace.d.ts +87 -0
  184. package/dist/namespace/namespace.js +117 -0
  185. package/dist/namespace/namespace.js.map +1 -0
  186. package/dist/resilience/_module-exports.d.ts +2 -0
  187. package/dist/resilience/_module-exports.js +3 -0
  188. package/dist/resilience/_module-exports.js.map +1 -0
  189. package/dist/resilience/middlewares/_module.d.ts +5 -0
  190. package/dist/resilience/middlewares/_module.js +6 -0
  191. package/dist/resilience/middlewares/_module.js.map +1 -0
  192. package/dist/resilience/middlewares/dynamic/_module.d.ts +1 -0
  193. package/dist/resilience/middlewares/dynamic/_module.js +2 -0
  194. package/dist/resilience/middlewares/dynamic/_module.js.map +1 -0
  195. package/dist/{async → resilience}/middlewares/dynamic/dynamic.middleware.d.ts +6 -6
  196. package/dist/{async → resilience}/middlewares/dynamic/dynamic.middleware.js +5 -5
  197. package/dist/resilience/middlewares/dynamic/dynamic.middleware.js.map +1 -0
  198. package/dist/resilience/middlewares/fallback/_module.d.ts +2 -0
  199. package/dist/resilience/middlewares/fallback/_module.js +3 -0
  200. package/dist/resilience/middlewares/fallback/_module.js.map +1 -0
  201. package/dist/{async → resilience}/middlewares/fallback/fallback.middleware.d.ts +9 -9
  202. package/dist/{async → resilience}/middlewares/fallback/fallback.middleware.js +7 -6
  203. package/dist/resilience/middlewares/fallback/fallback.middleware.js.map +1 -0
  204. package/dist/{async → resilience}/middlewares/fallback/fallback.types.d.ts +7 -6
  205. package/dist/{async → resilience}/middlewares/fallback/fallback.types.js +1 -1
  206. package/dist/resilience/middlewares/fallback/fallback.types.js.map +1 -0
  207. package/dist/resilience/middlewares/observe/_module.d.ts +2 -0
  208. package/dist/resilience/middlewares/observe/_module.js +3 -0
  209. package/dist/resilience/middlewares/observe/_module.js.map +1 -0
  210. package/dist/{async → resilience}/middlewares/observe/observe.middleware.d.ts +13 -11
  211. package/dist/{async → resilience}/middlewares/observe/observe.middleware.js +14 -10
  212. package/dist/resilience/middlewares/observe/observe.middleware.js.map +1 -0
  213. package/dist/{async → resilience}/middlewares/observe/observe.types.d.ts +13 -12
  214. package/dist/resilience/middlewares/observe/observe.types.js +5 -0
  215. package/dist/resilience/middlewares/observe/observe.types.js.map +1 -0
  216. package/dist/resilience/middlewares/retry/_module.d.ts +2 -0
  217. package/dist/resilience/middlewares/retry/_module.js +3 -0
  218. package/dist/resilience/middlewares/retry/_module.js.map +1 -0
  219. package/dist/{async → resilience}/middlewares/retry/retry.middleware.d.ts +12 -9
  220. package/dist/{async → resilience}/middlewares/retry/retry.middleware.js +19 -15
  221. package/dist/resilience/middlewares/retry/retry.middleware.js.map +1 -0
  222. package/dist/{async → resilience}/middlewares/retry/retry.types.d.ts +14 -12
  223. package/dist/resilience/middlewares/retry/retry.types.js +7 -0
  224. package/dist/resilience/middlewares/retry/retry.types.js.map +1 -0
  225. package/dist/resilience/middlewares/timeout/_module.d.ts +2 -0
  226. package/dist/resilience/middlewares/timeout/_module.js +3 -0
  227. package/dist/resilience/middlewares/timeout/_module.js.map +1 -0
  228. package/dist/{async → resilience}/middlewares/timeout/timeout.middleware.d.ts +9 -7
  229. package/dist/{async → resilience}/middlewares/timeout/timeout.middleware.js +12 -11
  230. package/dist/resilience/middlewares/timeout/timeout.middleware.js.map +1 -0
  231. package/dist/{async → resilience}/middlewares/timeout/timeout.type.d.ts +10 -9
  232. package/dist/resilience/middlewares/timeout/timeout.type.js +5 -0
  233. package/dist/resilience/middlewares/timeout/timeout.type.js.map +1 -0
  234. package/dist/resilience/resilience.errors.d.ts +40 -0
  235. package/dist/resilience/resilience.errors.js +48 -0
  236. package/dist/resilience/resilience.errors.js.map +1 -0
  237. package/dist/resilience/utilities/_module.d.ts +2 -0
  238. package/dist/resilience/utilities/_module.js +3 -0
  239. package/dist/resilience/utilities/_module.js.map +1 -0
  240. package/dist/resilience/utilities/abort-and-fail/_module.d.ts +1 -0
  241. package/dist/resilience/utilities/abort-and-fail/_module.js +2 -0
  242. package/dist/resilience/utilities/abort-and-fail/_module.js.map +1 -0
  243. package/dist/resilience/utilities/abort-and-fail/abort-and-fail.d.ts +7 -0
  244. package/dist/resilience/utilities/abort-and-fail/abort-and-fail.js +51 -0
  245. package/dist/resilience/utilities/abort-and-fail/abort-and-fail.js.map +1 -0
  246. package/dist/resilience/utilities/timeout-and-fail/_module.d.ts +1 -0
  247. package/dist/resilience/utilities/timeout-and-fail/_module.js +2 -0
  248. package/dist/resilience/utilities/timeout-and-fail/_module.js.map +1 -0
  249. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.d.ts +7 -0
  250. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.js +23 -0
  251. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.js.map +1 -0
  252. package/dist/semaphore/contracts/_module-exports.d.ts +9 -0
  253. package/dist/semaphore/contracts/_module-exports.js +10 -0
  254. package/dist/semaphore/contracts/_module-exports.js.map +1 -0
  255. package/dist/semaphore/contracts/database-semaphore-adapter.contract.d.ts +90 -0
  256. package/dist/semaphore/contracts/database-semaphore-adapter.contract.js +5 -0
  257. package/dist/semaphore/contracts/database-semaphore-adapter.contract.js.map +1 -0
  258. package/dist/semaphore/contracts/semaphore-adapter.contract.d.ts +61 -0
  259. package/dist/semaphore/contracts/semaphore-adapter.contract.js +5 -0
  260. package/dist/semaphore/contracts/semaphore-adapter.contract.js.map +1 -0
  261. package/dist/semaphore/contracts/semaphore-provider-factory.contract.d.ts +19 -0
  262. package/dist/semaphore/contracts/semaphore-provider-factory.contract.js +9 -0
  263. package/dist/semaphore/contracts/semaphore-provider-factory.contract.js.map +1 -0
  264. package/dist/semaphore/contracts/semaphore-provider.contract.d.ts +50 -0
  265. package/dist/semaphore/contracts/semaphore-provider.contract.js +5 -0
  266. package/dist/semaphore/contracts/semaphore-provider.contract.js.map +1 -0
  267. package/dist/semaphore/contracts/semaphore-state.contract.d.ts +70 -0
  268. package/dist/semaphore/contracts/semaphore-state.contract.js +15 -0
  269. package/dist/semaphore/contracts/semaphore-state.contract.js.map +1 -0
  270. package/dist/semaphore/contracts/semaphore.contract.d.ts +127 -0
  271. package/dist/semaphore/contracts/semaphore.contract.js +5 -0
  272. package/dist/semaphore/contracts/semaphore.contract.js.map +1 -0
  273. package/dist/semaphore/contracts/semaphore.errors.d.ts +52 -0
  274. package/dist/semaphore/contracts/semaphore.errors.js +63 -0
  275. package/dist/semaphore/contracts/semaphore.errors.js.map +1 -0
  276. package/dist/semaphore/contracts/semaphore.events.d.ts +101 -0
  277. package/dist/semaphore/contracts/semaphore.events.js +19 -0
  278. package/dist/semaphore/contracts/semaphore.events.js.map +1 -0
  279. package/dist/semaphore/contracts/types.d.ts +11 -0
  280. package/dist/semaphore/contracts/types.js +5 -0
  281. package/dist/semaphore/contracts/types.js.map +1 -0
  282. package/dist/semaphore/implementations/adapters/_module-exports.d.ts +5 -0
  283. package/dist/semaphore/implementations/adapters/_module-exports.js +6 -0
  284. package/dist/semaphore/implementations/adapters/_module-exports.js.map +1 -0
  285. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module.d.ts +1 -0
  286. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module.js +2 -0
  287. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module.js.map +1 -0
  288. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.d.ts +97 -0
  289. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.js +313 -0
  290. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.js.map +1 -0
  291. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module.d.ts +1 -0
  292. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module.js +2 -0
  293. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module.js.map +1 -0
  294. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.d.ts +49 -0
  295. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.js +141 -0
  296. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.js.map +1 -0
  297. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module.d.ts +1 -0
  298. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module.js +2 -0
  299. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module.js.map +1 -0
  300. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.d.ts +80 -0
  301. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.js +390 -0
  302. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.js.map +1 -0
  303. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module.d.ts +1 -0
  304. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module.js +2 -0
  305. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module.js.map +1 -0
  306. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.d.ts +18 -0
  307. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.js +30 -0
  308. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.js.map +1 -0
  309. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module.d.ts +1 -0
  310. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module.js +2 -0
  311. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module.js.map +1 -0
  312. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.d.ts +48 -0
  313. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.js +338 -0
  314. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.js.map +1 -0
  315. package/dist/semaphore/implementations/derivables/_module-exports.d.ts +2 -0
  316. package/dist/semaphore/implementations/derivables/_module-exports.js +3 -0
  317. package/dist/semaphore/implementations/derivables/_module-exports.js.map +1 -0
  318. package/dist/semaphore/implementations/derivables/semaphore-provider/_module.d.ts +1 -0
  319. package/dist/semaphore/implementations/derivables/semaphore-provider/_module.js +2 -0
  320. package/dist/semaphore/implementations/derivables/semaphore-provider/_module.js.map +1 -0
  321. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.d.ts +17 -0
  322. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.js +74 -0
  323. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.js.map +1 -0
  324. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.d.ts +8 -0
  325. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.js +15 -0
  326. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.js.map +1 -0
  327. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-database-semaphore-adapter.d.ts +8 -0
  328. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-database-semaphore-adapter.js +15 -0
  329. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-database-semaphore-adapter.js.map +1 -0
  330. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.d.ts +149 -0
  331. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.js +135 -0
  332. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.js.map +1 -0
  333. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.d.ts +41 -0
  334. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.js +77 -0
  335. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.js.map +1 -0
  336. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.d.ts +83 -0
  337. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.js +336 -0
  338. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.js.map +1 -0
  339. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.d.ts +1 -0
  340. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.js +2 -0
  341. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.js.map +1 -0
  342. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.d.ts +40 -0
  343. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.js +67 -0
  344. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.js.map +1 -0
  345. package/dist/semaphore/implementations/test-utilities/_module-exports.d.ts +3 -0
  346. package/dist/semaphore/implementations/test-utilities/_module-exports.js +4 -0
  347. package/dist/semaphore/implementations/test-utilities/_module-exports.js.map +1 -0
  348. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.d.ts +59 -0
  349. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.js +536 -0
  350. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.js.map +1 -0
  351. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.d.ts +59 -0
  352. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.js +961 -0
  353. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.js.map +1 -0
  354. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.d.ts +67 -0
  355. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.js +4981 -0
  356. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.js.map +1 -0
  357. package/dist/serde/contracts/_module-exports.d.ts +0 -1
  358. package/dist/serde/contracts/_module-exports.js +0 -1
  359. package/dist/serde/contracts/_module-exports.js.map +1 -1
  360. package/dist/serde/contracts/flexible-serde.contract.d.ts +21 -5
  361. package/dist/serde/contracts/serde.errors.d.ts +14 -11
  362. package/dist/serde/contracts/serde.errors.js +15 -14
  363. package/dist/serde/contracts/serde.errors.js.map +1 -1
  364. package/dist/serde/implementations/adapters/_module-exports.d.ts +0 -3
  365. package/dist/serde/implementations/adapters/_module-exports.js +0 -3
  366. package/dist/serde/implementations/adapters/_module-exports.js.map +1 -1
  367. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.js +6 -0
  368. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.js.map +1 -1
  369. package/dist/serde/implementations/derivables/serde-transformers.d.ts +38 -30
  370. package/dist/serde/implementations/derivables/serde-transformers.js +62 -20
  371. package/dist/serde/implementations/derivables/serde-transformers.js.map +1 -1
  372. package/dist/serde/implementations/derivables/serde.d.ts +12 -3
  373. package/dist/serde/implementations/derivables/serde.js +5 -2
  374. package/dist/serde/implementations/derivables/serde.js.map +1 -1
  375. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.js +85 -1
  376. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.js.map +1 -1
  377. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.js +85 -1
  378. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.js.map +1 -1
  379. package/dist/shared-lock/contracts/_module-exports.d.ts +10 -0
  380. package/dist/shared-lock/contracts/_module-exports.js +11 -0
  381. package/dist/shared-lock/contracts/_module-exports.js.map +1 -0
  382. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.d.ts +145 -0
  383. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.js +5 -0
  384. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.js.map +1 -0
  385. package/dist/shared-lock/contracts/shared-lock-adapter.contract.d.ts +96 -0
  386. package/dist/shared-lock/contracts/shared-lock-adapter.contract.js +5 -0
  387. package/dist/shared-lock/contracts/shared-lock-adapter.contract.js.map +1 -0
  388. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.d.ts +19 -0
  389. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.js +9 -0
  390. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.js.map +1 -0
  391. package/dist/shared-lock/contracts/shared-lock-provider.contract.d.ts +53 -0
  392. package/dist/shared-lock/contracts/shared-lock-provider.contract.js +5 -0
  393. package/dist/shared-lock/contracts/shared-lock-provider.contract.js.map +1 -0
  394. package/dist/shared-lock/contracts/shared-lock-state.contract.d.ts +133 -0
  395. package/dist/shared-lock/contracts/shared-lock-state.contract.js +33 -0
  396. package/dist/shared-lock/contracts/shared-lock-state.contract.js.map +1 -0
  397. package/dist/shared-lock/contracts/shared-lock.contract.d.ts +222 -0
  398. package/dist/shared-lock/contracts/shared-lock.contract.js +13 -0
  399. package/dist/shared-lock/contracts/shared-lock.contract.js.map +1 -0
  400. package/dist/shared-lock/contracts/shared-lock.errors.d.ts +124 -0
  401. package/dist/shared-lock/contracts/shared-lock.errors.js +136 -0
  402. package/dist/shared-lock/contracts/shared-lock.errors.js.map +1 -0
  403. package/dist/shared-lock/contracts/shared-lock.events.d.ts +205 -0
  404. package/dist/shared-lock/contracts/shared-lock.events.js +43 -0
  405. package/dist/shared-lock/contracts/shared-lock.events.js.map +1 -0
  406. package/dist/shared-lock/contracts/types.d.ts +10 -0
  407. package/dist/shared-lock/contracts/types.js +5 -0
  408. package/dist/shared-lock/contracts/types.js.map +1 -0
  409. package/dist/shared-lock/implementations/adapters/_module-exports.d.ts +5 -0
  410. package/dist/shared-lock/implementations/adapters/_module-exports.js +6 -0
  411. package/dist/shared-lock/implementations/adapters/_module-exports.js.map +1 -0
  412. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module.d.ts +1 -0
  413. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module.js +2 -0
  414. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module.js.map +1 -0
  415. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.d.ts +114 -0
  416. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.js +496 -0
  417. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.js.map +1 -0
  418. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module.d.ts +1 -0
  419. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module.js +2 -0
  420. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module.js.map +1 -0
  421. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.d.ts +79 -0
  422. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.js +347 -0
  423. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.js.map +1 -0
  424. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module.d.ts +1 -0
  425. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module.js +2 -0
  426. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module.js.map +1 -0
  427. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.d.ts +112 -0
  428. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.js +805 -0
  429. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.js.map +1 -0
  430. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module.d.ts +1 -0
  431. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module.js +2 -0
  432. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module.js.map +1 -0
  433. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.d.ts +23 -0
  434. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.js +42 -0
  435. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.js.map +1 -0
  436. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module.d.ts +1 -0
  437. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module.js +2 -0
  438. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module.js.map +1 -0
  439. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.d.ts +79 -0
  440. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.js +630 -0
  441. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.js.map +1 -0
  442. package/dist/shared-lock/implementations/derivables/_module-exports.d.ts +2 -0
  443. package/dist/shared-lock/implementations/derivables/_module-exports.js +3 -0
  444. package/dist/shared-lock/implementations/derivables/_module-exports.js.map +1 -0
  445. package/dist/shared-lock/implementations/derivables/shared-lock-provider/_module.d.ts +1 -0
  446. package/dist/shared-lock/implementations/derivables/shared-lock-provider/_module.js +2 -0
  447. package/dist/shared-lock/implementations/derivables/shared-lock-provider/_module.js.map +1 -0
  448. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.d.ts +27 -0
  449. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.js +208 -0
  450. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.js.map +1 -0
  451. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.d.ts +8 -0
  452. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.js +12 -0
  453. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.js.map +1 -0
  454. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-database-shared-lock-adapter.d.ts +8 -0
  455. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-database-shared-lock-adapter.js +15 -0
  456. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-database-shared-lock-adapter.js.map +1 -0
  457. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.d.ts +190 -0
  458. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js +177 -0
  459. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js.map +1 -0
  460. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.d.ts +41 -0
  461. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.js +77 -0
  462. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.js.map +1 -0
  463. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.d.ts +95 -0
  464. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.js +542 -0
  465. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.js.map +1 -0
  466. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/_module.d.ts +1 -0
  467. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/_module.js +2 -0
  468. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/_module.js.map +1 -0
  469. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.d.ts +97 -0
  470. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.js +128 -0
  471. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.js.map +1 -0
  472. package/dist/shared-lock/implementations/test-utilities/_module-exports.d.ts +3 -0
  473. package/dist/shared-lock/implementations/test-utilities/_module-exports.js +4 -0
  474. package/dist/shared-lock/implementations/test-utilities/_module-exports.js.map +1 -0
  475. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.d.ts +59 -0
  476. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.js +944 -0
  477. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.js.map +1 -0
  478. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.d.ts +59 -0
  479. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.js +1921 -0
  480. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.js.map +1 -0
  481. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.d.ts +67 -0
  482. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.js +9833 -0
  483. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.js.map +1 -0
  484. package/dist/task/_module-exports.d.ts +1 -0
  485. package/dist/task/_module-exports.js +2 -0
  486. package/dist/task/_module-exports.js.map +1 -0
  487. package/dist/{async/utilities/abort-and-fail → task}/abort-and-fail.d.ts +1 -1
  488. package/dist/{async/utilities/abort-and-fail → task}/abort-and-fail.js +1 -1
  489. package/dist/task/abort-and-fail.js.map +1 -0
  490. package/dist/task/task.d.ts +194 -0
  491. package/dist/task/task.js +212 -0
  492. package/dist/task/task.js.map +1 -0
  493. package/dist/time-span/contracts/_module-exports.d.ts +1 -0
  494. package/dist/time-span/contracts/_module-exports.js +2 -0
  495. package/dist/time-span/contracts/_module-exports.js.map +1 -0
  496. package/dist/time-span/contracts/time-span.contract.d.ts +19 -0
  497. package/dist/time-span/contracts/time-span.contract.js +10 -0
  498. package/dist/time-span/contracts/time-span.contract.js.map +1 -0
  499. package/dist/time-span/implementations/_module-exports.d.ts +1 -0
  500. package/dist/time-span/implementations/_module-exports.js +2 -0
  501. package/dist/time-span/implementations/_module-exports.js.map +1 -0
  502. package/dist/{utilities/classes/time-span → time-span/implementations}/time-span.d.ts +49 -11
  503. package/dist/{utilities/classes/time-span → time-span/implementations}/time-span.js +33 -11
  504. package/dist/time-span/implementations/time-span.js.map +1 -0
  505. package/dist/utilities/classes/_module.d.ts +0 -3
  506. package/dist/utilities/classes/_module.js +0 -3
  507. package/dist/utilities/classes/_module.js.map +1 -1
  508. package/dist/utilities/contracts/_module.d.ts +1 -1
  509. package/dist/utilities/contracts/_module.js +1 -1
  510. package/dist/utilities/contracts/_module.js.map +1 -1
  511. package/dist/utilities/contracts/comparable.contract.d.ts +49 -0
  512. package/dist/utilities/contracts/comparable.contract.js +5 -0
  513. package/dist/utilities/contracts/comparable.contract.js.map +1 -0
  514. package/dist/utilities/functions/is-standard-schema.d.ts +6 -0
  515. package/dist/utilities/functions/is-standard-schema.js +6 -0
  516. package/dist/utilities/functions/is-standard-schema.js.map +1 -1
  517. package/dist/utilities/functions/lazy.d.ts +3 -3
  518. package/dist/utilities/functions/lazy.js +3 -3
  519. package/dist/utilities/functions/lazy.js.map +1 -1
  520. package/dist/utilities/functions/option.d.ts +3 -0
  521. package/dist/utilities/functions/option.js +3 -0
  522. package/dist/utilities/functions/option.js.map +1 -1
  523. package/dist/utilities/functions/validate.d.ts +5 -0
  524. package/dist/utilities/functions/validate.js +5 -0
  525. package/dist/utilities/functions/validate.js.map +1 -1
  526. package/dist/utilities/types/any-class.type.d.ts +6 -0
  527. package/dist/utilities/types/any-class.type.js +3 -0
  528. package/dist/utilities/types/any-class.type.js.map +1 -1
  529. package/package.json +67 -5
  530. package/dist/async/_module-exports.d.ts +0 -4
  531. package/dist/async/_module-exports.js +0 -5
  532. package/dist/async/_module-exports.js.map +0 -1
  533. package/dist/async/async.errors.d.ts +0 -47
  534. package/dist/async/async.errors.js +0 -61
  535. package/dist/async/async.errors.js.map +0 -1
  536. package/dist/async/backof-policies/_module.d.ts +0 -5
  537. package/dist/async/backof-policies/_module.js +0 -6
  538. package/dist/async/backof-policies/_module.js.map +0 -1
  539. package/dist/async/backof-policies/_shared.js.map +0 -1
  540. package/dist/async/backof-policies/constant-backoff-policy/_module.d.ts +0 -1
  541. package/dist/async/backof-policies/constant-backoff-policy/_module.js +0 -2
  542. package/dist/async/backof-policies/constant-backoff-policy/_module.js.map +0 -1
  543. package/dist/async/backof-policies/constant-backoff-policy/constant-backoff-policy.js.map +0 -1
  544. package/dist/async/backof-policies/exponential-backoff-policy/_module.d.ts +0 -1
  545. package/dist/async/backof-policies/exponential-backoff-policy/_module.js +0 -2
  546. package/dist/async/backof-policies/exponential-backoff-policy/_module.js.map +0 -1
  547. package/dist/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js +0 -35
  548. package/dist/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js.map +0 -1
  549. package/dist/async/backof-policies/linear-backoff-policy/_module.d.ts +0 -1
  550. package/dist/async/backof-policies/linear-backoff-policy/_module.js +0 -2
  551. package/dist/async/backof-policies/linear-backoff-policy/_module.js.map +0 -1
  552. package/dist/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js +0 -35
  553. package/dist/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js.map +0 -1
  554. package/dist/async/backof-policies/polynomial-backoff-policy/_module.d.ts +0 -1
  555. package/dist/async/backof-policies/polynomial-backoff-policy/_module.js +0 -2
  556. package/dist/async/backof-policies/polynomial-backoff-policy/_module.js.map +0 -1
  557. package/dist/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js +0 -35
  558. package/dist/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js.map +0 -1
  559. package/dist/async/middlewares/_module.d.ts +0 -7
  560. package/dist/async/middlewares/_module.js +0 -8
  561. package/dist/async/middlewares/_module.js.map +0 -1
  562. package/dist/async/middlewares/bulkhead/_module.d.ts +0 -1
  563. package/dist/async/middlewares/bulkhead/_module.js +0 -2
  564. package/dist/async/middlewares/bulkhead/_module.js.map +0 -1
  565. package/dist/async/middlewares/bulkhead/bulkhead.middleware.d.ts +0 -80
  566. package/dist/async/middlewares/bulkhead/bulkhead.middleware.js +0 -46
  567. package/dist/async/middlewares/bulkhead/bulkhead.middleware.js.map +0 -1
  568. package/dist/async/middlewares/dynamic/_module.d.ts +0 -1
  569. package/dist/async/middlewares/dynamic/_module.js +0 -2
  570. package/dist/async/middlewares/dynamic/_module.js.map +0 -1
  571. package/dist/async/middlewares/dynamic/dynamic.middleware.js.map +0 -1
  572. package/dist/async/middlewares/fallback/_module.d.ts +0 -2
  573. package/dist/async/middlewares/fallback/_module.js +0 -3
  574. package/dist/async/middlewares/fallback/_module.js.map +0 -1
  575. package/dist/async/middlewares/fallback/fallback.middleware.js.map +0 -1
  576. package/dist/async/middlewares/fallback/fallback.types.js.map +0 -1
  577. package/dist/async/middlewares/hedging/_module.d.ts +0 -2
  578. package/dist/async/middlewares/hedging/_module.js +0 -3
  579. package/dist/async/middlewares/hedging/_module.js.map +0 -1
  580. package/dist/async/middlewares/hedging/hedging.types.d.ts +0 -121
  581. package/dist/async/middlewares/hedging/hedging.types.js +0 -6
  582. package/dist/async/middlewares/hedging/hedging.types.js.map +0 -1
  583. package/dist/async/middlewares/hedging/sequential-hedging.middleware.d.ts +0 -51
  584. package/dist/async/middlewares/hedging/sequential-hedging.middleware.js +0 -133
  585. package/dist/async/middlewares/hedging/sequential-hedging.middleware.js.map +0 -1
  586. package/dist/async/middlewares/observe/_module.d.ts +0 -2
  587. package/dist/async/middlewares/observe/_module.js +0 -3
  588. package/dist/async/middlewares/observe/_module.js.map +0 -1
  589. package/dist/async/middlewares/observe/observe.middleware.js.map +0 -1
  590. package/dist/async/middlewares/observe/observe.types.js +0 -6
  591. package/dist/async/middlewares/observe/observe.types.js.map +0 -1
  592. package/dist/async/middlewares/retry/_module.d.ts +0 -2
  593. package/dist/async/middlewares/retry/_module.js +0 -3
  594. package/dist/async/middlewares/retry/_module.js.map +0 -1
  595. package/dist/async/middlewares/retry/retry.middleware.js.map +0 -1
  596. package/dist/async/middlewares/retry/retry.types.js +0 -7
  597. package/dist/async/middlewares/retry/retry.types.js.map +0 -1
  598. package/dist/async/middlewares/timeout/_module.d.ts +0 -2
  599. package/dist/async/middlewares/timeout/_module.js +0 -3
  600. package/dist/async/middlewares/timeout/_module.js.map +0 -1
  601. package/dist/async/middlewares/timeout/timeout.middleware.js.map +0 -1
  602. package/dist/async/middlewares/timeout/timeout.type.js +0 -6
  603. package/dist/async/middlewares/timeout/timeout.type.js.map +0 -1
  604. package/dist/async/utilities/_module.d.ts +0 -4
  605. package/dist/async/utilities/_module.js +0 -5
  606. package/dist/async/utilities/_module.js.map +0 -1
  607. package/dist/async/utilities/abort-and-fail/_module.d.ts +0 -1
  608. package/dist/async/utilities/abort-and-fail/_module.js +0 -2
  609. package/dist/async/utilities/abort-and-fail/_module.js.map +0 -1
  610. package/dist/async/utilities/abort-and-fail/abort-and-fail.js.map +0 -1
  611. package/dist/async/utilities/lazy-promise/_module.d.ts +0 -1
  612. package/dist/async/utilities/lazy-promise/_module.js +0 -2
  613. package/dist/async/utilities/lazy-promise/_module.js.map +0 -1
  614. package/dist/async/utilities/lazy-promise/lazy-promise.d.ts +0 -153
  615. package/dist/async/utilities/lazy-promise/lazy-promise.js +0 -176
  616. package/dist/async/utilities/lazy-promise/lazy-promise.js.map +0 -1
  617. package/dist/async/utilities/promise-queue/_module.d.ts +0 -1
  618. package/dist/async/utilities/promise-queue/_module.js +0 -2
  619. package/dist/async/utilities/promise-queue/_module.js.map +0 -1
  620. package/dist/async/utilities/promise-queue/promise-queue.d.ts +0 -32
  621. package/dist/async/utilities/promise-queue/promise-queue.js +0 -118
  622. package/dist/async/utilities/promise-queue/promise-queue.js.map +0 -1
  623. package/dist/async/utilities/timeout-and-fail/_module.d.ts +0 -1
  624. package/dist/async/utilities/timeout-and-fail/_module.js +0 -2
  625. package/dist/async/utilities/timeout-and-fail/_module.js.map +0 -1
  626. package/dist/async/utilities/timeout-and-fail/timeout-and-fail.d.ts +0 -7
  627. package/dist/async/utilities/timeout-and-fail/timeout-and-fail.js +0 -22
  628. package/dist/async/utilities/timeout-and-fail/timeout-and-fail.js.map +0 -1
  629. package/dist/lock/implementations/derivables/lock-provider/lock-state.d.ts +0 -40
  630. package/dist/lock/implementations/derivables/lock-provider/lock-state.js +0 -60
  631. package/dist/lock/implementations/derivables/lock-provider/lock-state.js.map +0 -1
  632. package/dist/serde/contracts/serializable.contract.d.ts +0 -12
  633. package/dist/serde/contracts/serializable.contract.js +0 -5
  634. package/dist/serde/contracts/serializable.contract.js.map +0 -1
  635. package/dist/serde/implementations/adapters/mongodb-serde/_module.d.ts +0 -1
  636. package/dist/serde/implementations/adapters/mongodb-serde/_module.js +0 -2
  637. package/dist/serde/implementations/adapters/mongodb-serde/_module.js.map +0 -1
  638. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.d.ts +0 -13
  639. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.js +0 -38
  640. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.js.map +0 -1
  641. package/dist/serde/implementations/adapters/redis-serde/_module.d.ts +0 -1
  642. package/dist/serde/implementations/adapters/redis-serde/_module.js +0 -2
  643. package/dist/serde/implementations/adapters/redis-serde/_module.js.map +0 -1
  644. package/dist/serde/implementations/adapters/redis-serde/redis-serde.d.ts +0 -13
  645. package/dist/serde/implementations/adapters/redis-serde/redis-serde.js +0 -39
  646. package/dist/serde/implementations/adapters/redis-serde/redis-serde.js.map +0 -1
  647. package/dist/serde/implementations/adapters/sql-serde/_module.d.ts +0 -1
  648. package/dist/serde/implementations/adapters/sql-serde/_module.js +0 -2
  649. package/dist/serde/implementations/adapters/sql-serde/_module.js.map +0 -1
  650. package/dist/serde/implementations/adapters/sql-serde/sql-serde.d.ts +0 -13
  651. package/dist/serde/implementations/adapters/sql-serde/sql-serde.js +0 -39
  652. package/dist/serde/implementations/adapters/sql-serde/sql-serde.js.map +0 -1
  653. package/dist/utilities/classes/hooks/_module.d.ts +0 -3
  654. package/dist/utilities/classes/hooks/_module.js +0 -4
  655. package/dist/utilities/classes/hooks/_module.js.map +0 -1
  656. package/dist/utilities/classes/hooks/async-hooks.js.map +0 -1
  657. package/dist/utilities/classes/hooks/hooks.js.map +0 -1
  658. package/dist/utilities/classes/hooks/types.js +0 -5
  659. package/dist/utilities/classes/hooks/types.js.map +0 -1
  660. package/dist/utilities/classes/namespace/_module.d.ts +0 -1
  661. package/dist/utilities/classes/namespace/_module.js +0 -2
  662. package/dist/utilities/classes/namespace/_module.js.map +0 -1
  663. package/dist/utilities/classes/namespace/namespace.d.ts +0 -85
  664. package/dist/utilities/classes/namespace/namespace.js +0 -125
  665. package/dist/utilities/classes/namespace/namespace.js.map +0 -1
  666. package/dist/utilities/classes/time-span/_module.d.ts +0 -1
  667. package/dist/utilities/classes/time-span/_module.js +0 -2
  668. package/dist/utilities/classes/time-span/_module.js.map +0 -1
  669. package/dist/utilities/classes/time-span/time-span.js.map +0 -1
  670. package/dist/utilities/contracts/serialized-error.contract.d.ts +0 -13
  671. package/dist/utilities/contracts/serialized-error.contract.js +0 -5
  672. package/dist/utilities/contracts/serialized-error.contract.js.map +0 -1
@@ -0,0 +1,961 @@
1
+ /**
2
+ * @module Semaphore
3
+ */
4
+ import { vi, } from "vitest";
5
+ import {} from "../../../semaphore/contracts/_module-exports.js";
6
+ import {} from "../../../utilities/_module-exports.js";
7
+ import { Task } from "../../../task/_module-exports.js";
8
+ import { TimeSpan } from "../../../time-span/implementations/_module-exports.js";
9
+ /**
10
+ * The `semaphoreAdapterTestSuite` function simplifies the process of testing your custom implementation of {@link ISemaphoreAdapter | `ISemaphoreAdapter`} with `vitest`.
11
+ *
12
+ * IMPORT_PATH: `"@daiso-tech/core/semaphore/test-utilities"`
13
+ * @group Utilities
14
+ * @example
15
+ * ```ts
16
+ * import { afterEach, beforeEach, describe, expect, test } from "vitest";
17
+ * import { semaphoreAdapterTestSuite } from "@daiso-tech/core/semaphore/test-utilities";
18
+ * import { RedisSemaphoreAdapter } from "@daiso-tech/core/semaphore/adapters";
19
+ * import { Redis } from "ioredis";
20
+ * import {
21
+ * RedisContainer,
22
+ * type StartedRedisContainer,
23
+ * } from "@testcontainers/redis";
24
+ * import { TimeSpan } from "@daiso-tech/core/utilities";
25
+ *
26
+ * const timeout = TimeSpan.fromMinutes(2);
27
+ * describe("class: RedisSemaphoreAdapter", () => {
28
+ * let client: Redis;
29
+ * let startedContainer: StartedRedisContainer;
30
+ * beforeEach(async () => {
31
+ * startedContainer = await new RedisContainer("redis:7.4.2").start();
32
+ * client = new Redis(startedContainer.getConnectionUrl());
33
+ * }, timeout.toMilliseconds());
34
+ * afterEach(async () => {
35
+ * await client.quit();
36
+ * await startedContainer.stop();
37
+ * }, timeout.toMilliseconds());
38
+ * semaphoreAdapterTestSuite({
39
+ * createAdapter: () =>
40
+ * new RedisSemaphoreAdapter(client),
41
+ * test,
42
+ * beforeEach,
43
+ * expect,
44
+ * describe,
45
+ * });
46
+ * });
47
+ * ```
48
+ */
49
+ export function semaphoreAdapterTestSuite(settings) {
50
+ const { expect, test, createAdapter, describe, beforeEach } = settings;
51
+ let adapter;
52
+ async function delay(time) {
53
+ await Task.delay(time.addMilliseconds(10));
54
+ }
55
+ describe("Reusable tests:", () => {
56
+ beforeEach(async () => {
57
+ adapter = await createAdapter();
58
+ });
59
+ describe("method: acquire", () => {
60
+ test("Should return true when key doesnt exists", async () => {
61
+ const key = "a";
62
+ const slotId = "b";
63
+ const limit = 2;
64
+ const ttl = null;
65
+ const result = await adapter.acquire({
66
+ key,
67
+ slotId,
68
+ limit,
69
+ ttl,
70
+ });
71
+ expect(result).toBe(true);
72
+ });
73
+ test("Should return true when key exists and slot is expired", async () => {
74
+ const key = "a";
75
+ const slotId = "b";
76
+ const limit = 2;
77
+ const ttl = TimeSpan.fromMilliseconds(50);
78
+ await adapter.acquire({
79
+ key,
80
+ slotId,
81
+ limit,
82
+ ttl,
83
+ });
84
+ await delay(ttl);
85
+ const result = await adapter.acquire({
86
+ key,
87
+ slotId,
88
+ limit,
89
+ ttl,
90
+ });
91
+ expect(result).toBe(true);
92
+ });
93
+ test("Should return true when limit is not reached", async () => {
94
+ const key = "a";
95
+ const limit = 2;
96
+ const ttl = null;
97
+ const slotId1 = "1";
98
+ await adapter.acquire({
99
+ key,
100
+ slotId: slotId1,
101
+ limit,
102
+ ttl,
103
+ });
104
+ const slotId2 = "2";
105
+ const result = await adapter.acquire({
106
+ key,
107
+ slotId: slotId2,
108
+ limit,
109
+ ttl,
110
+ });
111
+ expect(result).toBe(true);
112
+ });
113
+ test("Should return false when limit is reached", async () => {
114
+ const key = "a";
115
+ const limit = 2;
116
+ const ttl = null;
117
+ const slotId1 = "1";
118
+ await adapter.acquire({
119
+ key,
120
+ slotId: slotId1,
121
+ limit,
122
+ ttl,
123
+ });
124
+ const slotId2 = "2";
125
+ await adapter.acquire({
126
+ key,
127
+ slotId: slotId2,
128
+ limit,
129
+ ttl,
130
+ });
131
+ const slotId3 = "3";
132
+ const result = await adapter.acquire({
133
+ key,
134
+ slotId: slotId3,
135
+ limit,
136
+ ttl,
137
+ });
138
+ expect(result).toBe(false);
139
+ });
140
+ test("Should return true when one slot is expired", async () => {
141
+ const key = "a";
142
+ const limit = 2;
143
+ const slotId1 = "1";
144
+ const ttl1 = null;
145
+ await adapter.acquire({
146
+ key,
147
+ slotId: slotId1,
148
+ limit,
149
+ ttl: ttl1,
150
+ });
151
+ const slotId2 = "2";
152
+ const ttl2 = TimeSpan.fromMilliseconds(50);
153
+ await adapter.acquire({
154
+ key,
155
+ slotId: slotId2,
156
+ limit,
157
+ ttl: ttl2,
158
+ });
159
+ await delay(ttl2);
160
+ const slotId3 = "3";
161
+ const ttl3 = null;
162
+ const result = await adapter.acquire({
163
+ key,
164
+ slotId: slotId3,
165
+ limit,
166
+ ttl: ttl3,
167
+ });
168
+ expect(result).toBe(true);
169
+ });
170
+ test("Should return true when slot exists, is unexpireable and acquired multiple times", async () => {
171
+ const key = "a";
172
+ const slotId = "b";
173
+ const limit = 2;
174
+ const ttl = null;
175
+ await adapter.acquire({
176
+ key,
177
+ slotId,
178
+ limit,
179
+ ttl,
180
+ });
181
+ const result = await adapter.acquire({
182
+ key,
183
+ slotId,
184
+ limit,
185
+ ttl,
186
+ });
187
+ expect(result).toBe(true);
188
+ });
189
+ test("Should return true when slot exists, is unexpired and acquired multiple times", async () => {
190
+ const key = "a";
191
+ const slotId = "b";
192
+ const limit = 2;
193
+ const ttl = TimeSpan.fromMilliseconds(50);
194
+ await adapter.acquire({
195
+ key,
196
+ slotId,
197
+ limit,
198
+ ttl,
199
+ });
200
+ const result = await adapter.acquire({
201
+ key,
202
+ slotId,
203
+ limit,
204
+ ttl,
205
+ });
206
+ expect(result).toBe(true);
207
+ });
208
+ test("Should not acquire a slot when slot exists, is unexpireable and acquired multiple times", async () => {
209
+ const key = "a";
210
+ const limit = 2;
211
+ const ttl = null;
212
+ const slotId1 = "1";
213
+ await adapter.acquire({
214
+ key,
215
+ slotId: slotId1,
216
+ limit,
217
+ ttl,
218
+ });
219
+ await adapter.acquire({
220
+ key,
221
+ slotId: slotId1,
222
+ limit,
223
+ ttl,
224
+ });
225
+ const slotId2 = "2";
226
+ const result = await adapter.acquire({
227
+ key,
228
+ slotId: slotId2,
229
+ limit,
230
+ ttl,
231
+ });
232
+ expect(result).toBe(true);
233
+ });
234
+ test("Should not acquire a slot when slot exists, is unexpired and acquired multiple times", async () => {
235
+ const key = "a";
236
+ const limit = 2;
237
+ const ttl = TimeSpan.fromMilliseconds(50);
238
+ const slotId1 = "1";
239
+ await adapter.acquire({
240
+ key,
241
+ slotId: slotId1,
242
+ limit,
243
+ ttl,
244
+ });
245
+ await adapter.acquire({
246
+ key,
247
+ slotId: slotId1,
248
+ limit,
249
+ ttl,
250
+ });
251
+ const slotId2 = "2";
252
+ const result = await adapter.acquire({
253
+ key,
254
+ slotId: slotId2,
255
+ limit,
256
+ ttl,
257
+ });
258
+ expect(result).toBe(true);
259
+ });
260
+ test("Should not update limit when slot count is more than 0", async () => {
261
+ const key = "a";
262
+ const limit = 2;
263
+ const ttl = null;
264
+ const slotId1 = "1";
265
+ await adapter.acquire({
266
+ key,
267
+ slotId: slotId1,
268
+ limit,
269
+ ttl,
270
+ });
271
+ const slotId2 = "2";
272
+ const newLimit = 3;
273
+ await adapter.acquire({
274
+ key,
275
+ slotId: slotId2,
276
+ limit: newLimit,
277
+ ttl,
278
+ });
279
+ const slotId3 = "3";
280
+ const result1 = await adapter.getState(key);
281
+ expect(result1?.limit).toBe(limit);
282
+ const result2 = await adapter.acquire({
283
+ key,
284
+ slotId: slotId3,
285
+ limit: newLimit,
286
+ ttl,
287
+ });
288
+ expect(result2).toBe(false);
289
+ });
290
+ });
291
+ describe("method: release", () => {
292
+ test("Should return false when key doesnt exists", async () => {
293
+ const key = "a";
294
+ const slotId = "b";
295
+ const limit = 2;
296
+ const ttl = null;
297
+ await adapter.acquire({
298
+ key,
299
+ slotId,
300
+ limit,
301
+ ttl,
302
+ });
303
+ const noneExistingKey = "c";
304
+ const result = await adapter.release(noneExistingKey, slotId);
305
+ expect(result).toBe(false);
306
+ });
307
+ test("Should return false when slot doesnt exists", async () => {
308
+ const key = "a";
309
+ const ttl = null;
310
+ const limit = 2;
311
+ const slotId = "1";
312
+ await adapter.acquire({
313
+ key,
314
+ slotId,
315
+ ttl,
316
+ limit,
317
+ });
318
+ const noneExistingSlotId = "2";
319
+ const result = await adapter.release(key, noneExistingSlotId);
320
+ expect(result).toBe(false);
321
+ });
322
+ test("Should return false when slot is expired", async () => {
323
+ const key = "a";
324
+ const ttl = TimeSpan.fromMilliseconds(50);
325
+ const limit = 2;
326
+ const slotId1 = "1";
327
+ await adapter.acquire({
328
+ key,
329
+ slotId: slotId1,
330
+ ttl,
331
+ limit,
332
+ });
333
+ await delay(ttl);
334
+ const slotId2 = "2";
335
+ const result = await adapter.release(key, slotId2);
336
+ expect(result).toBe(false);
337
+ });
338
+ test("Should return false when slot exists, is expired", async () => {
339
+ const key = "a";
340
+ const slotId = "b";
341
+ const ttl = TimeSpan.fromMilliseconds(50);
342
+ const limit = 2;
343
+ await adapter.acquire({
344
+ key,
345
+ slotId,
346
+ ttl,
347
+ limit,
348
+ });
349
+ await delay(ttl);
350
+ const result = await adapter.release(key, slotId);
351
+ expect(result).toBe(false);
352
+ });
353
+ test("Should return true when slot exists, is unexpired", async () => {
354
+ const key = "a";
355
+ const slotId = "b";
356
+ const ttl = TimeSpan.fromMilliseconds(50);
357
+ const limit = 2;
358
+ await adapter.acquire({
359
+ key,
360
+ slotId,
361
+ ttl,
362
+ limit,
363
+ });
364
+ const result = await adapter.release(key, slotId);
365
+ expect(result).toBe(true);
366
+ });
367
+ test("Should return true when slot exists, is unexpireable", async () => {
368
+ const key = "a";
369
+ const slotId = "b";
370
+ const ttl = null;
371
+ const limit = 2;
372
+ await adapter.acquire({
373
+ key,
374
+ slotId,
375
+ ttl,
376
+ limit,
377
+ });
378
+ const result = await adapter.release(key, slotId);
379
+ expect(result).toBe(true);
380
+ });
381
+ test("Should update limit when slot count is 0", async () => {
382
+ const key = "a";
383
+ const limit = 2;
384
+ const ttl = null;
385
+ const slotId1 = "1";
386
+ await adapter.acquire({
387
+ key,
388
+ slotId: slotId1,
389
+ limit,
390
+ ttl,
391
+ });
392
+ const slotId2 = "2";
393
+ await adapter.acquire({
394
+ key,
395
+ slotId: slotId2,
396
+ limit,
397
+ ttl,
398
+ });
399
+ await adapter.release(key, slotId1);
400
+ await adapter.release(key, slotId2);
401
+ const newLimit = 3;
402
+ const slotId3 = "3";
403
+ await adapter.acquire({
404
+ key,
405
+ slotId: slotId3,
406
+ limit: newLimit,
407
+ ttl,
408
+ });
409
+ const result1 = await adapter.getState(key);
410
+ expect(result1?.limit).toBe(newLimit);
411
+ const slotId4 = "4";
412
+ await adapter.acquire({
413
+ key,
414
+ slotId: slotId4,
415
+ limit: newLimit,
416
+ ttl,
417
+ });
418
+ const slotId5 = "5";
419
+ const result2 = await adapter.acquire({
420
+ key,
421
+ slotId: slotId5,
422
+ limit: newLimit,
423
+ ttl,
424
+ });
425
+ expect(result2).toBe(true);
426
+ const slotId6 = "6";
427
+ const result3 = await adapter.acquire({
428
+ key,
429
+ slotId: slotId6,
430
+ limit,
431
+ ttl,
432
+ });
433
+ expect(result3).toBe(false);
434
+ });
435
+ test("Should decrement slot count when one slot is released", async () => {
436
+ const key = "a";
437
+ const limit = 2;
438
+ const ttl = null;
439
+ const slotId1 = "1";
440
+ await adapter.acquire({
441
+ key,
442
+ slotId: slotId1,
443
+ limit,
444
+ ttl,
445
+ });
446
+ const slotId2 = "2";
447
+ await adapter.acquire({
448
+ key,
449
+ slotId: slotId2,
450
+ limit,
451
+ ttl,
452
+ });
453
+ await adapter.release(key, slotId1);
454
+ const result1 = await adapter.getState(key);
455
+ expect(result1?.acquiredSlots.size).toBe(1);
456
+ await adapter.release(key, slotId2);
457
+ const slotId3 = "3";
458
+ const result2 = await adapter.acquire({
459
+ key,
460
+ slotId: slotId3,
461
+ limit,
462
+ ttl,
463
+ });
464
+ expect(result2).toBe(true);
465
+ const slotId4 = "4";
466
+ const result3 = await adapter.acquire({
467
+ key,
468
+ slotId: slotId4,
469
+ limit,
470
+ ttl,
471
+ });
472
+ expect(result3).toBe(true);
473
+ });
474
+ });
475
+ describe("method: forceReleaseAll", () => {
476
+ test("Should return false when key doesnt exists", async () => {
477
+ const key = "a";
478
+ const slotId = "b";
479
+ const limit = 2;
480
+ const ttl = null;
481
+ await adapter.acquire({
482
+ key,
483
+ slotId,
484
+ limit,
485
+ ttl,
486
+ });
487
+ const noneExistingKey = "c";
488
+ const result = await adapter.forceReleaseAll(noneExistingKey);
489
+ expect(result).toBe(false);
490
+ });
491
+ test("Should return false when slot is expired", async () => {
492
+ const key = "a";
493
+ const ttl = TimeSpan.fromMilliseconds(50);
494
+ const limit = 2;
495
+ const slotId = "1";
496
+ await adapter.acquire({
497
+ key,
498
+ slotId,
499
+ limit,
500
+ ttl,
501
+ });
502
+ await delay(ttl);
503
+ const result = await adapter.forceReleaseAll(key);
504
+ expect(result).toBe(false);
505
+ });
506
+ test("Should return false when no slots are acquired", async () => {
507
+ const key = "a";
508
+ const ttl = null;
509
+ const slotId1 = "1";
510
+ const limit = 2;
511
+ await adapter.acquire({
512
+ key,
513
+ slotId: slotId1,
514
+ limit,
515
+ ttl,
516
+ });
517
+ const slotId2 = "2";
518
+ await adapter.acquire({
519
+ key,
520
+ slotId: slotId2,
521
+ limit,
522
+ ttl,
523
+ });
524
+ await adapter.release(key, slotId1);
525
+ await adapter.release(key, slotId2);
526
+ const result = await adapter.forceReleaseAll(key);
527
+ expect(result).toBe(false);
528
+ });
529
+ test("Should return true when at least 1 slot is acquired", async () => {
530
+ const key = "a";
531
+ const ttl = null;
532
+ const limit = 2;
533
+ const slotId = "1";
534
+ await adapter.acquire({
535
+ key,
536
+ slotId,
537
+ limit,
538
+ ttl,
539
+ });
540
+ const result = await adapter.forceReleaseAll(key);
541
+ expect(result).toBe(true);
542
+ });
543
+ test("Should make all slots reacquirable", async () => {
544
+ const key = "a";
545
+ const limit = 2;
546
+ const slotId1 = "1";
547
+ const ttl1 = null;
548
+ await adapter.acquire({
549
+ key,
550
+ slotId: slotId1,
551
+ limit,
552
+ ttl: ttl1,
553
+ });
554
+ const slotId2 = "2";
555
+ const ttl2 = TimeSpan.fromMilliseconds(50);
556
+ await adapter.acquire({
557
+ key,
558
+ slotId: slotId2,
559
+ limit,
560
+ ttl: ttl2,
561
+ });
562
+ await adapter.forceReleaseAll(key);
563
+ const slotId3 = "3";
564
+ const ttl3 = null;
565
+ const result1 = await adapter.acquire({
566
+ key,
567
+ slotId: slotId3,
568
+ limit,
569
+ ttl: ttl3,
570
+ });
571
+ expect(result1).toBe(true);
572
+ const slotId4 = "4";
573
+ const ttl4 = null;
574
+ const result2 = await adapter.acquire({
575
+ key,
576
+ slotId: slotId4,
577
+ limit,
578
+ ttl: ttl4,
579
+ });
580
+ expect(result2).toBe(true);
581
+ });
582
+ test("Should update limit when slot count is 0", async () => {
583
+ const key = "a";
584
+ const limit = 2;
585
+ const ttl = null;
586
+ const slotId1 = "1";
587
+ await adapter.acquire({
588
+ key,
589
+ slotId: slotId1,
590
+ limit,
591
+ ttl,
592
+ });
593
+ const slotId2 = "2";
594
+ await adapter.acquire({
595
+ key,
596
+ slotId: slotId2,
597
+ limit,
598
+ ttl,
599
+ });
600
+ await adapter.forceReleaseAll(key);
601
+ const newLimit = 3;
602
+ const slotId3 = "3";
603
+ await adapter.acquire({
604
+ key,
605
+ slotId: slotId3,
606
+ limit: newLimit,
607
+ ttl,
608
+ });
609
+ const result1 = await adapter.getState(key);
610
+ expect(result1?.limit).toBe(newLimit);
611
+ const slotId4 = "4";
612
+ await adapter.acquire({
613
+ key,
614
+ slotId: slotId4,
615
+ limit: newLimit,
616
+ ttl,
617
+ });
618
+ const slotId5 = "5";
619
+ const result2 = await adapter.acquire({
620
+ key,
621
+ slotId: slotId5,
622
+ limit: newLimit,
623
+ ttl,
624
+ });
625
+ expect(result2).toBe(true);
626
+ const slotId6 = "6";
627
+ const result3 = await adapter.acquire({
628
+ key,
629
+ slotId: slotId6,
630
+ limit,
631
+ ttl,
632
+ });
633
+ expect(result3).toBe(false);
634
+ });
635
+ });
636
+ describe("method: refresh", () => {
637
+ test("Should return false when key doesnt exists", async () => {
638
+ const key = "a";
639
+ const slotId = "b";
640
+ const limit = 2;
641
+ const ttl = null;
642
+ await adapter.acquire({
643
+ key,
644
+ slotId,
645
+ limit,
646
+ ttl,
647
+ });
648
+ const newTtl = TimeSpan.fromMilliseconds(100);
649
+ const noneExistingKey = "c";
650
+ const result = await adapter.refresh(noneExistingKey, slotId, newTtl);
651
+ expect(result).toBe(false);
652
+ });
653
+ test("Should return false when slot doesnt exists", async () => {
654
+ const key = "a";
655
+ const ttl = null;
656
+ const limit = 2;
657
+ const slotId = "b";
658
+ await adapter.acquire({
659
+ key,
660
+ slotId,
661
+ ttl,
662
+ limit,
663
+ });
664
+ const noneExistingSlotId = "c";
665
+ const newTtl = TimeSpan.fromMilliseconds(100);
666
+ const result = await adapter.refresh(key, noneExistingSlotId, newTtl);
667
+ expect(result).toBe(false);
668
+ });
669
+ test("Should return false when slot is expired", async () => {
670
+ const key = "a";
671
+ const slotId = "b";
672
+ const limit = 2;
673
+ const ttl = TimeSpan.fromMilliseconds(50);
674
+ await adapter.acquire({
675
+ key,
676
+ slotId,
677
+ limit,
678
+ ttl,
679
+ });
680
+ await delay(ttl);
681
+ const newTtl = TimeSpan.fromMilliseconds(100);
682
+ const result = await adapter.refresh(key, slotId, newTtl);
683
+ expect(result).toBe(false);
684
+ });
685
+ test("Should return false when slot exists, is expired", async () => {
686
+ const key = "a";
687
+ const slotId = "b";
688
+ const ttl = TimeSpan.fromMilliseconds(50);
689
+ const limit = 2;
690
+ await adapter.acquire({
691
+ key,
692
+ slotId,
693
+ ttl,
694
+ limit,
695
+ });
696
+ await delay(ttl);
697
+ const newTtl = TimeSpan.fromMilliseconds(100);
698
+ const result = await adapter.refresh(key, slotId, newTtl);
699
+ expect(result).toBe(false);
700
+ });
701
+ test("Should return false when slot exists, is unexpireable", async () => {
702
+ const key = "a";
703
+ const slotId = "b";
704
+ const ttl = null;
705
+ const limit = 2;
706
+ await adapter.acquire({
707
+ key,
708
+ slotId,
709
+ ttl,
710
+ limit,
711
+ });
712
+ const newTtl = TimeSpan.fromMilliseconds(100);
713
+ const result = await adapter.refresh(key, slotId, newTtl);
714
+ expect(result).toBe(false);
715
+ });
716
+ test("Should return true when slot exists, is unexpired", async () => {
717
+ const key = "a";
718
+ const slotId = "b";
719
+ const ttl = TimeSpan.fromMilliseconds(50);
720
+ const limit = 2;
721
+ await adapter.acquire({
722
+ key,
723
+ slotId,
724
+ ttl,
725
+ limit,
726
+ });
727
+ const newTtl = TimeSpan.fromMilliseconds(100);
728
+ const result = await adapter.refresh(key, slotId, newTtl);
729
+ expect(result).toBe(true);
730
+ });
731
+ test("Should not update expiration when slot exists, is unexpireable", async () => {
732
+ const key = "a";
733
+ const limit = 2;
734
+ const ttl1 = null;
735
+ const slotId1 = "1";
736
+ await adapter.acquire({
737
+ key,
738
+ slotId: slotId1,
739
+ ttl: ttl1,
740
+ limit,
741
+ });
742
+ const ttl2 = null;
743
+ const slotId2 = "2";
744
+ await adapter.acquire({
745
+ key,
746
+ slotId: slotId2,
747
+ ttl: ttl2,
748
+ limit,
749
+ });
750
+ const newTtl = TimeSpan.fromMilliseconds(100);
751
+ await adapter.refresh(key, slotId2, newTtl);
752
+ await delay(newTtl);
753
+ const slotId3 = "3";
754
+ const result1 = await adapter.acquire({
755
+ key,
756
+ slotId: slotId3,
757
+ ttl: ttl2,
758
+ limit,
759
+ });
760
+ expect(result1).toBe(false);
761
+ });
762
+ test("Should update expiration when slot exists, is unexpired", async () => {
763
+ const key = "a";
764
+ const limit = 2;
765
+ const ttl1 = null;
766
+ const slotId1 = "1";
767
+ await adapter.acquire({
768
+ key,
769
+ slotId: slotId1,
770
+ ttl: ttl1,
771
+ limit,
772
+ });
773
+ const ttl2 = TimeSpan.fromMilliseconds(50);
774
+ const slotId2 = "2";
775
+ await adapter.acquire({
776
+ key,
777
+ slotId: slotId2,
778
+ ttl: ttl2,
779
+ limit,
780
+ });
781
+ const newTtl = TimeSpan.fromMilliseconds(100);
782
+ await adapter.refresh(key, slotId2, newTtl);
783
+ await delay(newTtl.divide(2));
784
+ const slotId3 = "3";
785
+ const result1 = await adapter.acquire({
786
+ key,
787
+ slotId: slotId3,
788
+ ttl: ttl2,
789
+ limit,
790
+ });
791
+ expect(result1).toBe(false);
792
+ await delay(newTtl.divide(2));
793
+ const result2 = await adapter.acquire({
794
+ key,
795
+ slotId: slotId3,
796
+ ttl: ttl2,
797
+ limit,
798
+ });
799
+ expect(result2).toBe(true);
800
+ });
801
+ });
802
+ describe("method: getState", () => {
803
+ test("Should return null when key doesnt exists", async () => {
804
+ const key = "a";
805
+ const result = await adapter.getState(key);
806
+ expect(result).toBeNull();
807
+ });
808
+ test("Should return null when key is expired", async () => {
809
+ const key = "a";
810
+ const slotId = "b";
811
+ const ttl = TimeSpan.fromMilliseconds(50);
812
+ const limit = 2;
813
+ await adapter.acquire({
814
+ key,
815
+ limit,
816
+ slotId,
817
+ ttl,
818
+ });
819
+ await delay(ttl);
820
+ const result = await adapter.getState(key);
821
+ expect(result).toBeNull();
822
+ });
823
+ test("Should return null when all slots are released with forceRelease method", async () => {
824
+ const key = "a";
825
+ const limit = 2;
826
+ const ttl1 = null;
827
+ const slotId1 = "1";
828
+ await adapter.acquire({
829
+ key,
830
+ limit,
831
+ slotId: slotId1,
832
+ ttl: ttl1,
833
+ });
834
+ const ttl2 = null;
835
+ const slotId2 = "1";
836
+ await adapter.acquire({
837
+ key,
838
+ limit,
839
+ slotId: slotId2,
840
+ ttl: ttl2,
841
+ });
842
+ await adapter.forceReleaseAll(key);
843
+ const result = await adapter.getState(key);
844
+ expect(result).toBeNull();
845
+ });
846
+ test("Should return null when all slots are released with release method", async () => {
847
+ const key = "a";
848
+ const limit = 2;
849
+ const ttl1 = null;
850
+ const slotId1 = "1";
851
+ await adapter.acquire({
852
+ key,
853
+ limit,
854
+ slotId: slotId1,
855
+ ttl: ttl1,
856
+ });
857
+ const ttl2 = null;
858
+ const slotId2 = "1";
859
+ await adapter.acquire({
860
+ key,
861
+ limit,
862
+ slotId: slotId2,
863
+ ttl: ttl2,
864
+ });
865
+ await adapter.release(key, slotId1);
866
+ await adapter.release(key, slotId2);
867
+ const result = await adapter.getState(key);
868
+ expect(result).toBeNull();
869
+ });
870
+ test("Should return limit when key exists", async () => {
871
+ const key = "a";
872
+ const limit = 3;
873
+ const slotId = "1";
874
+ const ttl = null;
875
+ await adapter.acquire({
876
+ key,
877
+ limit,
878
+ slotId,
879
+ ttl,
880
+ });
881
+ const state = await adapter.getState(key);
882
+ expect(state?.limit).toBe(limit);
883
+ });
884
+ test("Should return slot count when key exists", async () => {
885
+ const key = "a";
886
+ const limit = 3;
887
+ const slotId1 = "1";
888
+ const ttl1 = null;
889
+ await adapter.acquire({
890
+ key,
891
+ limit,
892
+ slotId: slotId1,
893
+ ttl: ttl1,
894
+ });
895
+ const slotId2 = "2";
896
+ const ttl2 = TimeSpan.fromMilliseconds(50);
897
+ await adapter.acquire({
898
+ key,
899
+ limit,
900
+ slotId: slotId2,
901
+ ttl: ttl2,
902
+ });
903
+ const state = await adapter.getState(key);
904
+ expect(state?.acquiredSlots.size).toBe(2);
905
+ });
906
+ test("Should return slot when key exists, slot exists and slot is unexpired", async () => {
907
+ const key = "a";
908
+ const limit = 3;
909
+ const slotId = "a";
910
+ const ttl = null;
911
+ await adapter.acquire({
912
+ key,
913
+ limit,
914
+ slotId,
915
+ ttl: ttl,
916
+ });
917
+ const state = await adapter.getState(key);
918
+ expect({
919
+ ...state,
920
+ acquiredSlots: Object.fromEntries(state?.acquiredSlots ?? []),
921
+ }).toEqual({
922
+ limit,
923
+ acquiredSlots: {
924
+ [slotId]: ttl,
925
+ },
926
+ });
927
+ });
928
+ test("Should return slot when key exists, slot exists and slot is unexpireable", async () => {
929
+ const key = "a";
930
+ const limit = 3;
931
+ const slotId = "a";
932
+ const ttl = TimeSpan.fromMinutes(5);
933
+ let expiration;
934
+ try {
935
+ vi.useFakeTimers();
936
+ expiration = ttl.toEndDate();
937
+ await adapter.acquire({
938
+ key,
939
+ limit,
940
+ slotId,
941
+ ttl: ttl,
942
+ });
943
+ }
944
+ finally {
945
+ vi.useRealTimers();
946
+ }
947
+ const state = await adapter.getState(key);
948
+ expect({
949
+ ...state,
950
+ acquiredSlots: Object.fromEntries(state?.acquiredSlots ?? []),
951
+ }).toEqual({
952
+ limit,
953
+ acquiredSlots: {
954
+ [slotId]: expiration,
955
+ },
956
+ });
957
+ });
958
+ });
959
+ });
960
+ }
961
+ //# sourceMappingURL=semaphore-adapter.test-suite.js.map