@daiso-tech/core 0.23.0 → 0.25.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 (1838) hide show
  1. package/README.md +4 -1
  2. package/dist/async/_module-exports.d.ts +3 -0
  3. package/dist/async/_module-exports.js +4 -0
  4. package/dist/async/_module-exports.js.map +1 -0
  5. package/dist/async/async.errors.d.ts +45 -0
  6. package/dist/async/async.errors.js +50 -0
  7. package/dist/async/async.errors.js.map +1 -0
  8. package/dist/async/backof-policies/_module.d.ts +5 -0
  9. package/dist/async/backof-policies/_module.js +6 -0
  10. package/dist/async/backof-policies/_module.js.map +1 -0
  11. package/dist/async/backof-policies/_shared.d.ts +14 -0
  12. package/dist/async/backof-policies/_shared.js +10 -0
  13. package/dist/async/backof-policies/_shared.js.map +1 -0
  14. package/dist/async/backof-policies/constant-backoff-policy/_module.d.ts +1 -0
  15. package/dist/async/backof-policies/constant-backoff-policy/_module.js +2 -0
  16. package/dist/async/backof-policies/constant-backoff-policy/_module.js.map +1 -0
  17. package/dist/async/backof-policies/constant-backoff-policy/constant-backoff-policy.d.ts +32 -0
  18. package/dist/async/backof-policies/constant-backoff-policy/constant-backoff-policy.js +25 -0
  19. package/dist/async/backof-policies/constant-backoff-policy/constant-backoff-policy.js.map +1 -0
  20. package/dist/async/backof-policies/exponential-backoff-policy/_module.d.ts +1 -0
  21. package/dist/async/backof-policies/exponential-backoff-policy/_module.js +2 -0
  22. package/dist/async/backof-policies/exponential-backoff-policy/_module.js.map +1 -0
  23. package/dist/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.d.ts +40 -0
  24. package/dist/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js +29 -0
  25. package/dist/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js.map +1 -0
  26. package/dist/async/backof-policies/linear-backoff-policy/_module.d.ts +1 -0
  27. package/dist/async/backof-policies/linear-backoff-policy/_module.js +2 -0
  28. package/dist/async/backof-policies/linear-backoff-policy/_module.js.map +1 -0
  29. package/dist/async/backof-policies/linear-backoff-policy/linear-backoff-policy.d.ts +36 -0
  30. package/dist/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js +29 -0
  31. package/dist/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js.map +1 -0
  32. package/dist/async/backof-policies/polynomial-backoff-policy/_module.d.ts +1 -0
  33. package/dist/async/backof-policies/polynomial-backoff-policy/_module.js +2 -0
  34. package/dist/async/backof-policies/polynomial-backoff-policy/_module.js.map +1 -0
  35. package/dist/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.d.ts +40 -0
  36. package/dist/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js +29 -0
  37. package/dist/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js.map +1 -0
  38. package/dist/async/utilities/_module.d.ts +5 -0
  39. package/dist/async/utilities/_module.js +6 -0
  40. package/dist/async/utilities/_module.js.map +1 -0
  41. package/dist/async/utilities/abort/_module.d.ts +2 -0
  42. package/dist/async/utilities/abort/_module.js +3 -0
  43. package/dist/async/utilities/abort/_module.js.map +1 -0
  44. package/dist/async/utilities/abort/abort-and-fail.js +51 -0
  45. package/dist/async/utilities/abort/abort-and-fail.js.map +1 -0
  46. package/dist/async/utilities/abort/abort.d.ts +9 -0
  47. package/dist/async/utilities/abort/abort.js +18 -0
  48. package/dist/async/utilities/abort/abort.js.map +1 -0
  49. package/dist/async/utilities/delay/_module.d.ts +1 -0
  50. package/dist/async/utilities/delay/_module.js +2 -0
  51. package/dist/async/utilities/delay/_module.js.map +1 -0
  52. package/dist/async/utilities/delay/delay.d.ts +21 -0
  53. package/dist/async/utilities/delay/delay.js +45 -0
  54. package/dist/async/utilities/delay/delay.js.map +1 -0
  55. package/dist/async/utilities/lazy-promise/_module.d.ts +1 -0
  56. package/dist/async/utilities/lazy-promise/_module.js +2 -0
  57. package/dist/async/utilities/lazy-promise/_module.js.map +1 -0
  58. package/dist/async/utilities/lazy-promise/lazy-promise.d.ts +214 -0
  59. package/dist/async/utilities/lazy-promise/lazy-promise.js +301 -0
  60. package/dist/async/utilities/lazy-promise/lazy-promise.js.map +1 -0
  61. package/dist/async/utilities/retry/_module.d.ts +2 -0
  62. package/dist/async/utilities/retry/_module.js +3 -0
  63. package/dist/async/utilities/retry/_module.js.map +1 -0
  64. package/dist/async/utilities/retry/retry-or-fail.d.ts +27 -0
  65. package/dist/async/utilities/retry/retry-or-fail.js +39 -0
  66. package/dist/async/utilities/retry/retry-or-fail.js.map +1 -0
  67. package/dist/async/utilities/retry/retry.d.ts +10 -0
  68. package/dist/async/utilities/retry/retry.js +21 -0
  69. package/dist/async/utilities/retry/retry.js.map +1 -0
  70. package/dist/async/utilities/timeout/_module.d.ts +2 -0
  71. package/dist/async/utilities/timeout/_module.js +3 -0
  72. package/dist/async/utilities/timeout/_module.js.map +1 -0
  73. package/dist/async/utilities/timeout/timeout-and-fail.d.ts +5 -0
  74. package/dist/async/utilities/timeout/timeout-and-fail.js +28 -0
  75. package/dist/async/utilities/timeout/timeout-and-fail.js.map +1 -0
  76. package/dist/async/utilities/timeout/timeout.d.ts +10 -0
  77. package/dist/async/utilities/timeout/timeout.js +21 -0
  78. package/dist/async/utilities/timeout/timeout.js.map +1 -0
  79. package/dist/cache/contracts/_module-exports.d.ts +5 -0
  80. package/dist/cache/contracts/_module-exports.js +6 -0
  81. package/dist/cache/contracts/_module-exports.js.map +1 -0
  82. package/dist/cache/contracts/cache-adapter.contract.d.ts +56 -0
  83. package/dist/cache/contracts/cache-adapter.contract.js +5 -0
  84. package/dist/cache/contracts/cache-adapter.contract.js.map +1 -0
  85. package/dist/cache/contracts/cache-factory.contract.d.ts +19 -0
  86. package/dist/cache/contracts/cache-factory.contract.js +9 -0
  87. package/dist/cache/contracts/cache-factory.contract.js.map +1 -0
  88. package/dist/cache/contracts/cache.contract.d.ts +156 -0
  89. package/dist/cache/contracts/cache.contract.js +6 -0
  90. package/dist/cache/contracts/cache.contract.js.map +1 -0
  91. package/dist/cache/contracts/cache.errors.d.ts +49 -0
  92. package/dist/cache/contracts/cache.errors.js +86 -0
  93. package/dist/cache/contracts/cache.errors.js.map +1 -0
  94. package/dist/cache/contracts/cache.events.d.ts +117 -0
  95. package/dist/cache/contracts/cache.events.js +92 -0
  96. package/dist/cache/contracts/cache.events.js.map +1 -0
  97. package/dist/cache/implementations/adapters/_module-exports.d.ts +6 -0
  98. package/dist/cache/implementations/adapters/_module-exports.js +7 -0
  99. package/dist/cache/implementations/adapters/_module-exports.js.map +1 -0
  100. package/dist/cache/implementations/adapters/kysely-sqlite-cache-adapter/_module.d.ts +1 -0
  101. package/dist/cache/implementations/adapters/kysely-sqlite-cache-adapter/_module.js +2 -0
  102. package/dist/cache/implementations/adapters/kysely-sqlite-cache-adapter/_module.js.map +1 -0
  103. package/dist/cache/implementations/adapters/kysely-sqlite-cache-adapter/kysely-sqlite-cache-adapter.d.ts +61 -0
  104. package/dist/cache/implementations/adapters/kysely-sqlite-cache-adapter/kysely-sqlite-cache-adapter.js +318 -0
  105. package/dist/cache/implementations/adapters/kysely-sqlite-cache-adapter/kysely-sqlite-cache-adapter.js.map +1 -0
  106. package/dist/cache/implementations/adapters/libsql-cache-adapter/_module.d.ts +1 -0
  107. package/dist/cache/implementations/adapters/libsql-cache-adapter/_module.js +2 -0
  108. package/dist/cache/implementations/adapters/libsql-cache-adapter/_module.js.map +1 -0
  109. package/dist/cache/implementations/adapters/libsql-cache-adapter/libsql-cache-adapter.d.ts +71 -0
  110. package/dist/cache/implementations/adapters/libsql-cache-adapter/libsql-cache-adapter.js +104 -0
  111. package/dist/cache/implementations/adapters/libsql-cache-adapter/libsql-cache-adapter.js.map +1 -0
  112. package/dist/cache/implementations/adapters/memory-cache-adapter/_module.d.ts +1 -0
  113. package/dist/cache/implementations/adapters/memory-cache-adapter/_module.js +2 -0
  114. package/dist/cache/implementations/adapters/memory-cache-adapter/_module.js.map +1 -0
  115. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.d.ts +58 -0
  116. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js +119 -0
  117. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js.map +1 -0
  118. package/dist/cache/implementations/adapters/mongodb-cache-adapter/_module.d.ts +1 -0
  119. package/dist/cache/implementations/adapters/mongodb-cache-adapter/_module.js +2 -0
  120. package/dist/cache/implementations/adapters/mongodb-cache-adapter/_module.js.map +1 -0
  121. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.d.ts +77 -0
  122. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js +325 -0
  123. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js.map +1 -0
  124. package/dist/cache/implementations/adapters/no-op-cache-adapter/_module.d.ts +1 -0
  125. package/dist/cache/implementations/adapters/no-op-cache-adapter/_module.js +2 -0
  126. package/dist/cache/implementations/adapters/no-op-cache-adapter/_module.js.map +1 -0
  127. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.d.ts +22 -0
  128. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js +39 -0
  129. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js.map +1 -0
  130. package/dist/cache/implementations/adapters/redis-cache-adapter/_module.d.ts +1 -0
  131. package/dist/cache/implementations/adapters/redis-cache-adapter/_module.js +2 -0
  132. package/dist/cache/implementations/adapters/redis-cache-adapter/_module.js.map +1 -0
  133. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.d.ts +65 -0
  134. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js +205 -0
  135. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js.map +1 -0
  136. package/dist/cache/implementations/adapters/sqlite-cache-adapter/_module.d.ts +1 -0
  137. package/dist/cache/implementations/adapters/sqlite-cache-adapter/_module.js +2 -0
  138. package/dist/cache/implementations/adapters/sqlite-cache-adapter/_module.js.map +1 -0
  139. package/dist/cache/implementations/adapters/sqlite-cache-adapter/sqlite-cache-adapter.d.ts +71 -0
  140. package/dist/cache/implementations/adapters/sqlite-cache-adapter/sqlite-cache-adapter.js +103 -0
  141. package/dist/cache/implementations/adapters/sqlite-cache-adapter/sqlite-cache-adapter.js.map +1 -0
  142. package/dist/cache/implementations/derivables/_module-exports.d.ts +2 -0
  143. package/dist/cache/implementations/derivables/_module-exports.js +3 -0
  144. package/dist/cache/implementations/derivables/_module-exports.js.map +1 -0
  145. package/dist/cache/implementations/derivables/cache/_module.d.ts +1 -0
  146. package/dist/cache/implementations/derivables/cache/_module.js +2 -0
  147. package/dist/cache/implementations/derivables/cache/_module.js.map +1 -0
  148. package/dist/cache/implementations/derivables/cache/cache.d.ts +650 -0
  149. package/dist/cache/implementations/derivables/cache/cache.js +1109 -0
  150. package/dist/cache/implementations/derivables/cache/cache.js.map +1 -0
  151. package/dist/cache/implementations/derivables/cache-factory/_module.d.ts +1 -0
  152. package/dist/cache/implementations/derivables/cache-factory/_module.js +2 -0
  153. package/dist/cache/implementations/derivables/cache-factory/_module.js.map +1 -0
  154. package/dist/cache/implementations/derivables/cache-factory/cache-factory.d.ts +156 -0
  155. package/dist/cache/implementations/derivables/cache-factory/cache-factory.js +133 -0
  156. package/dist/cache/implementations/derivables/cache-factory/cache-factory.js.map +1 -0
  157. package/dist/cache/implementations/test-utilities/_module-exports.d.ts +2 -0
  158. package/dist/cache/implementations/test-utilities/_module-exports.js +3 -0
  159. package/dist/cache/implementations/test-utilities/_module-exports.js.map +1 -0
  160. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.d.ts +66 -0
  161. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js +302 -0
  162. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js.map +1 -0
  163. package/dist/cache/implementations/test-utilities/cache.test-suite.d.ts +61 -0
  164. package/dist/cache/implementations/test-utilities/cache.test-suite.js +1784 -0
  165. package/dist/cache/implementations/test-utilities/cache.test-suite.js.map +1 -0
  166. package/dist/collection/contracts/_module-exports.d.ts +4 -0
  167. package/dist/collection/contracts/_module-exports.js +5 -0
  168. package/dist/collection/contracts/_module-exports.js.map +1 -0
  169. package/dist/collection/contracts/_shared.d.ts +141 -0
  170. package/dist/collection/contracts/_shared.js +5 -0
  171. package/dist/collection/contracts/_shared.js.map +1 -0
  172. package/dist/collection/contracts/async-collection.contract.d.ts +2186 -0
  173. package/dist/collection/contracts/async-collection.contract.js +16 -0
  174. package/dist/collection/contracts/async-collection.contract.js.map +1 -0
  175. package/dist/collection/contracts/collection.contract.d.ts +2051 -0
  176. package/dist/collection/contracts/collection.contract.js +5 -0
  177. package/dist/collection/contracts/collection.contract.js.map +1 -0
  178. package/dist/collection/contracts/collection.errors.d.ts +67 -0
  179. package/dist/collection/contracts/collection.errors.js +116 -0
  180. package/dist/collection/contracts/collection.errors.js.map +1 -0
  181. package/dist/collection/implementations/_module-exports.d.ts +4 -0
  182. package/dist/collection/implementations/_module-exports.js +5 -0
  183. package/dist/collection/implementations/_module-exports.js.map +1 -0
  184. package/dist/collection/implementations/_shared.d.ts +39 -0
  185. package/dist/collection/implementations/_shared.js +79 -0
  186. package/dist/collection/implementations/_shared.js.map +1 -0
  187. package/dist/collection/implementations/async-iterable-collection/_module.d.ts +1 -0
  188. package/dist/collection/implementations/async-iterable-collection/_module.js +2 -0
  189. package/dist/collection/implementations/async-iterable-collection/_module.js.map +1 -0
  190. package/dist/collection/implementations/async-iterable-collection/_shared/_module.d.ts +36 -0
  191. package/dist/collection/implementations/async-iterable-collection/_shared/_module.js +37 -0
  192. package/dist/collection/implementations/async-iterable-collection/_shared/_module.js.map +1 -0
  193. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.d.ts +15 -0
  194. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.js +39 -0
  195. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.js.map +1 -0
  196. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.d.ts +15 -0
  197. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.js +36 -0
  198. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.js.map +1 -0
  199. package/dist/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.d.ts +12 -0
  200. package/dist/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.js +26 -0
  201. package/dist/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.js.map +1 -0
  202. package/dist/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.d.ts +13 -0
  203. package/dist/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.js +30 -0
  204. package/dist/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.js.map +1 -0
  205. package/dist/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.d.ts +16 -0
  206. package/dist/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.js +40 -0
  207. package/dist/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.js.map +1 -0
  208. package/dist/collection/implementations/async-iterable-collection/_shared/async-delay-iterable.d.ts +13 -0
  209. package/dist/collection/implementations/async-iterable-collection/_shared/async-delay-iterable.js +30 -0
  210. package/dist/collection/implementations/async-iterable-collection/_shared/async-delay-iterable.js.map +1 -0
  211. package/dist/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.d.ts +12 -0
  212. package/dist/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.js +21 -0
  213. package/dist/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.js.map +1 -0
  214. package/dist/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.d.ts +13 -0
  215. package/dist/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.js +23 -0
  216. package/dist/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.js.map +1 -0
  217. package/dist/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.d.ts +13 -0
  218. package/dist/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.js +21 -0
  219. package/dist/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.js.map +1 -0
  220. package/dist/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.d.ts +18 -0
  221. package/dist/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.js +33 -0
  222. package/dist/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.js.map +1 -0
  223. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.d.ts +15 -0
  224. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.js +31 -0
  225. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.js.map +1 -0
  226. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.d.ts +15 -0
  227. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.js +31 -0
  228. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.js.map +1 -0
  229. package/dist/collection/implementations/async-iterable-collection/_shared/async-map-iterable.d.ts +13 -0
  230. package/dist/collection/implementations/async-iterable-collection/_shared/async-map-iterable.js +21 -0
  231. package/dist/collection/implementations/async-iterable-collection/_shared/async-map-iterable.js.map +1 -0
  232. package/dist/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.d.ts +12 -0
  233. package/dist/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.js +27 -0
  234. package/dist/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.js.map +1 -0
  235. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.d.ts +16 -0
  236. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.js +35 -0
  237. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.js.map +1 -0
  238. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.d.ts +16 -0
  239. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.js +35 -0
  240. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.js.map +1 -0
  241. package/dist/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.d.ts +15 -0
  242. package/dist/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.js +33 -0
  243. package/dist/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.js.map +1 -0
  244. package/dist/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.d.ts +15 -0
  245. package/dist/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.js +26 -0
  246. package/dist/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.js.map +1 -0
  247. package/dist/collection/implementations/async-iterable-collection/_shared/async-retry-iterable.d.ts +13 -0
  248. package/dist/collection/implementations/async-iterable-collection/_shared/async-retry-iterable.js +36 -0
  249. package/dist/collection/implementations/async-iterable-collection/_shared/async-retry-iterable.js.map +1 -0
  250. package/dist/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.d.ts +15 -0
  251. package/dist/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.js +25 -0
  252. package/dist/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.js.map +1 -0
  253. package/dist/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.d.ts +13 -0
  254. package/dist/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.js +30 -0
  255. package/dist/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.js.map +1 -0
  256. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.d.ts +13 -0
  257. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.js +22 -0
  258. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.js.map +1 -0
  259. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.d.ts +13 -0
  260. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.js +28 -0
  261. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.js.map +1 -0
  262. package/dist/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.d.ts +14 -0
  263. package/dist/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.js +37 -0
  264. package/dist/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.js.map +1 -0
  265. package/dist/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.d.ts +14 -0
  266. package/dist/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.js +32 -0
  267. package/dist/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.js.map +1 -0
  268. package/dist/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.d.ts +13 -0
  269. package/dist/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.js +19 -0
  270. package/dist/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.js.map +1 -0
  271. package/dist/collection/implementations/async-iterable-collection/_shared/async-split-iterable.d.ts +15 -0
  272. package/dist/collection/implementations/async-iterable-collection/_shared/async-split-iterable.js +42 -0
  273. package/dist/collection/implementations/async-iterable-collection/_shared/async-split-iterable.js.map +1 -0
  274. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-iterable.d.ts +13 -0
  275. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-iterable.js +22 -0
  276. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-iterable.js.map +1 -0
  277. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-abort-iterable.js +39 -0
  278. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-abort-iterable.js.map +1 -0
  279. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.d.ts +13 -0
  280. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.js +24 -0
  281. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.js.map +1 -0
  282. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-timeout-iterable.d.ts +13 -0
  283. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-timeout-iterable.js +52 -0
  284. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-timeout-iterable.js.map +1 -0
  285. package/dist/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.d.ts +13 -0
  286. package/dist/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.js +20 -0
  287. package/dist/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.js.map +1 -0
  288. package/dist/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.d.ts +13 -0
  289. package/dist/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.js +26 -0
  290. package/dist/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.js.map +1 -0
  291. package/dist/collection/implementations/async-iterable-collection/_shared/async-update-iterable.d.ts +14 -0
  292. package/dist/collection/implementations/async-iterable-collection/_shared/async-update-iterable.js +28 -0
  293. package/dist/collection/implementations/async-iterable-collection/_shared/async-update-iterable.js.map +1 -0
  294. package/dist/collection/implementations/async-iterable-collection/_shared/async-when-iterable.d.ts +14 -0
  295. package/dist/collection/implementations/async-iterable-collection/_shared/async-when-iterable.js +25 -0
  296. package/dist/collection/implementations/async-iterable-collection/_shared/async-when-iterable.js.map +1 -0
  297. package/dist/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.d.ts +13 -0
  298. package/dist/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.js +41 -0
  299. package/dist/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.js.map +1 -0
  300. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.d.ts +305 -0
  301. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.js +804 -0
  302. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.js.map +1 -0
  303. package/dist/collection/implementations/iterable-collection/_module.d.ts +1 -0
  304. package/dist/collection/implementations/iterable-collection/_module.js +2 -0
  305. package/dist/collection/implementations/iterable-collection/_module.js.map +1 -0
  306. package/dist/collection/implementations/iterable-collection/_shared/_module.d.ts +32 -0
  307. package/dist/collection/implementations/iterable-collection/_shared/_module.js +33 -0
  308. package/dist/collection/implementations/iterable-collection/_shared/_module.js.map +1 -0
  309. package/dist/collection/implementations/iterable-collection/_shared/chunk-iterable.d.ts +14 -0
  310. package/dist/collection/implementations/iterable-collection/_shared/chunk-iterable.js +38 -0
  311. package/dist/collection/implementations/iterable-collection/_shared/chunk-iterable.js.map +1 -0
  312. package/dist/collection/implementations/iterable-collection/_shared/chunk-while-iterable.d.ts +14 -0
  313. package/dist/collection/implementations/iterable-collection/_shared/chunk-while-iterable.js +35 -0
  314. package/dist/collection/implementations/iterable-collection/_shared/chunk-while-iterable.js.map +1 -0
  315. package/dist/collection/implementations/iterable-collection/_shared/collapse-iterable.d.ts +12 -0
  316. package/dist/collection/implementations/iterable-collection/_shared/collapse-iterable.js +26 -0
  317. package/dist/collection/implementations/iterable-collection/_shared/collapse-iterable.js.map +1 -0
  318. package/dist/collection/implementations/iterable-collection/_shared/count-by-iterable.d.ts +13 -0
  319. package/dist/collection/implementations/iterable-collection/_shared/count-by-iterable.js +30 -0
  320. package/dist/collection/implementations/iterable-collection/_shared/count-by-iterable.js.map +1 -0
  321. package/dist/collection/implementations/iterable-collection/_shared/cross-join-iterable.d.ts +14 -0
  322. package/dist/collection/implementations/iterable-collection/_shared/cross-join-iterable.js +40 -0
  323. package/dist/collection/implementations/iterable-collection/_shared/cross-join-iterable.js.map +1 -0
  324. package/dist/collection/implementations/iterable-collection/_shared/entries-iterable.js +20 -0
  325. package/dist/collection/implementations/iterable-collection/_shared/entries-iterable.js.map +1 -0
  326. package/dist/collection/implementations/iterable-collection/_shared/filter-iterable.d.ts +13 -0
  327. package/dist/collection/implementations/iterable-collection/_shared/filter-iterable.js +23 -0
  328. package/dist/collection/implementations/iterable-collection/_shared/filter-iterable.js.map +1 -0
  329. package/dist/collection/implementations/iterable-collection/_shared/flat-map-iterable.d.ts +13 -0
  330. package/dist/collection/implementations/iterable-collection/_shared/flat-map-iterable.js +21 -0
  331. package/dist/collection/implementations/iterable-collection/_shared/flat-map-iterable.js.map +1 -0
  332. package/dist/collection/implementations/iterable-collection/_shared/group-by-iterable.d.ts +14 -0
  333. package/dist/collection/implementations/iterable-collection/_shared/group-by-iterable.js +32 -0
  334. package/dist/collection/implementations/iterable-collection/_shared/group-by-iterable.js.map +1 -0
  335. package/dist/collection/implementations/iterable-collection/_shared/insert-after-iterable.d.ts +14 -0
  336. package/dist/collection/implementations/iterable-collection/_shared/insert-after-iterable.js +28 -0
  337. package/dist/collection/implementations/iterable-collection/_shared/insert-after-iterable.js.map +1 -0
  338. package/dist/collection/implementations/iterable-collection/_shared/insert-before-iterable.d.ts +14 -0
  339. package/dist/collection/implementations/iterable-collection/_shared/insert-before-iterable.js +28 -0
  340. package/dist/collection/implementations/iterable-collection/_shared/insert-before-iterable.js.map +1 -0
  341. package/dist/collection/implementations/iterable-collection/_shared/map-iterable.d.ts +13 -0
  342. package/dist/collection/implementations/iterable-collection/_shared/map-iterable.js +21 -0
  343. package/dist/collection/implementations/iterable-collection/_shared/map-iterable.js.map +1 -0
  344. package/dist/collection/implementations/iterable-collection/_shared/merge-iterable.js +18 -0
  345. package/dist/collection/implementations/iterable-collection/_shared/merge-iterable.js.map +1 -0
  346. package/dist/collection/implementations/iterable-collection/_shared/pad-end-iterable.d.ts +15 -0
  347. package/dist/collection/implementations/iterable-collection/_shared/pad-end-iterable.js +34 -0
  348. package/dist/collection/implementations/iterable-collection/_shared/pad-end-iterable.js.map +1 -0
  349. package/dist/collection/implementations/iterable-collection/_shared/pad-start-iterable.d.ts +15 -0
  350. package/dist/collection/implementations/iterable-collection/_shared/pad-start-iterable.js +34 -0
  351. package/dist/collection/implementations/iterable-collection/_shared/pad-start-iterable.js.map +1 -0
  352. package/dist/collection/implementations/iterable-collection/_shared/partion-iterable.d.ts +14 -0
  353. package/dist/collection/implementations/iterable-collection/_shared/partion-iterable.js +32 -0
  354. package/dist/collection/implementations/iterable-collection/_shared/partion-iterable.js.map +1 -0
  355. package/dist/collection/implementations/iterable-collection/_shared/repeat-iterable.d.ts +14 -0
  356. package/dist/collection/implementations/iterable-collection/_shared/repeat-iterable.js +25 -0
  357. package/dist/collection/implementations/iterable-collection/_shared/repeat-iterable.js.map +1 -0
  358. package/dist/collection/implementations/iterable-collection/_shared/reverse-iterable.d.ts +14 -0
  359. package/dist/collection/implementations/iterable-collection/_shared/reverse-iterable.js +24 -0
  360. package/dist/collection/implementations/iterable-collection/_shared/reverse-iterable.js.map +1 -0
  361. package/dist/collection/implementations/iterable-collection/_shared/shuffle-iterable.js +29 -0
  362. package/dist/collection/implementations/iterable-collection/_shared/shuffle-iterable.js.map +1 -0
  363. package/dist/collection/implementations/iterable-collection/_shared/skip-iterable.d.ts +13 -0
  364. package/dist/collection/implementations/iterable-collection/_shared/skip-iterable.js +22 -0
  365. package/dist/collection/implementations/iterable-collection/_shared/skip-iterable.js.map +1 -0
  366. package/dist/collection/implementations/iterable-collection/_shared/skip-until-iterable.d.ts +13 -0
  367. package/dist/collection/implementations/iterable-collection/_shared/skip-until-iterable.js +27 -0
  368. package/dist/collection/implementations/iterable-collection/_shared/skip-until-iterable.js.map +1 -0
  369. package/dist/collection/implementations/iterable-collection/_shared/slice-iterable.d.ts +14 -0
  370. package/dist/collection/implementations/iterable-collection/_shared/slice-iterable.js +37 -0
  371. package/dist/collection/implementations/iterable-collection/_shared/slice-iterable.js.map +1 -0
  372. package/dist/collection/implementations/iterable-collection/_shared/sliding-iterable.d.ts +14 -0
  373. package/dist/collection/implementations/iterable-collection/_shared/sliding-iterable.js +32 -0
  374. package/dist/collection/implementations/iterable-collection/_shared/sliding-iterable.js.map +1 -0
  375. package/dist/collection/implementations/iterable-collection/_shared/sort-iterable.d.ts +13 -0
  376. package/dist/collection/implementations/iterable-collection/_shared/sort-iterable.js +19 -0
  377. package/dist/collection/implementations/iterable-collection/_shared/sort-iterable.js.map +1 -0
  378. package/dist/collection/implementations/iterable-collection/_shared/split-iterable.d.ts +14 -0
  379. package/dist/collection/implementations/iterable-collection/_shared/split-iterable.js +41 -0
  380. package/dist/collection/implementations/iterable-collection/_shared/split-iterable.js.map +1 -0
  381. package/dist/collection/implementations/iterable-collection/_shared/take-iterable.d.ts +13 -0
  382. package/dist/collection/implementations/iterable-collection/_shared/take-iterable.js +22 -0
  383. package/dist/collection/implementations/iterable-collection/_shared/take-iterable.js.map +1 -0
  384. package/dist/collection/implementations/iterable-collection/_shared/take-until-iterable.d.ts +13 -0
  385. package/dist/collection/implementations/iterable-collection/_shared/take-until-iterable.js +24 -0
  386. package/dist/collection/implementations/iterable-collection/_shared/take-until-iterable.js.map +1 -0
  387. package/dist/collection/implementations/iterable-collection/_shared/tap-iterable.d.ts +13 -0
  388. package/dist/collection/implementations/iterable-collection/_shared/tap-iterable.js +20 -0
  389. package/dist/collection/implementations/iterable-collection/_shared/tap-iterable.js.map +1 -0
  390. package/dist/collection/implementations/iterable-collection/_shared/unique-iterable.d.ts +13 -0
  391. package/dist/collection/implementations/iterable-collection/_shared/unique-iterable.js +26 -0
  392. package/dist/collection/implementations/iterable-collection/_shared/unique-iterable.js.map +1 -0
  393. package/dist/collection/implementations/iterable-collection/_shared/update-iterable.d.ts +14 -0
  394. package/dist/collection/implementations/iterable-collection/_shared/update-iterable.js +28 -0
  395. package/dist/collection/implementations/iterable-collection/_shared/update-iterable.js.map +1 -0
  396. package/dist/collection/implementations/iterable-collection/_shared/when-iterable.d.ts +14 -0
  397. package/dist/collection/implementations/iterable-collection/_shared/when-iterable.js +25 -0
  398. package/dist/collection/implementations/iterable-collection/_shared/when-iterable.js.map +1 -0
  399. package/dist/collection/implementations/iterable-collection/_shared/zip-iterable.js +26 -0
  400. package/dist/collection/implementations/iterable-collection/_shared/zip-iterable.js.map +1 -0
  401. package/dist/collection/implementations/iterable-collection/iterable-collection.d.ts +249 -0
  402. package/dist/collection/implementations/iterable-collection/iterable-collection.js +708 -0
  403. package/dist/collection/implementations/iterable-collection/iterable-collection.js.map +1 -0
  404. package/dist/collection/implementations/list-collection/_module.d.ts +1 -0
  405. package/dist/collection/implementations/list-collection/_module.js +2 -0
  406. package/dist/collection/implementations/list-collection/_module.js.map +1 -0
  407. package/dist/collection/implementations/list-collection/list-collection.d.ts +246 -0
  408. package/dist/collection/implementations/list-collection/list-collection.js +863 -0
  409. package/dist/collection/implementations/list-collection/list-collection.js.map +1 -0
  410. package/dist/event-bus/contracts/_module-exports.d.ts +5 -0
  411. package/dist/event-bus/contracts/_module-exports.js +6 -0
  412. package/dist/event-bus/contracts/_module-exports.js.map +1 -0
  413. package/dist/event-bus/contracts/_shared.d.ts +19 -0
  414. package/dist/event-bus/contracts/_shared.js +15 -0
  415. package/dist/event-bus/contracts/_shared.js.map +1 -0
  416. package/dist/event-bus/contracts/event-bus-adapter.contract.d.ts +34 -0
  417. package/dist/event-bus/contracts/event-bus-adapter.contract.js +5 -0
  418. package/dist/event-bus/contracts/event-bus-adapter.contract.js.map +1 -0
  419. package/dist/event-bus/contracts/event-bus-factory.contract.d.ts +20 -0
  420. package/dist/event-bus/contracts/event-bus-factory.contract.js +9 -0
  421. package/dist/event-bus/contracts/event-bus-factory.contract.js.map +1 -0
  422. package/dist/event-bus/contracts/event-bus.contract.d.ts +142 -0
  423. package/dist/event-bus/contracts/event-bus.contract.js +12 -0
  424. package/dist/event-bus/contracts/event-bus.contract.js.map +1 -0
  425. package/dist/event-bus/contracts/event-bus.errors.d.ts +57 -0
  426. package/dist/event-bus/contracts/event-bus.errors.js +98 -0
  427. package/dist/event-bus/contracts/event-bus.errors.js.map +1 -0
  428. package/dist/event-bus/implementations/adapters/_module-exports.d.ts +3 -0
  429. package/dist/event-bus/implementations/adapters/_module-exports.js +4 -0
  430. package/dist/event-bus/implementations/adapters/_module-exports.js.map +1 -0
  431. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/_module.d.ts +1 -0
  432. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/_module.js +2 -0
  433. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/_module.js.map +1 -0
  434. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.d.ts +55 -0
  435. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.js +71 -0
  436. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.js.map +1 -0
  437. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/_module.d.ts +1 -0
  438. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/_module.js +2 -0
  439. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/_module.js.map +1 -0
  440. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.d.ts +18 -0
  441. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.js +27 -0
  442. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.js.map +1 -0
  443. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module.d.ts +1 -0
  444. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module.js +2 -0
  445. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module.js.map +1 -0
  446. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.d.ts +58 -0
  447. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js +82 -0
  448. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js.map +1 -0
  449. package/dist/event-bus/implementations/derivables/_module-exports.d.ts +2 -0
  450. package/dist/event-bus/implementations/derivables/_module-exports.js +3 -0
  451. package/dist/event-bus/implementations/derivables/_module-exports.js.map +1 -0
  452. package/dist/event-bus/implementations/derivables/event-bus/_module.d.ts +1 -0
  453. package/dist/event-bus/implementations/derivables/event-bus/_module.js +2 -0
  454. package/dist/event-bus/implementations/derivables/event-bus/_module.js.map +1 -0
  455. package/dist/event-bus/implementations/derivables/event-bus/event-bus.d.ts +336 -0
  456. package/dist/event-bus/implementations/derivables/event-bus/event-bus.js +444 -0
  457. package/dist/event-bus/implementations/derivables/event-bus/event-bus.js.map +1 -0
  458. package/dist/event-bus/implementations/derivables/event-bus-factory/_module.d.ts +1 -0
  459. package/dist/event-bus/implementations/derivables/event-bus-factory/_module.js +2 -0
  460. package/dist/event-bus/implementations/derivables/event-bus-factory/_module.js.map +1 -0
  461. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.d.ts +139 -0
  462. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js +127 -0
  463. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js.map +1 -0
  464. package/dist/event-bus/implementations/test-utilities/_module-exports.d.ts +2 -0
  465. package/dist/event-bus/implementations/test-utilities/_module-exports.js +3 -0
  466. package/dist/event-bus/implementations/test-utilities/_module-exports.js.map +1 -0
  467. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.d.ts +73 -0
  468. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.js +155 -0
  469. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.js.map +1 -0
  470. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.d.ts +75 -0
  471. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.js +1163 -0
  472. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.js.map +1 -0
  473. package/dist/lock/contracts/_module-exports.d.ts +7 -0
  474. package/dist/lock/contracts/_module-exports.js +8 -0
  475. package/dist/lock/contracts/_module-exports.js.map +1 -0
  476. package/dist/lock/contracts/database-lock-adapter.contract.d.ts +52 -0
  477. package/dist/lock/contracts/database-lock-adapter.contract.js +5 -0
  478. package/dist/lock/contracts/database-lock-adapter.contract.js.map +1 -0
  479. package/dist/lock/contracts/lock-adapter.contract.d.ts +41 -0
  480. package/dist/lock/contracts/lock-adapter.contract.js +5 -0
  481. package/dist/lock/contracts/lock-adapter.contract.js.map +1 -0
  482. package/dist/lock/contracts/lock-provider-factory.contract.d.ts +19 -0
  483. package/dist/lock/contracts/lock-provider-factory.contract.js +9 -0
  484. package/dist/lock/contracts/lock-provider-factory.contract.js.map +1 -0
  485. package/dist/lock/contracts/lock-provider.contract.d.ts +48 -0
  486. package/dist/lock/contracts/lock-provider.contract.js +5 -0
  487. package/dist/lock/contracts/lock-provider.contract.js.map +1 -0
  488. package/dist/lock/contracts/lock.contract.d.ts +111 -0
  489. package/dist/lock/contracts/lock.contract.js +5 -0
  490. package/dist/lock/contracts/lock.contract.js.map +1 -0
  491. package/dist/lock/contracts/lock.errors.d.ts +82 -0
  492. package/dist/lock/contracts/lock.errors.js +165 -0
  493. package/dist/lock/contracts/lock.errors.js.map +1 -0
  494. package/dist/lock/contracts/lock.events.d.ts +103 -0
  495. package/dist/lock/contracts/lock.events.js +82 -0
  496. package/dist/lock/contracts/lock.events.js.map +1 -0
  497. package/dist/lock/implementations/adapters/_module-exports.d.ts +5 -0
  498. package/dist/lock/implementations/adapters/_module-exports.js +6 -0
  499. package/dist/lock/implementations/adapters/_module-exports.js.map +1 -0
  500. package/dist/lock/implementations/adapters/kysely-lock-adapter/_module.d.ts +1 -0
  501. package/dist/lock/implementations/adapters/kysely-lock-adapter/_module.js +2 -0
  502. package/dist/lock/implementations/adapters/kysely-lock-adapter/_module.js.map +1 -0
  503. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.d.ts +52 -0
  504. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js +129 -0
  505. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js.map +1 -0
  506. package/dist/lock/implementations/adapters/libsql-lock-adapter/_module.d.ts +1 -0
  507. package/dist/lock/implementations/adapters/libsql-lock-adapter/_module.js +2 -0
  508. package/dist/lock/implementations/adapters/libsql-lock-adapter/_module.js.map +1 -0
  509. package/dist/lock/implementations/adapters/libsql-lock-adapter/libsql-lock-adapter.d.ts +65 -0
  510. package/dist/lock/implementations/adapters/libsql-lock-adapter/libsql-lock-adapter.js +93 -0
  511. package/dist/lock/implementations/adapters/libsql-lock-adapter/libsql-lock-adapter.js.map +1 -0
  512. package/dist/lock/implementations/adapters/memory-lock-adapter/_module.d.ts +1 -0
  513. package/dist/lock/implementations/adapters/memory-lock-adapter/_module.js +2 -0
  514. package/dist/lock/implementations/adapters/memory-lock-adapter/_module.js.map +1 -0
  515. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.d.ts +56 -0
  516. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js +122 -0
  517. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js.map +1 -0
  518. package/dist/lock/implementations/adapters/mongodb-lock-adapter/_module.d.ts +1 -0
  519. package/dist/lock/implementations/adapters/mongodb-lock-adapter/_module.js +2 -0
  520. package/dist/lock/implementations/adapters/mongodb-lock-adapter/_module.js.map +1 -0
  521. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.d.ts +68 -0
  522. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js +180 -0
  523. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js.map +1 -0
  524. package/dist/lock/implementations/adapters/redis-lock-adapter/_module.d.ts +1 -0
  525. package/dist/lock/implementations/adapters/redis-lock-adapter/_module.js +2 -0
  526. package/dist/lock/implementations/adapters/redis-lock-adapter/_module.js.map +1 -0
  527. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.d.ts +62 -0
  528. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js +140 -0
  529. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js.map +1 -0
  530. package/dist/lock/implementations/adapters/sqlite-lock-adapter/_module.d.ts +1 -0
  531. package/dist/lock/implementations/adapters/sqlite-lock-adapter/_module.js +2 -0
  532. package/dist/lock/implementations/adapters/sqlite-lock-adapter/_module.js.map +1 -0
  533. package/dist/lock/implementations/adapters/sqlite-lock-adapter/sqlite-lock-adapter.d.ts +65 -0
  534. package/dist/lock/implementations/adapters/sqlite-lock-adapter/sqlite-lock-adapter.js +92 -0
  535. package/dist/lock/implementations/adapters/sqlite-lock-adapter/sqlite-lock-adapter.js.map +1 -0
  536. package/dist/lock/implementations/derivables/_module-exports.d.ts +2 -0
  537. package/dist/lock/implementations/derivables/_module-exports.js +3 -0
  538. package/dist/lock/implementations/derivables/_module-exports.js.map +1 -0
  539. package/dist/lock/implementations/derivables/lock-provider/_module.d.ts +1 -0
  540. package/dist/lock/implementations/derivables/lock-provider/_module.js +2 -0
  541. package/dist/lock/implementations/derivables/lock-provider/_module.js.map +1 -0
  542. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.d.ts +18 -0
  543. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.js +50 -0
  544. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.js.map +1 -0
  545. package/dist/lock/implementations/derivables/lock-provider/lock-provider.d.ts +497 -0
  546. package/dist/lock/implementations/derivables/lock-provider/lock-provider.js +540 -0
  547. package/dist/lock/implementations/derivables/lock-provider/lock-provider.js.map +1 -0
  548. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.d.ts +44 -0
  549. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js +78 -0
  550. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js.map +1 -0
  551. package/dist/lock/implementations/derivables/lock-provider/lock-state.d.ts +43 -0
  552. package/dist/lock/implementations/derivables/lock-provider/lock-state.js +77 -0
  553. package/dist/lock/implementations/derivables/lock-provider/lock-state.js.map +1 -0
  554. package/dist/lock/implementations/derivables/lock-provider/lock.d.ts +811 -0
  555. package/dist/lock/implementations/derivables/lock-provider/lock.js +1069 -0
  556. package/dist/lock/implementations/derivables/lock-provider/lock.js.map +1 -0
  557. package/dist/lock/implementations/derivables/lock-provider-factory/_module.d.ts +1 -0
  558. package/dist/lock/implementations/derivables/lock-provider-factory/_module.js +2 -0
  559. package/dist/lock/implementations/derivables/lock-provider-factory/_module.js.map +1 -0
  560. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.d.ts +203 -0
  561. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js +156 -0
  562. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js.map +1 -0
  563. package/dist/lock/implementations/test-utilities/_module-exports.d.ts +3 -0
  564. package/dist/lock/implementations/test-utilities/_module-exports.js +4 -0
  565. package/dist/lock/implementations/test-utilities/_module-exports.js.map +1 -0
  566. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.d.ts +61 -0
  567. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.js +329 -0
  568. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.js.map +1 -0
  569. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.d.ts +63 -0
  570. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.js +156 -0
  571. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.js.map +1 -0
  572. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.d.ts +70 -0
  573. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.js +2315 -0
  574. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.js.map +1 -0
  575. package/dist/serde/contracts/_module-exports.d.ts +7 -0
  576. package/dist/serde/contracts/_module-exports.js +8 -0
  577. package/dist/serde/contracts/_module-exports.js.map +1 -0
  578. package/dist/serde/contracts/deserializer.contract.d.ts +15 -0
  579. package/dist/serde/contracts/deserializer.contract.js +7 -0
  580. package/dist/serde/contracts/deserializer.contract.js.map +1 -0
  581. package/dist/serde/contracts/flexible-serde-adapter.contract.d.ts +27 -0
  582. package/dist/serde/contracts/flexible-serde-adapter.contract.js +5 -0
  583. package/dist/serde/contracts/flexible-serde-adapter.contract.js.map +1 -0
  584. package/dist/serde/contracts/flexible-serde.contract.d.ts +55 -0
  585. package/dist/serde/contracts/flexible-serde.contract.js +5 -0
  586. package/dist/serde/contracts/flexible-serde.contract.js.map +1 -0
  587. package/dist/serde/contracts/serde.contract.d.ts +12 -0
  588. package/dist/serde/contracts/serde.contract.js +5 -0
  589. package/dist/serde/contracts/serde.contract.js.map +1 -0
  590. package/dist/serde/contracts/serde.errors.d.ts +27 -0
  591. package/dist/serde/contracts/serde.errors.js +37 -0
  592. package/dist/serde/contracts/serde.errors.js.map +1 -0
  593. package/dist/serde/contracts/serializable.contract.d.ts +12 -0
  594. package/dist/serde/contracts/serializable.contract.js +5 -0
  595. package/dist/serde/contracts/serializable.contract.js.map +1 -0
  596. package/dist/serde/contracts/serializer.contract.d.ts +12 -0
  597. package/dist/serde/contracts/serializer.contract.js +7 -0
  598. package/dist/serde/contracts/serializer.contract.js.map +1 -0
  599. package/dist/serde/implementations/adapters/_module-exports.d.ts +5 -0
  600. package/dist/serde/implementations/adapters/_module-exports.js +6 -0
  601. package/dist/serde/implementations/adapters/_module-exports.js.map +1 -0
  602. package/dist/serde/implementations/adapters/mongodb-serde/_module.d.ts +1 -0
  603. package/dist/serde/implementations/adapters/mongodb-serde/_module.js +2 -0
  604. package/dist/serde/implementations/adapters/mongodb-serde/_module.js.map +1 -0
  605. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.d.ts +13 -0
  606. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.js +39 -0
  607. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.js.map +1 -0
  608. package/dist/serde/implementations/adapters/no-op-serde-adapter/_module.d.ts +1 -0
  609. package/dist/serde/implementations/adapters/no-op-serde-adapter/_module.js +2 -0
  610. package/dist/serde/implementations/adapters/no-op-serde-adapter/_module.js.map +1 -0
  611. package/dist/serde/implementations/adapters/no-op-serde-adapter/no-op-serde-adapter.d.ts +14 -0
  612. package/dist/serde/implementations/adapters/no-op-serde-adapter/no-op-serde-adapter.js +17 -0
  613. package/dist/serde/implementations/adapters/no-op-serde-adapter/no-op-serde-adapter.js.map +1 -0
  614. package/dist/serde/implementations/adapters/redis-serde/_module.d.ts +1 -0
  615. package/dist/serde/implementations/adapters/redis-serde/_module.js +2 -0
  616. package/dist/serde/implementations/adapters/redis-serde/_module.js.map +1 -0
  617. package/dist/serde/implementations/adapters/redis-serde/redis-serde.d.ts +13 -0
  618. package/dist/serde/implementations/adapters/redis-serde/redis-serde.js +40 -0
  619. package/dist/serde/implementations/adapters/redis-serde/redis-serde.js.map +1 -0
  620. package/dist/serde/implementations/adapters/sql-serde/_module.d.ts +1 -0
  621. package/dist/serde/implementations/adapters/sql-serde/_module.js +2 -0
  622. package/dist/serde/implementations/adapters/sql-serde/_module.js.map +1 -0
  623. package/dist/serde/implementations/adapters/sql-serde/sql-serde.d.ts +13 -0
  624. package/dist/serde/implementations/adapters/sql-serde/sql-serde.js +40 -0
  625. package/dist/serde/implementations/adapters/sql-serde/sql-serde.js.map +1 -0
  626. package/dist/serde/implementations/adapters/super-json-serde-adapter/_module.d.ts +1 -0
  627. package/dist/serde/implementations/adapters/super-json-serde-adapter/_module.js +2 -0
  628. package/dist/serde/implementations/adapters/super-json-serde-adapter/_module.js.map +1 -0
  629. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.d.ts +15 -0
  630. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.js +44 -0
  631. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.js.map +1 -0
  632. package/dist/serde/implementations/derivables/_module-exports.d.ts +1 -0
  633. package/dist/serde/implementations/derivables/_module-exports.js +2 -0
  634. package/dist/serde/implementations/derivables/_module-exports.js.map +1 -0
  635. package/dist/serde/implementations/derivables/serde-transformers.d.ts +210 -0
  636. package/dist/serde/implementations/derivables/serde-transformers.js +414 -0
  637. package/dist/serde/implementations/derivables/serde-transformers.js.map +1 -0
  638. package/dist/serde/implementations/derivables/serde.d.ts +299 -0
  639. package/dist/serde/implementations/derivables/serde.js +319 -0
  640. package/dist/serde/implementations/derivables/serde.js.map +1 -0
  641. package/dist/serde/implementations/test-utilities/_module-exports.d.ts +2 -0
  642. package/dist/serde/implementations/test-utilities/_module-exports.js +3 -0
  643. package/dist/serde/implementations/test-utilities/_module-exports.js.map +1 -0
  644. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.d.ts +36 -0
  645. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.js +145 -0
  646. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.js.map +1 -0
  647. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.d.ts +38 -0
  648. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.js +307 -0
  649. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.js.map +1 -0
  650. package/dist/utilities/_module-exports.d.ts +7 -0
  651. package/dist/utilities/_module-exports.js +8 -0
  652. package/dist/utilities/_module-exports.js.map +1 -0
  653. package/dist/utilities/constants.d.ts +7 -0
  654. package/dist/utilities/constants.js +8 -0
  655. package/dist/utilities/constants.js.map +1 -0
  656. package/dist/utilities/contracts/_module.d.ts +3 -0
  657. package/dist/utilities/contracts/_module.js +4 -0
  658. package/dist/utilities/contracts/_module.js.map +1 -0
  659. package/dist/utilities/contracts/deinitizable.contract.d.ts +11 -0
  660. package/dist/utilities/contracts/deinitizable.contract.js +5 -0
  661. package/dist/utilities/contracts/deinitizable.contract.js.map +1 -0
  662. package/dist/utilities/contracts/initizable.contract.d.ts +11 -0
  663. package/dist/utilities/contracts/initizable.contract.js +5 -0
  664. package/dist/utilities/contracts/initizable.contract.js.map +1 -0
  665. package/dist/utilities/contracts/serialized-error.contract.d.ts +13 -0
  666. package/dist/utilities/contracts/serialized-error.contract.js +5 -0
  667. package/dist/utilities/contracts/serialized-error.contract.js.map +1 -0
  668. package/dist/utilities/errors.d.ts +27 -0
  669. package/dist/utilities/errors.js +37 -0
  670. package/dist/utilities/errors.js.map +1 -0
  671. package/dist/utilities/functions.d.ts +25 -0
  672. package/dist/utilities/functions.js +55 -0
  673. package/dist/utilities/functions.js.map +1 -0
  674. package/dist/utilities/kysely/_module.d.ts +1 -0
  675. package/dist/utilities/kysely/_module.js +2 -0
  676. package/dist/utilities/kysely/_module.js.map +1 -0
  677. package/dist/utilities/kysely/kysely-table-name-transformer-plugin.js +50 -0
  678. package/dist/utilities/kysely/kysely-table-name-transformer-plugin.js.map +1 -0
  679. package/dist/utilities/time-span/_module.d.ts +1 -0
  680. package/dist/utilities/time-span/_module.js +2 -0
  681. package/dist/utilities/time-span/_module.js.map +1 -0
  682. package/dist/utilities/time-span/time-span.d.ts +66 -0
  683. package/dist/utilities/time-span/time-span.js +125 -0
  684. package/dist/utilities/time-span/time-span.js.map +1 -0
  685. package/dist/utilities/types.d.ts +54 -0
  686. package/dist/utilities/types.js +5 -0
  687. package/dist/utilities/types.js.map +1 -0
  688. package/package.json +29 -8
  689. package/dist/cjs/_module.js +0 -29
  690. package/dist/cjs/_module.js.map +0 -1
  691. package/dist/cjs/async/_module.js +0 -20
  692. package/dist/cjs/async/_module.js.map +0 -1
  693. package/dist/cjs/async/async.errors.js +0 -34
  694. package/dist/cjs/async/async.errors.js.map +0 -1
  695. package/dist/cjs/async/backof-policies/_module.js +0 -22
  696. package/dist/cjs/async/backof-policies/_module.js.map +0 -1
  697. package/dist/cjs/async/backof-policies/_shared.js +0 -7
  698. package/dist/cjs/async/backof-policies/_shared.js.map +0 -1
  699. package/dist/cjs/async/backof-policies/constant-backoff-policy/_module.js +0 -18
  700. package/dist/cjs/async/backof-policies/constant-backoff-policy/_module.js.map +0 -1
  701. package/dist/cjs/async/backof-policies/constant-backoff-policy/constant-backoff-policy.js +0 -19
  702. package/dist/cjs/async/backof-policies/constant-backoff-policy/constant-backoff-policy.js.map +0 -1
  703. package/dist/cjs/async/backof-policies/exponential-backoff-policy/_module.js +0 -18
  704. package/dist/cjs/async/backof-policies/exponential-backoff-policy/_module.js.map +0 -1
  705. package/dist/cjs/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js +0 -23
  706. package/dist/cjs/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js.map +0 -1
  707. package/dist/cjs/async/backof-policies/linear-backoff-policy/_module.js +0 -18
  708. package/dist/cjs/async/backof-policies/linear-backoff-policy/_module.js.map +0 -1
  709. package/dist/cjs/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js +0 -23
  710. package/dist/cjs/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js.map +0 -1
  711. package/dist/cjs/async/backof-policies/polynomial-backoff-policy/_module.js +0 -18
  712. package/dist/cjs/async/backof-policies/polynomial-backoff-policy/_module.js.map +0 -1
  713. package/dist/cjs/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js +0 -23
  714. package/dist/cjs/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js.map +0 -1
  715. package/dist/cjs/async/utilities/_module.js +0 -22
  716. package/dist/cjs/async/utilities/_module.js.map +0 -1
  717. package/dist/cjs/async/utilities/abort/_module.js +0 -19
  718. package/dist/cjs/async/utilities/abort/_module.js.map +0 -1
  719. package/dist/cjs/async/utilities/abort/abort-and-fail.js +0 -45
  720. package/dist/cjs/async/utilities/abort/abort-and-fail.js.map +0 -1
  721. package/dist/cjs/async/utilities/abort/abort.js +0 -18
  722. package/dist/cjs/async/utilities/abort/abort.js.map +0 -1
  723. package/dist/cjs/async/utilities/delay/_module.js +0 -18
  724. package/dist/cjs/async/utilities/delay/_module.js.map +0 -1
  725. package/dist/cjs/async/utilities/delay/delay.js +0 -20
  726. package/dist/cjs/async/utilities/delay/delay.js.map +0 -1
  727. package/dist/cjs/async/utilities/lazy-promise/_module.js +0 -18
  728. package/dist/cjs/async/utilities/lazy-promise/_module.js.map +0 -1
  729. package/dist/cjs/async/utilities/lazy-promise/lazy-promise.js +0 -111
  730. package/dist/cjs/async/utilities/lazy-promise/lazy-promise.js.map +0 -1
  731. package/dist/cjs/async/utilities/retry/_module.js +0 -19
  732. package/dist/cjs/async/utilities/retry/_module.js.map +0 -1
  733. package/dist/cjs/async/utilities/retry/retry-or-fail.js +0 -36
  734. package/dist/cjs/async/utilities/retry/retry-or-fail.js.map +0 -1
  735. package/dist/cjs/async/utilities/retry/retry.js +0 -18
  736. package/dist/cjs/async/utilities/retry/retry.js.map +0 -1
  737. package/dist/cjs/async/utilities/timeout/_module.js +0 -19
  738. package/dist/cjs/async/utilities/timeout/_module.js.map +0 -1
  739. package/dist/cjs/async/utilities/timeout/timeout-and-fail.js +0 -25
  740. package/dist/cjs/async/utilities/timeout/timeout-and-fail.js.map +0 -1
  741. package/dist/cjs/async/utilities/timeout/timeout.js +0 -18
  742. package/dist/cjs/async/utilities/timeout/timeout.js.map +0 -1
  743. package/dist/cjs/cache/contracts/_module.js +0 -22
  744. package/dist/cjs/cache/contracts/_module.js.map +0 -1
  745. package/dist/cjs/cache/contracts/cache-adapter.contract.js +0 -3
  746. package/dist/cjs/cache/contracts/cache-adapter.contract.js.map +0 -1
  747. package/dist/cjs/cache/contracts/cache-factory.contract.js +0 -3
  748. package/dist/cjs/cache/contracts/cache-factory.contract.js.map +0 -1
  749. package/dist/cjs/cache/contracts/cache.contract.js +0 -3
  750. package/dist/cjs/cache/contracts/cache.contract.js.map +0 -1
  751. package/dist/cjs/cache/contracts/cache.errors.js +0 -64
  752. package/dist/cjs/cache/contracts/cache.errors.js.map +0 -1
  753. package/dist/cjs/cache/contracts/cache.events.js +0 -50
  754. package/dist/cjs/cache/contracts/cache.events.js.map +0 -1
  755. package/dist/cjs/cache/implementations/_module.js +0 -20
  756. package/dist/cjs/cache/implementations/_module.js.map +0 -1
  757. package/dist/cjs/cache/implementations/_shared/_module.js +0 -19
  758. package/dist/cjs/cache/implementations/_shared/_module.js.map +0 -1
  759. package/dist/cjs/cache/implementations/_shared/cache-adapter.test-suite.js +0 -253
  760. package/dist/cjs/cache/implementations/_shared/cache-adapter.test-suite.js.map +0 -1
  761. package/dist/cjs/cache/implementations/_shared/cache.test-suite.js +0 -1739
  762. package/dist/cjs/cache/implementations/_shared/cache.test-suite.js.map +0 -1
  763. package/dist/cjs/cache/implementations/adapters/_module.js +0 -23
  764. package/dist/cjs/cache/implementations/adapters/_module.js.map +0 -1
  765. package/dist/cjs/cache/implementations/adapters/kysely-sqlite-cache-adapter/_module.js +0 -18
  766. package/dist/cjs/cache/implementations/adapters/kysely-sqlite-cache-adapter/_module.js.map +0 -1
  767. package/dist/cjs/cache/implementations/adapters/kysely-sqlite-cache-adapter/kysely-sqlite-cache-adapter.js +0 -314
  768. package/dist/cjs/cache/implementations/adapters/kysely-sqlite-cache-adapter/kysely-sqlite-cache-adapter.js.map +0 -1
  769. package/dist/cjs/cache/implementations/adapters/libsql-cache-adapter/_module.js +0 -18
  770. package/dist/cjs/cache/implementations/adapters/libsql-cache-adapter/_module.js.map +0 -1
  771. package/dist/cjs/cache/implementations/adapters/libsql-cache-adapter/libsql-cache-adapter.js +0 -68
  772. package/dist/cjs/cache/implementations/adapters/libsql-cache-adapter/libsql-cache-adapter.js.map +0 -1
  773. package/dist/cjs/cache/implementations/adapters/memory-cache-adapter/_module.js +0 -18
  774. package/dist/cjs/cache/implementations/adapters/memory-cache-adapter/_module.js.map +0 -1
  775. package/dist/cjs/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js +0 -91
  776. package/dist/cjs/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js.map +0 -1
  777. package/dist/cjs/cache/implementations/adapters/mongodb-cache-adapter/_module.js +0 -18
  778. package/dist/cjs/cache/implementations/adapters/mongodb-cache-adapter/_module.js.map +0 -1
  779. package/dist/cjs/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js +0 -290
  780. package/dist/cjs/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js.map +0 -1
  781. package/dist/cjs/cache/implementations/adapters/no-op-cache-adapter/_module.js +0 -18
  782. package/dist/cjs/cache/implementations/adapters/no-op-cache-adapter/_module.js.map +0 -1
  783. package/dist/cjs/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js +0 -34
  784. package/dist/cjs/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js.map +0 -1
  785. package/dist/cjs/cache/implementations/adapters/redis-cache-adapter/_module.js +0 -18
  786. package/dist/cjs/cache/implementations/adapters/redis-cache-adapter/_module.js.map +0 -1
  787. package/dist/cjs/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js +0 -171
  788. package/dist/cjs/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js.map +0 -1
  789. package/dist/cjs/cache/implementations/adapters/sqlite-cache-adapter/_module.js +0 -18
  790. package/dist/cjs/cache/implementations/adapters/sqlite-cache-adapter/_module.js.map +0 -1
  791. package/dist/cjs/cache/implementations/adapters/sqlite-cache-adapter/sqlite-cache-adapter.js +0 -67
  792. package/dist/cjs/cache/implementations/adapters/sqlite-cache-adapter/sqlite-cache-adapter.js.map +0 -1
  793. package/dist/cjs/cache/implementations/derivables/_module.js +0 -19
  794. package/dist/cjs/cache/implementations/derivables/_module.js.map +0 -1
  795. package/dist/cjs/cache/implementations/derivables/cache/_module.js +0 -18
  796. package/dist/cjs/cache/implementations/derivables/cache/_module.js.map +0 -1
  797. package/dist/cjs/cache/implementations/derivables/cache/cache.js +0 -553
  798. package/dist/cjs/cache/implementations/derivables/cache/cache.js.map +0 -1
  799. package/dist/cjs/cache/implementations/derivables/cache-factory/_module.js +0 -18
  800. package/dist/cjs/cache/implementations/derivables/cache-factory/_module.js.map +0 -1
  801. package/dist/cjs/cache/implementations/derivables/cache-factory/cache-factory.js +0 -70
  802. package/dist/cjs/cache/implementations/derivables/cache-factory/cache-factory.js.map +0 -1
  803. package/dist/cjs/collection/contracts/_module.js +0 -21
  804. package/dist/cjs/collection/contracts/_module.js.map +0 -1
  805. package/dist/cjs/collection/contracts/_shared.js +0 -3
  806. package/dist/cjs/collection/contracts/_shared.js.map +0 -1
  807. package/dist/cjs/collection/contracts/async-collection.contract.js +0 -3
  808. package/dist/cjs/collection/contracts/async-collection.contract.js.map +0 -1
  809. package/dist/cjs/collection/contracts/collection.contract.js +0 -3
  810. package/dist/cjs/collection/contracts/collection.contract.js.map +0 -1
  811. package/dist/cjs/collection/contracts/collection.errors.js +0 -46
  812. package/dist/cjs/collection/contracts/collection.errors.js.map +0 -1
  813. package/dist/cjs/collection/implementations/_module.js +0 -21
  814. package/dist/cjs/collection/implementations/_module.js.map +0 -1
  815. package/dist/cjs/collection/implementations/_shared.js +0 -30
  816. package/dist/cjs/collection/implementations/_shared.js.map +0 -1
  817. package/dist/cjs/collection/implementations/async-iterable-collection/_module.js +0 -18
  818. package/dist/cjs/collection/implementations/async-iterable-collection/_module.js.map +0 -1
  819. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/_module.js +0 -53
  820. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/_module.js.map +0 -1
  821. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.js +0 -35
  822. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.js.map +0 -1
  823. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.js +0 -32
  824. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.js.map +0 -1
  825. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.js +0 -22
  826. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.js.map +0 -1
  827. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.js +0 -27
  828. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.js.map +0 -1
  829. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.js +0 -35
  830. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.js.map +0 -1
  831. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-delay-iterable.js +0 -27
  832. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-delay-iterable.js.map +0 -1
  833. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.js +0 -18
  834. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.js.map +0 -1
  835. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.js +0 -20
  836. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.js.map +0 -1
  837. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.js +0 -18
  838. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.js.map +0 -1
  839. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.js +0 -29
  840. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.js.map +0 -1
  841. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.js +0 -27
  842. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.js.map +0 -1
  843. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.js +0 -27
  844. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.js.map +0 -1
  845. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-map-iterable.js +0 -18
  846. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-map-iterable.js.map +0 -1
  847. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.js +0 -24
  848. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.js.map +0 -1
  849. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.js +0 -31
  850. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.js.map +0 -1
  851. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.js +0 -31
  852. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.js.map +0 -1
  853. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.js +0 -29
  854. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.js.map +0 -1
  855. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.js +0 -22
  856. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.js.map +0 -1
  857. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-retry-iterable.js +0 -33
  858. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-retry-iterable.js.map +0 -1
  859. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.js +0 -21
  860. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.js.map +0 -1
  861. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.js +0 -27
  862. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.js.map +0 -1
  863. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.js +0 -19
  864. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.js.map +0 -1
  865. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.js +0 -25
  866. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.js.map +0 -1
  867. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.js +0 -34
  868. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.js.map +0 -1
  869. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.js +0 -29
  870. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.js.map +0 -1
  871. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.js +0 -16
  872. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.js.map +0 -1
  873. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-split-iterable.js +0 -38
  874. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-split-iterable.js.map +0 -1
  875. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-take-iterable.js +0 -19
  876. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-take-iterable.js.map +0 -1
  877. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-take-until-abort-iterable.js +0 -36
  878. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-take-until-abort-iterable.js.map +0 -1
  879. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.js +0 -21
  880. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.js.map +0 -1
  881. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-take-until-timeout-iterable.js +0 -48
  882. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-take-until-timeout-iterable.js.map +0 -1
  883. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.js +0 -17
  884. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.js.map +0 -1
  885. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.js +0 -23
  886. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.js.map +0 -1
  887. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-update-iterable.js +0 -25
  888. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-update-iterable.js.map +0 -1
  889. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-when-iterable.js +0 -22
  890. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-when-iterable.js.map +0 -1
  891. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.js +0 -37
  892. package/dist/cjs/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.js.map +0 -1
  893. package/dist/cjs/collection/implementations/async-iterable-collection/async-iterable-collection.js +0 -633
  894. package/dist/cjs/collection/implementations/async-iterable-collection/async-iterable-collection.js.map +0 -1
  895. package/dist/cjs/collection/implementations/iterable-collection/_module.js +0 -18
  896. package/dist/cjs/collection/implementations/iterable-collection/_module.js.map +0 -1
  897. package/dist/cjs/collection/implementations/iterable-collection/_shared/_module.js +0 -49
  898. package/dist/cjs/collection/implementations/iterable-collection/_shared/_module.js.map +0 -1
  899. package/dist/cjs/collection/implementations/iterable-collection/_shared/chunk-iterable.js +0 -35
  900. package/dist/cjs/collection/implementations/iterable-collection/_shared/chunk-iterable.js.map +0 -1
  901. package/dist/cjs/collection/implementations/iterable-collection/_shared/chunk-while-iterable.js +0 -32
  902. package/dist/cjs/collection/implementations/iterable-collection/_shared/chunk-while-iterable.js.map +0 -1
  903. package/dist/cjs/collection/implementations/iterable-collection/_shared/collapse-iterable.js +0 -22
  904. package/dist/cjs/collection/implementations/iterable-collection/_shared/collapse-iterable.js.map +0 -1
  905. package/dist/cjs/collection/implementations/iterable-collection/_shared/count-by-iterable.js +0 -27
  906. package/dist/cjs/collection/implementations/iterable-collection/_shared/count-by-iterable.js.map +0 -1
  907. package/dist/cjs/collection/implementations/iterable-collection/_shared/cross-join-iterable.js +0 -37
  908. package/dist/cjs/collection/implementations/iterable-collection/_shared/cross-join-iterable.js.map +0 -1
  909. package/dist/cjs/collection/implementations/iterable-collection/_shared/entries-iterable.js +0 -18
  910. package/dist/cjs/collection/implementations/iterable-collection/_shared/entries-iterable.js.map +0 -1
  911. package/dist/cjs/collection/implementations/iterable-collection/_shared/filter-iterable.js +0 -20
  912. package/dist/cjs/collection/implementations/iterable-collection/_shared/filter-iterable.js.map +0 -1
  913. package/dist/cjs/collection/implementations/iterable-collection/_shared/flat-map-iterable.js +0 -18
  914. package/dist/cjs/collection/implementations/iterable-collection/_shared/flat-map-iterable.js.map +0 -1
  915. package/dist/cjs/collection/implementations/iterable-collection/_shared/group-by-iterable.js +0 -29
  916. package/dist/cjs/collection/implementations/iterable-collection/_shared/group-by-iterable.js.map +0 -1
  917. package/dist/cjs/collection/implementations/iterable-collection/_shared/insert-after-iterable.js +0 -25
  918. package/dist/cjs/collection/implementations/iterable-collection/_shared/insert-after-iterable.js.map +0 -1
  919. package/dist/cjs/collection/implementations/iterable-collection/_shared/insert-before-iterable.js +0 -25
  920. package/dist/cjs/collection/implementations/iterable-collection/_shared/insert-before-iterable.js.map +0 -1
  921. package/dist/cjs/collection/implementations/iterable-collection/_shared/map-iterable.js +0 -18
  922. package/dist/cjs/collection/implementations/iterable-collection/_shared/map-iterable.js.map +0 -1
  923. package/dist/cjs/collection/implementations/iterable-collection/_shared/merge-iterable.js +0 -16
  924. package/dist/cjs/collection/implementations/iterable-collection/_shared/merge-iterable.js.map +0 -1
  925. package/dist/cjs/collection/implementations/iterable-collection/_shared/pad-end-iterable.js +0 -31
  926. package/dist/cjs/collection/implementations/iterable-collection/_shared/pad-end-iterable.js.map +0 -1
  927. package/dist/cjs/collection/implementations/iterable-collection/_shared/pad-start-iterable.js +0 -31
  928. package/dist/cjs/collection/implementations/iterable-collection/_shared/pad-start-iterable.js.map +0 -1
  929. package/dist/cjs/collection/implementations/iterable-collection/_shared/partion-iterable.js +0 -29
  930. package/dist/cjs/collection/implementations/iterable-collection/_shared/partion-iterable.js.map +0 -1
  931. package/dist/cjs/collection/implementations/iterable-collection/_shared/repeat-iterable.js +0 -22
  932. package/dist/cjs/collection/implementations/iterable-collection/_shared/repeat-iterable.js.map +0 -1
  933. package/dist/cjs/collection/implementations/iterable-collection/_shared/reverse-iterable.js +0 -21
  934. package/dist/cjs/collection/implementations/iterable-collection/_shared/reverse-iterable.js.map +0 -1
  935. package/dist/cjs/collection/implementations/iterable-collection/_shared/shuffle-iterable.js +0 -27
  936. package/dist/cjs/collection/implementations/iterable-collection/_shared/shuffle-iterable.js.map +0 -1
  937. package/dist/cjs/collection/implementations/iterable-collection/_shared/skip-iterable.js +0 -19
  938. package/dist/cjs/collection/implementations/iterable-collection/_shared/skip-iterable.js.map +0 -1
  939. package/dist/cjs/collection/implementations/iterable-collection/_shared/skip-until-iterable.js +0 -24
  940. package/dist/cjs/collection/implementations/iterable-collection/_shared/skip-until-iterable.js.map +0 -1
  941. package/dist/cjs/collection/implementations/iterable-collection/_shared/slice-iterable.js +0 -34
  942. package/dist/cjs/collection/implementations/iterable-collection/_shared/slice-iterable.js.map +0 -1
  943. package/dist/cjs/collection/implementations/iterable-collection/_shared/sliding-iterable.js +0 -29
  944. package/dist/cjs/collection/implementations/iterable-collection/_shared/sliding-iterable.js.map +0 -1
  945. package/dist/cjs/collection/implementations/iterable-collection/_shared/sort-iterable.js +0 -16
  946. package/dist/cjs/collection/implementations/iterable-collection/_shared/sort-iterable.js.map +0 -1
  947. package/dist/cjs/collection/implementations/iterable-collection/_shared/split-iterable.js +0 -38
  948. package/dist/cjs/collection/implementations/iterable-collection/_shared/split-iterable.js.map +0 -1
  949. package/dist/cjs/collection/implementations/iterable-collection/_shared/take-iterable.js +0 -19
  950. package/dist/cjs/collection/implementations/iterable-collection/_shared/take-iterable.js.map +0 -1
  951. package/dist/cjs/collection/implementations/iterable-collection/_shared/take-until-iterable.js +0 -21
  952. package/dist/cjs/collection/implementations/iterable-collection/_shared/take-until-iterable.js.map +0 -1
  953. package/dist/cjs/collection/implementations/iterable-collection/_shared/tap-iterable.js +0 -17
  954. package/dist/cjs/collection/implementations/iterable-collection/_shared/tap-iterable.js.map +0 -1
  955. package/dist/cjs/collection/implementations/iterable-collection/_shared/unique-iterable.js +0 -23
  956. package/dist/cjs/collection/implementations/iterable-collection/_shared/unique-iterable.js.map +0 -1
  957. package/dist/cjs/collection/implementations/iterable-collection/_shared/update-iterable.js +0 -25
  958. package/dist/cjs/collection/implementations/iterable-collection/_shared/update-iterable.js.map +0 -1
  959. package/dist/cjs/collection/implementations/iterable-collection/_shared/when-iterable.js +0 -22
  960. package/dist/cjs/collection/implementations/iterable-collection/_shared/when-iterable.js.map +0 -1
  961. package/dist/cjs/collection/implementations/iterable-collection/_shared/zip-iterable.js +0 -23
  962. package/dist/cjs/collection/implementations/iterable-collection/_shared/zip-iterable.js.map +0 -1
  963. package/dist/cjs/collection/implementations/iterable-collection/iterable-collection.js +0 -554
  964. package/dist/cjs/collection/implementations/iterable-collection/iterable-collection.js.map +0 -1
  965. package/dist/cjs/collection/implementations/list-collection/_module.js +0 -18
  966. package/dist/cjs/collection/implementations/list-collection/_module.js.map +0 -1
  967. package/dist/cjs/collection/implementations/list-collection/list-collection.js +0 -703
  968. package/dist/cjs/collection/implementations/list-collection/list-collection.js.map +0 -1
  969. package/dist/cjs/event-bus/contracts/_module.js +0 -22
  970. package/dist/cjs/event-bus/contracts/_module.js.map +0 -1
  971. package/dist/cjs/event-bus/contracts/_shared.js +0 -11
  972. package/dist/cjs/event-bus/contracts/_shared.js.map +0 -1
  973. package/dist/cjs/event-bus/contracts/event-bus-adapter.contract.js +0 -3
  974. package/dist/cjs/event-bus/contracts/event-bus-adapter.contract.js.map +0 -1
  975. package/dist/cjs/event-bus/contracts/event-bus-factory.contract.js +0 -3
  976. package/dist/cjs/event-bus/contracts/event-bus-factory.contract.js.map +0 -1
  977. package/dist/cjs/event-bus/contracts/event-bus.contract.js +0 -3
  978. package/dist/cjs/event-bus/contracts/event-bus.contract.js.map +0 -1
  979. package/dist/cjs/event-bus/contracts/event-bus.errors.js +0 -72
  980. package/dist/cjs/event-bus/contracts/event-bus.errors.js.map +0 -1
  981. package/dist/cjs/event-bus/implementations/_module.js +0 -20
  982. package/dist/cjs/event-bus/implementations/_module.js.map +0 -1
  983. package/dist/cjs/event-bus/implementations/_shared/_module.js +0 -19
  984. package/dist/cjs/event-bus/implementations/_shared/_module.js.map +0 -1
  985. package/dist/cjs/event-bus/implementations/_shared/event-bus-adapter.test-suite.js +0 -101
  986. package/dist/cjs/event-bus/implementations/_shared/event-bus-adapter.test-suite.js.map +0 -1
  987. package/dist/cjs/event-bus/implementations/_shared/event-bus.test-suite.js +0 -350
  988. package/dist/cjs/event-bus/implementations/_shared/event-bus.test-suite.js.map +0 -1
  989. package/dist/cjs/event-bus/implementations/adapters/_module.js +0 -20
  990. package/dist/cjs/event-bus/implementations/adapters/_module.js.map +0 -1
  991. package/dist/cjs/event-bus/implementations/adapters/memory-event-bus-adapter/_module.js +0 -18
  992. package/dist/cjs/event-bus/implementations/adapters/memory-event-bus-adapter/_module.js.map +0 -1
  993. package/dist/cjs/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.js +0 -37
  994. package/dist/cjs/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.js.map +0 -1
  995. package/dist/cjs/event-bus/implementations/adapters/no-op-event-bus-adapter/_module.js +0 -18
  996. package/dist/cjs/event-bus/implementations/adapters/no-op-event-bus-adapter/_module.js.map +0 -1
  997. package/dist/cjs/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.js +0 -22
  998. package/dist/cjs/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.js.map +0 -1
  999. package/dist/cjs/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module.js +0 -18
  1000. package/dist/cjs/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module.js.map +0 -1
  1001. package/dist/cjs/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js +0 -52
  1002. package/dist/cjs/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js.map +0 -1
  1003. package/dist/cjs/event-bus/implementations/derivables/_module.js +0 -19
  1004. package/dist/cjs/event-bus/implementations/derivables/_module.js.map +0 -1
  1005. package/dist/cjs/event-bus/implementations/derivables/event-bus/_module.js +0 -18
  1006. package/dist/cjs/event-bus/implementations/derivables/event-bus/_module.js.map +0 -1
  1007. package/dist/cjs/event-bus/implementations/derivables/event-bus/event-bus.js +0 -137
  1008. package/dist/cjs/event-bus/implementations/derivables/event-bus/event-bus.js.map +0 -1
  1009. package/dist/cjs/event-bus/implementations/derivables/event-bus-factory/_module.js +0 -18
  1010. package/dist/cjs/event-bus/implementations/derivables/event-bus-factory/_module.js.map +0 -1
  1011. package/dist/cjs/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js +0 -59
  1012. package/dist/cjs/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js.map +0 -1
  1013. package/dist/cjs/lock/contracts/_module.js +0 -24
  1014. package/dist/cjs/lock/contracts/_module.js.map +0 -1
  1015. package/dist/cjs/lock/contracts/database-lock-adapter.contract.js +0 -3
  1016. package/dist/cjs/lock/contracts/database-lock-adapter.contract.js.map +0 -1
  1017. package/dist/cjs/lock/contracts/lock-adapter.contract.js +0 -3
  1018. package/dist/cjs/lock/contracts/lock-adapter.contract.js.map +0 -1
  1019. package/dist/cjs/lock/contracts/lock-provider-factory.contract.js +0 -3
  1020. package/dist/cjs/lock/contracts/lock-provider-factory.contract.js.map +0 -1
  1021. package/dist/cjs/lock/contracts/lock-provider.contract.js +0 -3
  1022. package/dist/cjs/lock/contracts/lock-provider.contract.js.map +0 -1
  1023. package/dist/cjs/lock/contracts/lock.contract.js +0 -3
  1024. package/dist/cjs/lock/contracts/lock.contract.js.map +0 -1
  1025. package/dist/cjs/lock/contracts/lock.errors.js +0 -131
  1026. package/dist/cjs/lock/contracts/lock.errors.js.map +0 -1
  1027. package/dist/cjs/lock/contracts/lock.events.js +0 -44
  1028. package/dist/cjs/lock/contracts/lock.events.js.map +0 -1
  1029. package/dist/cjs/lock/implementations/_module.js +0 -20
  1030. package/dist/cjs/lock/implementations/_module.js.map +0 -1
  1031. package/dist/cjs/lock/implementations/_shared/_module.js +0 -20
  1032. package/dist/cjs/lock/implementations/_shared/_module.js.map +0 -1
  1033. package/dist/cjs/lock/implementations/_shared/database-lock-adapter.test-suite.js +0 -285
  1034. package/dist/cjs/lock/implementations/_shared/database-lock-adapter.test-suite.js.map +0 -1
  1035. package/dist/cjs/lock/implementations/_shared/lock-adapter.test-suite.js +0 -109
  1036. package/dist/cjs/lock/implementations/_shared/lock-adapter.test-suite.js.map +0 -1
  1037. package/dist/cjs/lock/implementations/_shared/lock-provider.test-suite.js +0 -1839
  1038. package/dist/cjs/lock/implementations/_shared/lock-provider.test-suite.js.map +0 -1
  1039. package/dist/cjs/lock/implementations/adapters/_module.js +0 -22
  1040. package/dist/cjs/lock/implementations/adapters/_module.js.map +0 -1
  1041. package/dist/cjs/lock/implementations/adapters/kysely-lock-adapter/_module.js +0 -18
  1042. package/dist/cjs/lock/implementations/adapters/kysely-lock-adapter/_module.js.map +0 -1
  1043. package/dist/cjs/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js +0 -126
  1044. package/dist/cjs/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js.map +0 -1
  1045. package/dist/cjs/lock/implementations/adapters/libsql-lock-adapter/_module.js +0 -18
  1046. package/dist/cjs/lock/implementations/adapters/libsql-lock-adapter/_module.js.map +0 -1
  1047. package/dist/cjs/lock/implementations/adapters/libsql-lock-adapter/libsql-lock-adapter.js +0 -61
  1048. package/dist/cjs/lock/implementations/adapters/libsql-lock-adapter/libsql-lock-adapter.js.map +0 -1
  1049. package/dist/cjs/lock/implementations/adapters/memory-lock-adapter/_module.js +0 -18
  1050. package/dist/cjs/lock/implementations/adapters/memory-lock-adapter/_module.js.map +0 -1
  1051. package/dist/cjs/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js +0 -91
  1052. package/dist/cjs/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js.map +0 -1
  1053. package/dist/cjs/lock/implementations/adapters/mongodb-lock-adapter/_module.js +0 -18
  1054. package/dist/cjs/lock/implementations/adapters/mongodb-lock-adapter/_module.js.map +0 -1
  1055. package/dist/cjs/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js +0 -148
  1056. package/dist/cjs/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js.map +0 -1
  1057. package/dist/cjs/lock/implementations/adapters/redis-lock-adapter/_module.js +0 -18
  1058. package/dist/cjs/lock/implementations/adapters/redis-lock-adapter/_module.js.map +0 -1
  1059. package/dist/cjs/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js +0 -118
  1060. package/dist/cjs/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js.map +0 -1
  1061. package/dist/cjs/lock/implementations/adapters/sqlite-lock-adapter/_module.js +0 -18
  1062. package/dist/cjs/lock/implementations/adapters/sqlite-lock-adapter/_module.js.map +0 -1
  1063. package/dist/cjs/lock/implementations/adapters/sqlite-lock-adapter/sqlite-lock-adapter.js +0 -60
  1064. package/dist/cjs/lock/implementations/adapters/sqlite-lock-adapter/sqlite-lock-adapter.js.map +0 -1
  1065. package/dist/cjs/lock/implementations/derivables/_module.js +0 -19
  1066. package/dist/cjs/lock/implementations/derivables/_module.js.map +0 -1
  1067. package/dist/cjs/lock/implementations/derivables/lock-provider/_module.js +0 -18
  1068. package/dist/cjs/lock/implementations/derivables/lock-provider/_module.js.map +0 -1
  1069. package/dist/cjs/lock/implementations/derivables/lock-provider/database-lock-adapter.js +0 -48
  1070. package/dist/cjs/lock/implementations/derivables/lock-provider/database-lock-adapter.js.map +0 -1
  1071. package/dist/cjs/lock/implementations/derivables/lock-provider/lock-provider.js +0 -172
  1072. package/dist/cjs/lock/implementations/derivables/lock-provider/lock-provider.js.map +0 -1
  1073. package/dist/cjs/lock/implementations/derivables/lock-provider/lock-state.js +0 -58
  1074. package/dist/cjs/lock/implementations/derivables/lock-provider/lock-state.js.map +0 -1
  1075. package/dist/cjs/lock/implementations/derivables/lock-provider/lock.js +0 -299
  1076. package/dist/cjs/lock/implementations/derivables/lock-provider/lock.js.map +0 -1
  1077. package/dist/cjs/lock/implementations/derivables/lock-provider-factory/_module.js +0 -18
  1078. package/dist/cjs/lock/implementations/derivables/lock-provider-factory/_module.js.map +0 -1
  1079. package/dist/cjs/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js +0 -78
  1080. package/dist/cjs/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js.map +0 -1
  1081. package/dist/cjs/serde/contracts/_module.js +0 -23
  1082. package/dist/cjs/serde/contracts/_module.js.map +0 -1
  1083. package/dist/cjs/serde/contracts/deserializer.contract.js +0 -3
  1084. package/dist/cjs/serde/contracts/deserializer.contract.js.map +0 -1
  1085. package/dist/cjs/serde/contracts/flexible-serde.contract.js +0 -3
  1086. package/dist/cjs/serde/contracts/flexible-serde.contract.js.map +0 -1
  1087. package/dist/cjs/serde/contracts/serde.contract.js +0 -3
  1088. package/dist/cjs/serde/contracts/serde.contract.js.map +0 -1
  1089. package/dist/cjs/serde/contracts/serde.errors.js +0 -25
  1090. package/dist/cjs/serde/contracts/serde.errors.js.map +0 -1
  1091. package/dist/cjs/serde/contracts/serializable.contract.js +0 -3
  1092. package/dist/cjs/serde/contracts/serializable.contract.js.map +0 -1
  1093. package/dist/cjs/serde/contracts/serializer.contract.js +0 -3
  1094. package/dist/cjs/serde/contracts/serializer.contract.js.map +0 -1
  1095. package/dist/cjs/serde/implementations/_module.js +0 -23
  1096. package/dist/cjs/serde/implementations/_module.js.map +0 -1
  1097. package/dist/cjs/serde/implementations/_shared/test-utilities/_module.js +0 -19
  1098. package/dist/cjs/serde/implementations/_shared/test-utilities/_module.js.map +0 -1
  1099. package/dist/cjs/serde/implementations/_shared/test-utilities/flexible-serde.test-suite.js +0 -69
  1100. package/dist/cjs/serde/implementations/_shared/test-utilities/flexible-serde.test-suite.js.map +0 -1
  1101. package/dist/cjs/serde/implementations/_shared/test-utilities/serde.test-suite.js +0 -336
  1102. package/dist/cjs/serde/implementations/_shared/test-utilities/serde.test-suite.js.map +0 -1
  1103. package/dist/cjs/serde/implementations/mongodb-serde/_module.js +0 -18
  1104. package/dist/cjs/serde/implementations/mongodb-serde/_module.js.map +0 -1
  1105. package/dist/cjs/serde/implementations/mongodb-serde/mongodb-serde.js +0 -36
  1106. package/dist/cjs/serde/implementations/mongodb-serde/mongodb-serde.js.map +0 -1
  1107. package/dist/cjs/serde/implementations/no-op-serde/_module.js +0 -18
  1108. package/dist/cjs/serde/implementations/no-op-serde/_module.js.map +0 -1
  1109. package/dist/cjs/serde/implementations/no-op-serde/no-op-serde.js +0 -22
  1110. package/dist/cjs/serde/implementations/no-op-serde/no-op-serde.js.map +0 -1
  1111. package/dist/cjs/serde/implementations/redis-serde/_module.js +0 -18
  1112. package/dist/cjs/serde/implementations/redis-serde/_module.js.map +0 -1
  1113. package/dist/cjs/serde/implementations/redis-serde/redis-serde.js +0 -37
  1114. package/dist/cjs/serde/implementations/redis-serde/redis-serde.js.map +0 -1
  1115. package/dist/cjs/serde/implementations/sql-serde/_module.js +0 -18
  1116. package/dist/cjs/serde/implementations/sql-serde/_module.js.map +0 -1
  1117. package/dist/cjs/serde/implementations/sql-serde/sql-serde.js +0 -37
  1118. package/dist/cjs/serde/implementations/sql-serde/sql-serde.js.map +0 -1
  1119. package/dist/cjs/serde/implementations/super-json-serde/_module.js +0 -18
  1120. package/dist/cjs/serde/implementations/super-json-serde/_module.js.map +0 -1
  1121. package/dist/cjs/serde/implementations/super-json-serde/super-json-serde.js +0 -239
  1122. package/dist/cjs/serde/implementations/super-json-serde/super-json-serde.js.map +0 -1
  1123. package/dist/cjs/utilities/_module.js +0 -23
  1124. package/dist/cjs/utilities/_module.js.map +0 -1
  1125. package/dist/cjs/utilities/contracts/_module.js +0 -21
  1126. package/dist/cjs/utilities/contracts/_module.js.map +0 -1
  1127. package/dist/cjs/utilities/contracts/buildable.contract.js +0 -3
  1128. package/dist/cjs/utilities/contracts/buildable.contract.js.map +0 -1
  1129. package/dist/cjs/utilities/contracts/deinitizable.contract.js +0 -3
  1130. package/dist/cjs/utilities/contracts/deinitizable.contract.js.map +0 -1
  1131. package/dist/cjs/utilities/contracts/initizable.contract.js +0 -3
  1132. package/dist/cjs/utilities/contracts/initizable.contract.js.map +0 -1
  1133. package/dist/cjs/utilities/contracts/serialized-error.contract.js +0 -3
  1134. package/dist/cjs/utilities/contracts/serialized-error.contract.js.map +0 -1
  1135. package/dist/cjs/utilities/errors.js +0 -25
  1136. package/dist/cjs/utilities/errors.js.map +0 -1
  1137. package/dist/cjs/utilities/functions.js +0 -43
  1138. package/dist/cjs/utilities/functions.js.map +0 -1
  1139. package/dist/cjs/utilities/kysely/_module.js +0 -18
  1140. package/dist/cjs/utilities/kysely/_module.js.map +0 -1
  1141. package/dist/cjs/utilities/kysely/kysely-table-name-transformer-plugin.js +0 -45
  1142. package/dist/cjs/utilities/kysely/kysely-table-name-transformer-plugin.js.map +0 -1
  1143. package/dist/cjs/utilities/time-span/_module.js +0 -18
  1144. package/dist/cjs/utilities/time-span/_module.js.map +0 -1
  1145. package/dist/cjs/utilities/time-span/time-span.js +0 -111
  1146. package/dist/cjs/utilities/time-span/time-span.js.map +0 -1
  1147. package/dist/cjs/utilities/types.js +0 -3
  1148. package/dist/cjs/utilities/types.js.map +0 -1
  1149. package/dist/esm/_module.js +0 -13
  1150. package/dist/esm/_module.js.map +0 -1
  1151. package/dist/esm/async/_module.js +0 -4
  1152. package/dist/esm/async/_module.js.map +0 -1
  1153. package/dist/esm/async/async.errors.js +0 -27
  1154. package/dist/esm/async/async.errors.js.map +0 -1
  1155. package/dist/esm/async/backof-policies/_module.js +0 -6
  1156. package/dist/esm/async/backof-policies/_module.js.map +0 -1
  1157. package/dist/esm/async/backof-policies/_shared.js +0 -4
  1158. package/dist/esm/async/backof-policies/_shared.js.map +0 -1
  1159. package/dist/esm/async/backof-policies/constant-backoff-policy/_module.js +0 -2
  1160. package/dist/esm/async/backof-policies/constant-backoff-policy/_module.js.map +0 -1
  1161. package/dist/esm/async/backof-policies/constant-backoff-policy/constant-backoff-policy.js +0 -16
  1162. package/dist/esm/async/backof-policies/constant-backoff-policy/constant-backoff-policy.js.map +0 -1
  1163. package/dist/esm/async/backof-policies/exponential-backoff-policy/_module.js +0 -2
  1164. package/dist/esm/async/backof-policies/exponential-backoff-policy/_module.js.map +0 -1
  1165. package/dist/esm/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js +0 -20
  1166. package/dist/esm/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js.map +0 -1
  1167. package/dist/esm/async/backof-policies/linear-backoff-policy/_module.js +0 -2
  1168. package/dist/esm/async/backof-policies/linear-backoff-policy/_module.js.map +0 -1
  1169. package/dist/esm/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js +0 -20
  1170. package/dist/esm/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js.map +0 -1
  1171. package/dist/esm/async/backof-policies/polynomial-backoff-policy/_module.js +0 -2
  1172. package/dist/esm/async/backof-policies/polynomial-backoff-policy/_module.js.map +0 -1
  1173. package/dist/esm/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js +0 -20
  1174. package/dist/esm/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js.map +0 -1
  1175. package/dist/esm/async/utilities/_module.js +0 -6
  1176. package/dist/esm/async/utilities/_module.js.map +0 -1
  1177. package/dist/esm/async/utilities/abort/_module.js +0 -3
  1178. package/dist/esm/async/utilities/abort/_module.js.map +0 -1
  1179. package/dist/esm/async/utilities/abort/abort-and-fail.js +0 -42
  1180. package/dist/esm/async/utilities/abort/abort-and-fail.js.map +0 -1
  1181. package/dist/esm/async/utilities/abort/abort.js +0 -15
  1182. package/dist/esm/async/utilities/abort/abort.js.map +0 -1
  1183. package/dist/esm/async/utilities/delay/_module.js +0 -2
  1184. package/dist/esm/async/utilities/delay/_module.js.map +0 -1
  1185. package/dist/esm/async/utilities/delay/delay.js +0 -17
  1186. package/dist/esm/async/utilities/delay/delay.js.map +0 -1
  1187. package/dist/esm/async/utilities/lazy-promise/_module.js +0 -2
  1188. package/dist/esm/async/utilities/lazy-promise/_module.js.map +0 -1
  1189. package/dist/esm/async/utilities/lazy-promise/lazy-promise.js +0 -107
  1190. package/dist/esm/async/utilities/lazy-promise/lazy-promise.js.map +0 -1
  1191. package/dist/esm/async/utilities/retry/_module.js +0 -3
  1192. package/dist/esm/async/utilities/retry/_module.js.map +0 -1
  1193. package/dist/esm/async/utilities/retry/retry-or-fail.js +0 -33
  1194. package/dist/esm/async/utilities/retry/retry-or-fail.js.map +0 -1
  1195. package/dist/esm/async/utilities/retry/retry.js +0 -15
  1196. package/dist/esm/async/utilities/retry/retry.js.map +0 -1
  1197. package/dist/esm/async/utilities/timeout/_module.js +0 -3
  1198. package/dist/esm/async/utilities/timeout/_module.js.map +0 -1
  1199. package/dist/esm/async/utilities/timeout/timeout-and-fail.js +0 -22
  1200. package/dist/esm/async/utilities/timeout/timeout-and-fail.js.map +0 -1
  1201. package/dist/esm/async/utilities/timeout/timeout.js +0 -15
  1202. package/dist/esm/async/utilities/timeout/timeout.js.map +0 -1
  1203. package/dist/esm/cache/contracts/_module.js +0 -6
  1204. package/dist/esm/cache/contracts/_module.js.map +0 -1
  1205. package/dist/esm/cache/contracts/cache-adapter.contract.js +0 -1
  1206. package/dist/esm/cache/contracts/cache-adapter.contract.js.map +0 -1
  1207. package/dist/esm/cache/contracts/cache-factory.contract.js +0 -1
  1208. package/dist/esm/cache/contracts/cache-factory.contract.js.map +0 -1
  1209. package/dist/esm/cache/contracts/cache.contract.js +0 -1
  1210. package/dist/esm/cache/contracts/cache.contract.js.map +0 -1
  1211. package/dist/esm/cache/contracts/cache.errors.js +0 -56
  1212. package/dist/esm/cache/contracts/cache.errors.js.map +0 -1
  1213. package/dist/esm/cache/contracts/cache.events.js +0 -37
  1214. package/dist/esm/cache/contracts/cache.events.js.map +0 -1
  1215. package/dist/esm/cache/implementations/_module.js +0 -4
  1216. package/dist/esm/cache/implementations/_module.js.map +0 -1
  1217. package/dist/esm/cache/implementations/_shared/_module.js +0 -3
  1218. package/dist/esm/cache/implementations/_shared/_module.js.map +0 -1
  1219. package/dist/esm/cache/implementations/_shared/cache-adapter.test-suite.js +0 -250
  1220. package/dist/esm/cache/implementations/_shared/cache-adapter.test-suite.js.map +0 -1
  1221. package/dist/esm/cache/implementations/_shared/cache.test-suite.js +0 -1736
  1222. package/dist/esm/cache/implementations/_shared/cache.test-suite.js.map +0 -1
  1223. package/dist/esm/cache/implementations/adapters/_module.js +0 -7
  1224. package/dist/esm/cache/implementations/adapters/_module.js.map +0 -1
  1225. package/dist/esm/cache/implementations/adapters/kysely-sqlite-cache-adapter/_module.js +0 -2
  1226. package/dist/esm/cache/implementations/adapters/kysely-sqlite-cache-adapter/_module.js.map +0 -1
  1227. package/dist/esm/cache/implementations/adapters/kysely-sqlite-cache-adapter/kysely-sqlite-cache-adapter.js +0 -310
  1228. package/dist/esm/cache/implementations/adapters/kysely-sqlite-cache-adapter/kysely-sqlite-cache-adapter.js.map +0 -1
  1229. package/dist/esm/cache/implementations/adapters/libsql-cache-adapter/_module.js +0 -2
  1230. package/dist/esm/cache/implementations/adapters/libsql-cache-adapter/_module.js.map +0 -1
  1231. package/dist/esm/cache/implementations/adapters/libsql-cache-adapter/libsql-cache-adapter.js +0 -64
  1232. package/dist/esm/cache/implementations/adapters/libsql-cache-adapter/libsql-cache-adapter.js.map +0 -1
  1233. package/dist/esm/cache/implementations/adapters/memory-cache-adapter/_module.js +0 -2
  1234. package/dist/esm/cache/implementations/adapters/memory-cache-adapter/_module.js.map +0 -1
  1235. package/dist/esm/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js +0 -87
  1236. package/dist/esm/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js.map +0 -1
  1237. package/dist/esm/cache/implementations/adapters/mongodb-cache-adapter/_module.js +0 -2
  1238. package/dist/esm/cache/implementations/adapters/mongodb-cache-adapter/_module.js.map +0 -1
  1239. package/dist/esm/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js +0 -286
  1240. package/dist/esm/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js.map +0 -1
  1241. package/dist/esm/cache/implementations/adapters/no-op-cache-adapter/_module.js +0 -2
  1242. package/dist/esm/cache/implementations/adapters/no-op-cache-adapter/_module.js.map +0 -1
  1243. package/dist/esm/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js +0 -30
  1244. package/dist/esm/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js.map +0 -1
  1245. package/dist/esm/cache/implementations/adapters/redis-cache-adapter/_module.js +0 -2
  1246. package/dist/esm/cache/implementations/adapters/redis-cache-adapter/_module.js.map +0 -1
  1247. package/dist/esm/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js +0 -167
  1248. package/dist/esm/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js.map +0 -1
  1249. package/dist/esm/cache/implementations/adapters/sqlite-cache-adapter/_module.js +0 -2
  1250. package/dist/esm/cache/implementations/adapters/sqlite-cache-adapter/_module.js.map +0 -1
  1251. package/dist/esm/cache/implementations/adapters/sqlite-cache-adapter/sqlite-cache-adapter.js +0 -63
  1252. package/dist/esm/cache/implementations/adapters/sqlite-cache-adapter/sqlite-cache-adapter.js.map +0 -1
  1253. package/dist/esm/cache/implementations/derivables/_module.js +0 -3
  1254. package/dist/esm/cache/implementations/derivables/_module.js.map +0 -1
  1255. package/dist/esm/cache/implementations/derivables/cache/_module.js +0 -2
  1256. package/dist/esm/cache/implementations/derivables/cache/_module.js.map +0 -1
  1257. package/dist/esm/cache/implementations/derivables/cache/cache.js +0 -549
  1258. package/dist/esm/cache/implementations/derivables/cache/cache.js.map +0 -1
  1259. package/dist/esm/cache/implementations/derivables/cache-factory/_module.js +0 -2
  1260. package/dist/esm/cache/implementations/derivables/cache-factory/_module.js.map +0 -1
  1261. package/dist/esm/cache/implementations/derivables/cache-factory/cache-factory.js +0 -66
  1262. package/dist/esm/cache/implementations/derivables/cache-factory/cache-factory.js.map +0 -1
  1263. package/dist/esm/collection/contracts/_module.js +0 -5
  1264. package/dist/esm/collection/contracts/_module.js.map +0 -1
  1265. package/dist/esm/collection/contracts/_shared.js +0 -1
  1266. package/dist/esm/collection/contracts/_shared.js.map +0 -1
  1267. package/dist/esm/collection/contracts/async-collection.contract.js +0 -1
  1268. package/dist/esm/collection/contracts/async-collection.contract.js.map +0 -1
  1269. package/dist/esm/collection/contracts/collection.contract.js +0 -1
  1270. package/dist/esm/collection/contracts/collection.contract.js.map +0 -1
  1271. package/dist/esm/collection/contracts/collection.errors.js +0 -37
  1272. package/dist/esm/collection/contracts/collection.errors.js.map +0 -1
  1273. package/dist/esm/collection/implementations/_module.js +0 -5
  1274. package/dist/esm/collection/implementations/_module.js.map +0 -1
  1275. package/dist/esm/collection/implementations/_shared.js +0 -25
  1276. package/dist/esm/collection/implementations/_shared.js.map +0 -1
  1277. package/dist/esm/collection/implementations/async-iterable-collection/_module.js +0 -2
  1278. package/dist/esm/collection/implementations/async-iterable-collection/_module.js.map +0 -1
  1279. package/dist/esm/collection/implementations/async-iterable-collection/_shared/_module.js +0 -37
  1280. package/dist/esm/collection/implementations/async-iterable-collection/_shared/_module.js.map +0 -1
  1281. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.js +0 -31
  1282. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.js.map +0 -1
  1283. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.js +0 -28
  1284. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.js.map +0 -1
  1285. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.js +0 -18
  1286. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.js.map +0 -1
  1287. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.js +0 -23
  1288. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.js.map +0 -1
  1289. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.js +0 -31
  1290. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.js.map +0 -1
  1291. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-delay-iterable.js +0 -23
  1292. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-delay-iterable.js.map +0 -1
  1293. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.js +0 -14
  1294. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.js.map +0 -1
  1295. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.js +0 -16
  1296. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.js.map +0 -1
  1297. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.js +0 -14
  1298. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.js.map +0 -1
  1299. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.js +0 -25
  1300. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.js.map +0 -1
  1301. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.js +0 -23
  1302. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.js.map +0 -1
  1303. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.js +0 -23
  1304. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.js.map +0 -1
  1305. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-map-iterable.js +0 -14
  1306. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-map-iterable.js.map +0 -1
  1307. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.js +0 -20
  1308. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.js.map +0 -1
  1309. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.js +0 -27
  1310. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.js.map +0 -1
  1311. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.js +0 -27
  1312. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.js.map +0 -1
  1313. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.js +0 -25
  1314. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.js.map +0 -1
  1315. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.js +0 -18
  1316. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.js.map +0 -1
  1317. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-retry-iterable.js +0 -29
  1318. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-retry-iterable.js.map +0 -1
  1319. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.js +0 -17
  1320. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.js.map +0 -1
  1321. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.js +0 -23
  1322. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.js.map +0 -1
  1323. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.js +0 -15
  1324. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.js.map +0 -1
  1325. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.js +0 -21
  1326. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.js.map +0 -1
  1327. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.js +0 -30
  1328. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.js.map +0 -1
  1329. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.js +0 -25
  1330. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.js.map +0 -1
  1331. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.js +0 -12
  1332. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.js.map +0 -1
  1333. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-split-iterable.js +0 -34
  1334. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-split-iterable.js.map +0 -1
  1335. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-take-iterable.js +0 -15
  1336. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-take-iterable.js.map +0 -1
  1337. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-take-until-abort-iterable.js +0 -32
  1338. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-take-until-abort-iterable.js.map +0 -1
  1339. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.js +0 -17
  1340. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.js.map +0 -1
  1341. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-take-until-timeout-iterable.js +0 -44
  1342. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-take-until-timeout-iterable.js.map +0 -1
  1343. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.js +0 -13
  1344. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.js.map +0 -1
  1345. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.js +0 -19
  1346. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.js.map +0 -1
  1347. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-update-iterable.js +0 -21
  1348. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-update-iterable.js.map +0 -1
  1349. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-when-iterable.js +0 -18
  1350. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-when-iterable.js.map +0 -1
  1351. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.js +0 -33
  1352. package/dist/esm/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.js.map +0 -1
  1353. package/dist/esm/collection/implementations/async-iterable-collection/async-iterable-collection.js +0 -629
  1354. package/dist/esm/collection/implementations/async-iterable-collection/async-iterable-collection.js.map +0 -1
  1355. package/dist/esm/collection/implementations/iterable-collection/_module.js +0 -2
  1356. package/dist/esm/collection/implementations/iterable-collection/_module.js.map +0 -1
  1357. package/dist/esm/collection/implementations/iterable-collection/_shared/_module.js +0 -33
  1358. package/dist/esm/collection/implementations/iterable-collection/_shared/_module.js.map +0 -1
  1359. package/dist/esm/collection/implementations/iterable-collection/_shared/chunk-iterable.js +0 -31
  1360. package/dist/esm/collection/implementations/iterable-collection/_shared/chunk-iterable.js.map +0 -1
  1361. package/dist/esm/collection/implementations/iterable-collection/_shared/chunk-while-iterable.js +0 -28
  1362. package/dist/esm/collection/implementations/iterable-collection/_shared/chunk-while-iterable.js.map +0 -1
  1363. package/dist/esm/collection/implementations/iterable-collection/_shared/collapse-iterable.js +0 -18
  1364. package/dist/esm/collection/implementations/iterable-collection/_shared/collapse-iterable.js.map +0 -1
  1365. package/dist/esm/collection/implementations/iterable-collection/_shared/count-by-iterable.js +0 -23
  1366. package/dist/esm/collection/implementations/iterable-collection/_shared/count-by-iterable.js.map +0 -1
  1367. package/dist/esm/collection/implementations/iterable-collection/_shared/cross-join-iterable.js +0 -33
  1368. package/dist/esm/collection/implementations/iterable-collection/_shared/cross-join-iterable.js.map +0 -1
  1369. package/dist/esm/collection/implementations/iterable-collection/_shared/entries-iterable.js +0 -14
  1370. package/dist/esm/collection/implementations/iterable-collection/_shared/entries-iterable.js.map +0 -1
  1371. package/dist/esm/collection/implementations/iterable-collection/_shared/filter-iterable.js +0 -16
  1372. package/dist/esm/collection/implementations/iterable-collection/_shared/filter-iterable.js.map +0 -1
  1373. package/dist/esm/collection/implementations/iterable-collection/_shared/flat-map-iterable.js +0 -14
  1374. package/dist/esm/collection/implementations/iterable-collection/_shared/flat-map-iterable.js.map +0 -1
  1375. package/dist/esm/collection/implementations/iterable-collection/_shared/group-by-iterable.js +0 -25
  1376. package/dist/esm/collection/implementations/iterable-collection/_shared/group-by-iterable.js.map +0 -1
  1377. package/dist/esm/collection/implementations/iterable-collection/_shared/insert-after-iterable.js +0 -21
  1378. package/dist/esm/collection/implementations/iterable-collection/_shared/insert-after-iterable.js.map +0 -1
  1379. package/dist/esm/collection/implementations/iterable-collection/_shared/insert-before-iterable.js +0 -21
  1380. package/dist/esm/collection/implementations/iterable-collection/_shared/insert-before-iterable.js.map +0 -1
  1381. package/dist/esm/collection/implementations/iterable-collection/_shared/map-iterable.js +0 -14
  1382. package/dist/esm/collection/implementations/iterable-collection/_shared/map-iterable.js.map +0 -1
  1383. package/dist/esm/collection/implementations/iterable-collection/_shared/merge-iterable.js +0 -12
  1384. package/dist/esm/collection/implementations/iterable-collection/_shared/merge-iterable.js.map +0 -1
  1385. package/dist/esm/collection/implementations/iterable-collection/_shared/pad-end-iterable.js +0 -27
  1386. package/dist/esm/collection/implementations/iterable-collection/_shared/pad-end-iterable.js.map +0 -1
  1387. package/dist/esm/collection/implementations/iterable-collection/_shared/pad-start-iterable.js +0 -27
  1388. package/dist/esm/collection/implementations/iterable-collection/_shared/pad-start-iterable.js.map +0 -1
  1389. package/dist/esm/collection/implementations/iterable-collection/_shared/partion-iterable.js +0 -25
  1390. package/dist/esm/collection/implementations/iterable-collection/_shared/partion-iterable.js.map +0 -1
  1391. package/dist/esm/collection/implementations/iterable-collection/_shared/repeat-iterable.js +0 -18
  1392. package/dist/esm/collection/implementations/iterable-collection/_shared/repeat-iterable.js.map +0 -1
  1393. package/dist/esm/collection/implementations/iterable-collection/_shared/reverse-iterable.js +0 -17
  1394. package/dist/esm/collection/implementations/iterable-collection/_shared/reverse-iterable.js.map +0 -1
  1395. package/dist/esm/collection/implementations/iterable-collection/_shared/shuffle-iterable.js +0 -23
  1396. package/dist/esm/collection/implementations/iterable-collection/_shared/shuffle-iterable.js.map +0 -1
  1397. package/dist/esm/collection/implementations/iterable-collection/_shared/skip-iterable.js +0 -15
  1398. package/dist/esm/collection/implementations/iterable-collection/_shared/skip-iterable.js.map +0 -1
  1399. package/dist/esm/collection/implementations/iterable-collection/_shared/skip-until-iterable.js +0 -20
  1400. package/dist/esm/collection/implementations/iterable-collection/_shared/skip-until-iterable.js.map +0 -1
  1401. package/dist/esm/collection/implementations/iterable-collection/_shared/slice-iterable.js +0 -30
  1402. package/dist/esm/collection/implementations/iterable-collection/_shared/slice-iterable.js.map +0 -1
  1403. package/dist/esm/collection/implementations/iterable-collection/_shared/sliding-iterable.js +0 -25
  1404. package/dist/esm/collection/implementations/iterable-collection/_shared/sliding-iterable.js.map +0 -1
  1405. package/dist/esm/collection/implementations/iterable-collection/_shared/sort-iterable.js +0 -12
  1406. package/dist/esm/collection/implementations/iterable-collection/_shared/sort-iterable.js.map +0 -1
  1407. package/dist/esm/collection/implementations/iterable-collection/_shared/split-iterable.js +0 -34
  1408. package/dist/esm/collection/implementations/iterable-collection/_shared/split-iterable.js.map +0 -1
  1409. package/dist/esm/collection/implementations/iterable-collection/_shared/take-iterable.js +0 -15
  1410. package/dist/esm/collection/implementations/iterable-collection/_shared/take-iterable.js.map +0 -1
  1411. package/dist/esm/collection/implementations/iterable-collection/_shared/take-until-iterable.js +0 -17
  1412. package/dist/esm/collection/implementations/iterable-collection/_shared/take-until-iterable.js.map +0 -1
  1413. package/dist/esm/collection/implementations/iterable-collection/_shared/tap-iterable.js +0 -13
  1414. package/dist/esm/collection/implementations/iterable-collection/_shared/tap-iterable.js.map +0 -1
  1415. package/dist/esm/collection/implementations/iterable-collection/_shared/unique-iterable.js +0 -19
  1416. package/dist/esm/collection/implementations/iterable-collection/_shared/unique-iterable.js.map +0 -1
  1417. package/dist/esm/collection/implementations/iterable-collection/_shared/update-iterable.js +0 -21
  1418. package/dist/esm/collection/implementations/iterable-collection/_shared/update-iterable.js.map +0 -1
  1419. package/dist/esm/collection/implementations/iterable-collection/_shared/when-iterable.js +0 -18
  1420. package/dist/esm/collection/implementations/iterable-collection/_shared/when-iterable.js.map +0 -1
  1421. package/dist/esm/collection/implementations/iterable-collection/_shared/zip-iterable.js +0 -19
  1422. package/dist/esm/collection/implementations/iterable-collection/_shared/zip-iterable.js.map +0 -1
  1423. package/dist/esm/collection/implementations/iterable-collection/iterable-collection.js +0 -550
  1424. package/dist/esm/collection/implementations/iterable-collection/iterable-collection.js.map +0 -1
  1425. package/dist/esm/collection/implementations/list-collection/_module.js +0 -2
  1426. package/dist/esm/collection/implementations/list-collection/_module.js.map +0 -1
  1427. package/dist/esm/collection/implementations/list-collection/list-collection.js +0 -699
  1428. package/dist/esm/collection/implementations/list-collection/list-collection.js.map +0 -1
  1429. package/dist/esm/event-bus/contracts/_module.js +0 -6
  1430. package/dist/esm/event-bus/contracts/_module.js.map +0 -1
  1431. package/dist/esm/event-bus/contracts/_shared.js +0 -7
  1432. package/dist/esm/event-bus/contracts/_shared.js.map +0 -1
  1433. package/dist/esm/event-bus/contracts/event-bus-adapter.contract.js +0 -1
  1434. package/dist/esm/event-bus/contracts/event-bus-adapter.contract.js.map +0 -1
  1435. package/dist/esm/event-bus/contracts/event-bus-factory.contract.js +0 -1
  1436. package/dist/esm/event-bus/contracts/event-bus-factory.contract.js.map +0 -1
  1437. package/dist/esm/event-bus/contracts/event-bus.contract.js +0 -1
  1438. package/dist/esm/event-bus/contracts/event-bus.contract.js.map +0 -1
  1439. package/dist/esm/event-bus/contracts/event-bus.errors.js +0 -63
  1440. package/dist/esm/event-bus/contracts/event-bus.errors.js.map +0 -1
  1441. package/dist/esm/event-bus/implementations/_module.js +0 -4
  1442. package/dist/esm/event-bus/implementations/_module.js.map +0 -1
  1443. package/dist/esm/event-bus/implementations/_shared/_module.js +0 -3
  1444. package/dist/esm/event-bus/implementations/_shared/_module.js.map +0 -1
  1445. package/dist/esm/event-bus/implementations/_shared/event-bus-adapter.test-suite.js +0 -98
  1446. package/dist/esm/event-bus/implementations/_shared/event-bus-adapter.test-suite.js.map +0 -1
  1447. package/dist/esm/event-bus/implementations/_shared/event-bus.test-suite.js +0 -347
  1448. package/dist/esm/event-bus/implementations/_shared/event-bus.test-suite.js.map +0 -1
  1449. package/dist/esm/event-bus/implementations/adapters/_module.js +0 -4
  1450. package/dist/esm/event-bus/implementations/adapters/_module.js.map +0 -1
  1451. package/dist/esm/event-bus/implementations/adapters/memory-event-bus-adapter/_module.js +0 -2
  1452. package/dist/esm/event-bus/implementations/adapters/memory-event-bus-adapter/_module.js.map +0 -1
  1453. package/dist/esm/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.js +0 -33
  1454. package/dist/esm/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.js.map +0 -1
  1455. package/dist/esm/event-bus/implementations/adapters/no-op-event-bus-adapter/_module.js +0 -2
  1456. package/dist/esm/event-bus/implementations/adapters/no-op-event-bus-adapter/_module.js.map +0 -1
  1457. package/dist/esm/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.js +0 -18
  1458. package/dist/esm/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.js.map +0 -1
  1459. package/dist/esm/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module.js +0 -2
  1460. package/dist/esm/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module.js.map +0 -1
  1461. package/dist/esm/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js +0 -48
  1462. package/dist/esm/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js.map +0 -1
  1463. package/dist/esm/event-bus/implementations/derivables/_module.js +0 -3
  1464. package/dist/esm/event-bus/implementations/derivables/_module.js.map +0 -1
  1465. package/dist/esm/event-bus/implementations/derivables/event-bus/_module.js +0 -2
  1466. package/dist/esm/event-bus/implementations/derivables/event-bus/_module.js.map +0 -1
  1467. package/dist/esm/event-bus/implementations/derivables/event-bus/event-bus.js +0 -133
  1468. package/dist/esm/event-bus/implementations/derivables/event-bus/event-bus.js.map +0 -1
  1469. package/dist/esm/event-bus/implementations/derivables/event-bus-factory/_module.js +0 -2
  1470. package/dist/esm/event-bus/implementations/derivables/event-bus-factory/_module.js.map +0 -1
  1471. package/dist/esm/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js +0 -55
  1472. package/dist/esm/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js.map +0 -1
  1473. package/dist/esm/lock/contracts/_module.js +0 -8
  1474. package/dist/esm/lock/contracts/_module.js.map +0 -1
  1475. package/dist/esm/lock/contracts/database-lock-adapter.contract.js +0 -1
  1476. package/dist/esm/lock/contracts/database-lock-adapter.contract.js.map +0 -1
  1477. package/dist/esm/lock/contracts/lock-adapter.contract.js +0 -1
  1478. package/dist/esm/lock/contracts/lock-adapter.contract.js.map +0 -1
  1479. package/dist/esm/lock/contracts/lock-provider-factory.contract.js +0 -1
  1480. package/dist/esm/lock/contracts/lock-provider-factory.contract.js.map +0 -1
  1481. package/dist/esm/lock/contracts/lock-provider.contract.js +0 -1
  1482. package/dist/esm/lock/contracts/lock-provider.contract.js.map +0 -1
  1483. package/dist/esm/lock/contracts/lock.contract.js +0 -1
  1484. package/dist/esm/lock/contracts/lock.contract.js.map +0 -1
  1485. package/dist/esm/lock/contracts/lock.errors.js +0 -120
  1486. package/dist/esm/lock/contracts/lock.errors.js.map +0 -1
  1487. package/dist/esm/lock/contracts/lock.events.js +0 -32
  1488. package/dist/esm/lock/contracts/lock.events.js.map +0 -1
  1489. package/dist/esm/lock/implementations/_module.js +0 -4
  1490. package/dist/esm/lock/implementations/_module.js.map +0 -1
  1491. package/dist/esm/lock/implementations/_shared/_module.js +0 -4
  1492. package/dist/esm/lock/implementations/_shared/_module.js.map +0 -1
  1493. package/dist/esm/lock/implementations/_shared/database-lock-adapter.test-suite.js +0 -282
  1494. package/dist/esm/lock/implementations/_shared/database-lock-adapter.test-suite.js.map +0 -1
  1495. package/dist/esm/lock/implementations/_shared/lock-adapter.test-suite.js +0 -106
  1496. package/dist/esm/lock/implementations/_shared/lock-adapter.test-suite.js.map +0 -1
  1497. package/dist/esm/lock/implementations/_shared/lock-provider.test-suite.js +0 -1836
  1498. package/dist/esm/lock/implementations/_shared/lock-provider.test-suite.js.map +0 -1
  1499. package/dist/esm/lock/implementations/adapters/_module.js +0 -6
  1500. package/dist/esm/lock/implementations/adapters/_module.js.map +0 -1
  1501. package/dist/esm/lock/implementations/adapters/kysely-lock-adapter/_module.js +0 -2
  1502. package/dist/esm/lock/implementations/adapters/kysely-lock-adapter/_module.js.map +0 -1
  1503. package/dist/esm/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js +0 -122
  1504. package/dist/esm/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js.map +0 -1
  1505. package/dist/esm/lock/implementations/adapters/libsql-lock-adapter/_module.js +0 -2
  1506. package/dist/esm/lock/implementations/adapters/libsql-lock-adapter/_module.js.map +0 -1
  1507. package/dist/esm/lock/implementations/adapters/libsql-lock-adapter/libsql-lock-adapter.js +0 -57
  1508. package/dist/esm/lock/implementations/adapters/libsql-lock-adapter/libsql-lock-adapter.js.map +0 -1
  1509. package/dist/esm/lock/implementations/adapters/memory-lock-adapter/_module.js +0 -2
  1510. package/dist/esm/lock/implementations/adapters/memory-lock-adapter/_module.js.map +0 -1
  1511. package/dist/esm/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js +0 -87
  1512. package/dist/esm/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js.map +0 -1
  1513. package/dist/esm/lock/implementations/adapters/mongodb-lock-adapter/_module.js +0 -2
  1514. package/dist/esm/lock/implementations/adapters/mongodb-lock-adapter/_module.js.map +0 -1
  1515. package/dist/esm/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js +0 -144
  1516. package/dist/esm/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js.map +0 -1
  1517. package/dist/esm/lock/implementations/adapters/redis-lock-adapter/_module.js +0 -2
  1518. package/dist/esm/lock/implementations/adapters/redis-lock-adapter/_module.js.map +0 -1
  1519. package/dist/esm/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js +0 -114
  1520. package/dist/esm/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js.map +0 -1
  1521. package/dist/esm/lock/implementations/adapters/sqlite-lock-adapter/_module.js +0 -2
  1522. package/dist/esm/lock/implementations/adapters/sqlite-lock-adapter/_module.js.map +0 -1
  1523. package/dist/esm/lock/implementations/adapters/sqlite-lock-adapter/sqlite-lock-adapter.js +0 -56
  1524. package/dist/esm/lock/implementations/adapters/sqlite-lock-adapter/sqlite-lock-adapter.js.map +0 -1
  1525. package/dist/esm/lock/implementations/derivables/_module.js +0 -3
  1526. package/dist/esm/lock/implementations/derivables/_module.js.map +0 -1
  1527. package/dist/esm/lock/implementations/derivables/lock-provider/_module.js +0 -2
  1528. package/dist/esm/lock/implementations/derivables/lock-provider/_module.js.map +0 -1
  1529. package/dist/esm/lock/implementations/derivables/lock-provider/database-lock-adapter.js +0 -44
  1530. package/dist/esm/lock/implementations/derivables/lock-provider/database-lock-adapter.js.map +0 -1
  1531. package/dist/esm/lock/implementations/derivables/lock-provider/lock-provider.js +0 -168
  1532. package/dist/esm/lock/implementations/derivables/lock-provider/lock-provider.js.map +0 -1
  1533. package/dist/esm/lock/implementations/derivables/lock-provider/lock-state.js +0 -54
  1534. package/dist/esm/lock/implementations/derivables/lock-provider/lock-state.js.map +0 -1
  1535. package/dist/esm/lock/implementations/derivables/lock-provider/lock.js +0 -295
  1536. package/dist/esm/lock/implementations/derivables/lock-provider/lock.js.map +0 -1
  1537. package/dist/esm/lock/implementations/derivables/lock-provider-factory/_module.js +0 -2
  1538. package/dist/esm/lock/implementations/derivables/lock-provider-factory/_module.js.map +0 -1
  1539. package/dist/esm/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js +0 -74
  1540. package/dist/esm/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js.map +0 -1
  1541. package/dist/esm/serde/contracts/_module.js +0 -7
  1542. package/dist/esm/serde/contracts/_module.js.map +0 -1
  1543. package/dist/esm/serde/contracts/deserializer.contract.js +0 -1
  1544. package/dist/esm/serde/contracts/deserializer.contract.js.map +0 -1
  1545. package/dist/esm/serde/contracts/flexible-serde.contract.js +0 -1
  1546. package/dist/esm/serde/contracts/flexible-serde.contract.js.map +0 -1
  1547. package/dist/esm/serde/contracts/serde.contract.js +0 -1
  1548. package/dist/esm/serde/contracts/serde.contract.js.map +0 -1
  1549. package/dist/esm/serde/contracts/serde.errors.js +0 -19
  1550. package/dist/esm/serde/contracts/serde.errors.js.map +0 -1
  1551. package/dist/esm/serde/contracts/serializable.contract.js +0 -1
  1552. package/dist/esm/serde/contracts/serializable.contract.js.map +0 -1
  1553. package/dist/esm/serde/contracts/serializer.contract.js +0 -1
  1554. package/dist/esm/serde/contracts/serializer.contract.js.map +0 -1
  1555. package/dist/esm/serde/implementations/_module.js +0 -7
  1556. package/dist/esm/serde/implementations/_module.js.map +0 -1
  1557. package/dist/esm/serde/implementations/_shared/test-utilities/_module.js +0 -3
  1558. package/dist/esm/serde/implementations/_shared/test-utilities/_module.js.map +0 -1
  1559. package/dist/esm/serde/implementations/_shared/test-utilities/flexible-serde.test-suite.js +0 -66
  1560. package/dist/esm/serde/implementations/_shared/test-utilities/flexible-serde.test-suite.js.map +0 -1
  1561. package/dist/esm/serde/implementations/_shared/test-utilities/serde.test-suite.js +0 -333
  1562. package/dist/esm/serde/implementations/_shared/test-utilities/serde.test-suite.js.map +0 -1
  1563. package/dist/esm/serde/implementations/mongodb-serde/_module.js +0 -2
  1564. package/dist/esm/serde/implementations/mongodb-serde/_module.js.map +0 -1
  1565. package/dist/esm/serde/implementations/mongodb-serde/mongodb-serde.js +0 -32
  1566. package/dist/esm/serde/implementations/mongodb-serde/mongodb-serde.js.map +0 -1
  1567. package/dist/esm/serde/implementations/no-op-serde/_module.js +0 -2
  1568. package/dist/esm/serde/implementations/no-op-serde/_module.js.map +0 -1
  1569. package/dist/esm/serde/implementations/no-op-serde/no-op-serde.js +0 -18
  1570. package/dist/esm/serde/implementations/no-op-serde/no-op-serde.js.map +0 -1
  1571. package/dist/esm/serde/implementations/redis-serde/_module.js +0 -2
  1572. package/dist/esm/serde/implementations/redis-serde/_module.js.map +0 -1
  1573. package/dist/esm/serde/implementations/redis-serde/redis-serde.js +0 -33
  1574. package/dist/esm/serde/implementations/redis-serde/redis-serde.js.map +0 -1
  1575. package/dist/esm/serde/implementations/sql-serde/_module.js +0 -2
  1576. package/dist/esm/serde/implementations/sql-serde/_module.js.map +0 -1
  1577. package/dist/esm/serde/implementations/sql-serde/sql-serde.js +0 -33
  1578. package/dist/esm/serde/implementations/sql-serde/sql-serde.js.map +0 -1
  1579. package/dist/esm/serde/implementations/super-json-serde/_module.js +0 -2
  1580. package/dist/esm/serde/implementations/super-json-serde/_module.js.map +0 -1
  1581. package/dist/esm/serde/implementations/super-json-serde/super-json-serde.js +0 -235
  1582. package/dist/esm/serde/implementations/super-json-serde/super-json-serde.js.map +0 -1
  1583. package/dist/esm/utilities/_module.js +0 -7
  1584. package/dist/esm/utilities/_module.js.map +0 -1
  1585. package/dist/esm/utilities/contracts/_module.js +0 -5
  1586. package/dist/esm/utilities/contracts/_module.js.map +0 -1
  1587. package/dist/esm/utilities/contracts/buildable.contract.js +0 -1
  1588. package/dist/esm/utilities/contracts/buildable.contract.js.map +0 -1
  1589. package/dist/esm/utilities/contracts/deinitizable.contract.js +0 -1
  1590. package/dist/esm/utilities/contracts/deinitizable.contract.js.map +0 -1
  1591. package/dist/esm/utilities/contracts/initizable.contract.js +0 -1
  1592. package/dist/esm/utilities/contracts/initizable.contract.js.map +0 -1
  1593. package/dist/esm/utilities/contracts/serialized-error.contract.js +0 -1
  1594. package/dist/esm/utilities/contracts/serialized-error.contract.js.map +0 -1
  1595. package/dist/esm/utilities/errors.js +0 -19
  1596. package/dist/esm/utilities/errors.js.map +0 -1
  1597. package/dist/esm/utilities/functions.js +0 -35
  1598. package/dist/esm/utilities/functions.js.map +0 -1
  1599. package/dist/esm/utilities/kysely/_module.js +0 -2
  1600. package/dist/esm/utilities/kysely/_module.js.map +0 -1
  1601. package/dist/esm/utilities/kysely/kysely-table-name-transformer-plugin.js +0 -41
  1602. package/dist/esm/utilities/kysely/kysely-table-name-transformer-plugin.js.map +0 -1
  1603. package/dist/esm/utilities/time-span/_module.js +0 -2
  1604. package/dist/esm/utilities/time-span/_module.js.map +0 -1
  1605. package/dist/esm/utilities/time-span/time-span.js +0 -107
  1606. package/dist/esm/utilities/time-span/time-span.js.map +0 -1
  1607. package/dist/esm/utilities/types.js +0 -1
  1608. package/dist/esm/utilities/types.js.map +0 -1
  1609. package/dist/types/_module.d.ts +0 -12
  1610. package/dist/types/async/_module.d.ts +0 -3
  1611. package/dist/types/async/async.errors.d.ts +0 -35
  1612. package/dist/types/async/backof-policies/_module.d.ts +0 -5
  1613. package/dist/types/async/backof-policies/_shared.d.ts +0 -12
  1614. package/dist/types/async/backof-policies/constant-backoff-policy/_module.d.ts +0 -1
  1615. package/dist/types/async/backof-policies/constant-backoff-policy/constant-backoff-policy.d.ts +0 -28
  1616. package/dist/types/async/backof-policies/exponential-backoff-policy/_module.d.ts +0 -1
  1617. package/dist/types/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.d.ts +0 -36
  1618. package/dist/types/async/backof-policies/linear-backoff-policy/_module.d.ts +0 -1
  1619. package/dist/types/async/backof-policies/linear-backoff-policy/linear-backoff-policy.d.ts +0 -32
  1620. package/dist/types/async/backof-policies/polynomial-backoff-policy/_module.d.ts +0 -1
  1621. package/dist/types/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.d.ts +0 -36
  1622. package/dist/types/async/utilities/_module.d.ts +0 -5
  1623. package/dist/types/async/utilities/abort/_module.d.ts +0 -2
  1624. package/dist/types/async/utilities/abort/abort.d.ts +0 -9
  1625. package/dist/types/async/utilities/delay/_module.d.ts +0 -1
  1626. package/dist/types/async/utilities/delay/delay.d.ts +0 -19
  1627. package/dist/types/async/utilities/lazy-promise/_module.d.ts +0 -1
  1628. package/dist/types/async/utilities/lazy-promise/lazy-promise.d.ts +0 -212
  1629. package/dist/types/async/utilities/retry/_module.d.ts +0 -2
  1630. package/dist/types/async/utilities/retry/retry-or-fail.d.ts +0 -23
  1631. package/dist/types/async/utilities/retry/retry.d.ts +0 -10
  1632. package/dist/types/async/utilities/timeout/_module.d.ts +0 -2
  1633. package/dist/types/async/utilities/timeout/timeout-and-fail.d.ts +0 -5
  1634. package/dist/types/async/utilities/timeout/timeout.d.ts +0 -10
  1635. package/dist/types/cache/contracts/_module.d.ts +0 -5
  1636. package/dist/types/cache/contracts/cache-adapter.contract.d.ts +0 -54
  1637. package/dist/types/cache/contracts/cache-factory.contract.d.ts +0 -34
  1638. package/dist/types/cache/contracts/cache.contract.d.ts +0 -642
  1639. package/dist/types/cache/contracts/cache.errors.d.ts +0 -39
  1640. package/dist/types/cache/contracts/cache.events.d.ts +0 -95
  1641. package/dist/types/cache/implementations/_module.d.ts +0 -3
  1642. package/dist/types/cache/implementations/_shared/_module.d.ts +0 -2
  1643. package/dist/types/cache/implementations/_shared/cache-adapter.test-suite.d.ts +0 -55
  1644. package/dist/types/cache/implementations/_shared/cache.test-suite.d.ts +0 -63
  1645. package/dist/types/cache/implementations/adapters/_module.d.ts +0 -6
  1646. package/dist/types/cache/implementations/adapters/kysely-sqlite-cache-adapter/_module.d.ts +0 -1
  1647. package/dist/types/cache/implementations/adapters/kysely-sqlite-cache-adapter/kysely-sqlite-cache-adapter.d.ts +0 -61
  1648. package/dist/types/cache/implementations/adapters/libsql-cache-adapter/_module.d.ts +0 -1
  1649. package/dist/types/cache/implementations/adapters/libsql-cache-adapter/libsql-cache-adapter.d.ts +0 -65
  1650. package/dist/types/cache/implementations/adapters/memory-cache-adapter/_module.d.ts +0 -1
  1651. package/dist/types/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.d.ts +0 -54
  1652. package/dist/types/cache/implementations/adapters/mongodb-cache-adapter/_module.d.ts +0 -1
  1653. package/dist/types/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.d.ts +0 -71
  1654. package/dist/types/cache/implementations/adapters/no-op-cache-adapter/_module.d.ts +0 -1
  1655. package/dist/types/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.d.ts +0 -20
  1656. package/dist/types/cache/implementations/adapters/redis-cache-adapter/_module.d.ts +0 -1
  1657. package/dist/types/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.d.ts +0 -59
  1658. package/dist/types/cache/implementations/adapters/sqlite-cache-adapter/_module.d.ts +0 -1
  1659. package/dist/types/cache/implementations/adapters/sqlite-cache-adapter/sqlite-cache-adapter.d.ts +0 -65
  1660. package/dist/types/cache/implementations/derivables/_module.d.ts +0 -2
  1661. package/dist/types/cache/implementations/derivables/cache/_module.d.ts +0 -1
  1662. package/dist/types/cache/implementations/derivables/cache/cache.d.ts +0 -125
  1663. package/dist/types/cache/implementations/derivables/cache-factory/_module.d.ts +0 -1
  1664. package/dist/types/cache/implementations/derivables/cache-factory/cache-factory.d.ts +0 -111
  1665. package/dist/types/collection/contracts/_module.d.ts +0 -4
  1666. package/dist/types/collection/contracts/_shared.d.ts +0 -33
  1667. package/dist/types/collection/contracts/async-collection.contract.d.ts +0 -2180
  1668. package/dist/types/collection/contracts/collection.contract.d.ts +0 -2048
  1669. package/dist/types/collection/contracts/collection.errors.d.ts +0 -39
  1670. package/dist/types/collection/implementations/_module.d.ts +0 -4
  1671. package/dist/types/collection/implementations/_shared.d.ts +0 -22
  1672. package/dist/types/collection/implementations/async-iterable-collection/_module.d.ts +0 -1
  1673. package/dist/types/collection/implementations/async-iterable-collection/_shared/_module.d.ts +0 -36
  1674. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.d.ts +0 -15
  1675. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.d.ts +0 -15
  1676. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.d.ts +0 -12
  1677. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.d.ts +0 -13
  1678. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.d.ts +0 -16
  1679. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-delay-iterable.d.ts +0 -13
  1680. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.d.ts +0 -12
  1681. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.d.ts +0 -13
  1682. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.d.ts +0 -13
  1683. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.d.ts +0 -18
  1684. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.d.ts +0 -15
  1685. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.d.ts +0 -15
  1686. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-map-iterable.d.ts +0 -13
  1687. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.d.ts +0 -12
  1688. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.d.ts +0 -16
  1689. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.d.ts +0 -16
  1690. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.d.ts +0 -15
  1691. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.d.ts +0 -15
  1692. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-retry-iterable.d.ts +0 -13
  1693. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.d.ts +0 -15
  1694. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.d.ts +0 -13
  1695. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.d.ts +0 -13
  1696. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.d.ts +0 -13
  1697. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.d.ts +0 -14
  1698. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.d.ts +0 -14
  1699. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.d.ts +0 -13
  1700. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-split-iterable.d.ts +0 -15
  1701. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-take-iterable.d.ts +0 -13
  1702. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.d.ts +0 -13
  1703. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-take-until-timeout-iterable.d.ts +0 -13
  1704. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.d.ts +0 -13
  1705. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.d.ts +0 -13
  1706. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-update-iterable.d.ts +0 -14
  1707. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-when-iterable.d.ts +0 -14
  1708. package/dist/types/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.d.ts +0 -13
  1709. package/dist/types/collection/implementations/async-iterable-collection/async-iterable-collection.d.ts +0 -303
  1710. package/dist/types/collection/implementations/iterable-collection/_module.d.ts +0 -1
  1711. package/dist/types/collection/implementations/iterable-collection/_shared/_module.d.ts +0 -32
  1712. package/dist/types/collection/implementations/iterable-collection/_shared/chunk-iterable.d.ts +0 -14
  1713. package/dist/types/collection/implementations/iterable-collection/_shared/chunk-while-iterable.d.ts +0 -14
  1714. package/dist/types/collection/implementations/iterable-collection/_shared/collapse-iterable.d.ts +0 -12
  1715. package/dist/types/collection/implementations/iterable-collection/_shared/count-by-iterable.d.ts +0 -13
  1716. package/dist/types/collection/implementations/iterable-collection/_shared/cross-join-iterable.d.ts +0 -14
  1717. package/dist/types/collection/implementations/iterable-collection/_shared/filter-iterable.d.ts +0 -13
  1718. package/dist/types/collection/implementations/iterable-collection/_shared/flat-map-iterable.d.ts +0 -13
  1719. package/dist/types/collection/implementations/iterable-collection/_shared/group-by-iterable.d.ts +0 -14
  1720. package/dist/types/collection/implementations/iterable-collection/_shared/insert-after-iterable.d.ts +0 -14
  1721. package/dist/types/collection/implementations/iterable-collection/_shared/insert-before-iterable.d.ts +0 -14
  1722. package/dist/types/collection/implementations/iterable-collection/_shared/map-iterable.d.ts +0 -13
  1723. package/dist/types/collection/implementations/iterable-collection/_shared/pad-end-iterable.d.ts +0 -15
  1724. package/dist/types/collection/implementations/iterable-collection/_shared/pad-start-iterable.d.ts +0 -15
  1725. package/dist/types/collection/implementations/iterable-collection/_shared/partion-iterable.d.ts +0 -14
  1726. package/dist/types/collection/implementations/iterable-collection/_shared/repeat-iterable.d.ts +0 -14
  1727. package/dist/types/collection/implementations/iterable-collection/_shared/reverse-iterable.d.ts +0 -14
  1728. package/dist/types/collection/implementations/iterable-collection/_shared/skip-iterable.d.ts +0 -13
  1729. package/dist/types/collection/implementations/iterable-collection/_shared/skip-until-iterable.d.ts +0 -13
  1730. package/dist/types/collection/implementations/iterable-collection/_shared/slice-iterable.d.ts +0 -14
  1731. package/dist/types/collection/implementations/iterable-collection/_shared/sliding-iterable.d.ts +0 -14
  1732. package/dist/types/collection/implementations/iterable-collection/_shared/sort-iterable.d.ts +0 -13
  1733. package/dist/types/collection/implementations/iterable-collection/_shared/split-iterable.d.ts +0 -14
  1734. package/dist/types/collection/implementations/iterable-collection/_shared/take-iterable.d.ts +0 -13
  1735. package/dist/types/collection/implementations/iterable-collection/_shared/take-until-iterable.d.ts +0 -13
  1736. package/dist/types/collection/implementations/iterable-collection/_shared/tap-iterable.d.ts +0 -13
  1737. package/dist/types/collection/implementations/iterable-collection/_shared/unique-iterable.d.ts +0 -13
  1738. package/dist/types/collection/implementations/iterable-collection/_shared/update-iterable.d.ts +0 -14
  1739. package/dist/types/collection/implementations/iterable-collection/_shared/when-iterable.d.ts +0 -14
  1740. package/dist/types/collection/implementations/iterable-collection/iterable-collection.d.ts +0 -245
  1741. package/dist/types/collection/implementations/list-collection/_module.d.ts +0 -1
  1742. package/dist/types/collection/implementations/list-collection/list-collection.d.ts +0 -242
  1743. package/dist/types/event-bus/contracts/_module.d.ts +0 -5
  1744. package/dist/types/event-bus/contracts/_shared.d.ts +0 -15
  1745. package/dist/types/event-bus/contracts/event-bus-adapter.contract.d.ts +0 -26
  1746. package/dist/types/event-bus/contracts/event-bus-factory.contract.d.ts +0 -40
  1747. package/dist/types/event-bus/contracts/event-bus.contract.d.ts +0 -146
  1748. package/dist/types/event-bus/contracts/event-bus.errors.d.ts +0 -45
  1749. package/dist/types/event-bus/implementations/_module.d.ts +0 -3
  1750. package/dist/types/event-bus/implementations/_shared/_module.d.ts +0 -2
  1751. package/dist/types/event-bus/implementations/_shared/event-bus-adapter.test-suite.d.ts +0 -63
  1752. package/dist/types/event-bus/implementations/_shared/event-bus.test-suite.d.ts +0 -65
  1753. package/dist/types/event-bus/implementations/adapters/_module.d.ts +0 -3
  1754. package/dist/types/event-bus/implementations/adapters/memory-event-bus-adapter/_module.d.ts +0 -1
  1755. package/dist/types/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.d.ts +0 -51
  1756. package/dist/types/event-bus/implementations/adapters/no-op-event-bus-adapter/_module.d.ts +0 -1
  1757. package/dist/types/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.d.ts +0 -16
  1758. package/dist/types/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module.d.ts +0 -1
  1759. package/dist/types/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.d.ts +0 -52
  1760. package/dist/types/event-bus/implementations/derivables/_module.d.ts +0 -2
  1761. package/dist/types/event-bus/implementations/derivables/event-bus/_module.d.ts +0 -1
  1762. package/dist/types/event-bus/implementations/derivables/event-bus/event-bus.d.ts +0 -70
  1763. package/dist/types/event-bus/implementations/derivables/event-bus-factory/_module.d.ts +0 -1
  1764. package/dist/types/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.d.ts +0 -92
  1765. package/dist/types/lock/contracts/_module.d.ts +0 -7
  1766. package/dist/types/lock/contracts/database-lock-adapter.contract.d.ts +0 -48
  1767. package/dist/types/lock/contracts/lock-adapter.contract.d.ts +0 -39
  1768. package/dist/types/lock/contracts/lock-provider-factory.contract.d.ts +0 -36
  1769. package/dist/types/lock/contracts/lock-provider.contract.d.ts +0 -92
  1770. package/dist/types/lock/contracts/lock.contract.d.ts +0 -219
  1771. package/dist/types/lock/contracts/lock.errors.d.ts +0 -66
  1772. package/dist/types/lock/contracts/lock.events.d.ts +0 -83
  1773. package/dist/types/lock/implementations/_module.d.ts +0 -3
  1774. package/dist/types/lock/implementations/_shared/_module.d.ts +0 -3
  1775. package/dist/types/lock/implementations/_shared/database-lock-adapter.test-suite.d.ts +0 -21
  1776. package/dist/types/lock/implementations/_shared/lock-adapter.test-suite.d.ts +0 -21
  1777. package/dist/types/lock/implementations/_shared/lock-provider.test-suite.d.ts +0 -23
  1778. package/dist/types/lock/implementations/adapters/_module.d.ts +0 -5
  1779. package/dist/types/lock/implementations/adapters/kysely-lock-adapter/_module.d.ts +0 -1
  1780. package/dist/types/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.d.ts +0 -52
  1781. package/dist/types/lock/implementations/adapters/libsql-lock-adapter/_module.d.ts +0 -1
  1782. package/dist/types/lock/implementations/adapters/libsql-lock-adapter/libsql-lock-adapter.d.ts +0 -58
  1783. package/dist/types/lock/implementations/adapters/memory-lock-adapter/_module.d.ts +0 -1
  1784. package/dist/types/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.d.ts +0 -50
  1785. package/dist/types/lock/implementations/adapters/mongodb-lock-adapter/_module.d.ts +0 -1
  1786. package/dist/types/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.d.ts +0 -61
  1787. package/dist/types/lock/implementations/adapters/redis-lock-adapter/_module.d.ts +0 -1
  1788. package/dist/types/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.d.ts +0 -55
  1789. package/dist/types/lock/implementations/adapters/sqlite-lock-adapter/_module.d.ts +0 -1
  1790. package/dist/types/lock/implementations/adapters/sqlite-lock-adapter/sqlite-lock-adapter.d.ts +0 -57
  1791. package/dist/types/lock/implementations/derivables/_module.d.ts +0 -2
  1792. package/dist/types/lock/implementations/derivables/lock-provider/_module.d.ts +0 -1
  1793. package/dist/types/lock/implementations/derivables/lock-provider/database-lock-adapter.d.ts +0 -18
  1794. package/dist/types/lock/implementations/derivables/lock-provider/lock-provider.d.ts +0 -112
  1795. package/dist/types/lock/implementations/derivables/lock-provider/lock-state.d.ts +0 -40
  1796. package/dist/types/lock/implementations/derivables/lock-provider/lock.d.ts +0 -79
  1797. package/dist/types/lock/implementations/derivables/lock-provider-factory/_module.d.ts +0 -1
  1798. package/dist/types/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.d.ts +0 -124
  1799. package/dist/types/serde/contracts/_module.d.ts +0 -6
  1800. package/dist/types/serde/contracts/deserializer.contract.d.ts +0 -13
  1801. package/dist/types/serde/contracts/flexible-serde.contract.d.ts +0 -121
  1802. package/dist/types/serde/contracts/serde.contract.d.ts +0 -10
  1803. package/dist/types/serde/contracts/serde.errors.d.ts +0 -21
  1804. package/dist/types/serde/contracts/serializable.contract.d.ts +0 -10
  1805. package/dist/types/serde/contracts/serializer.contract.d.ts +0 -10
  1806. package/dist/types/serde/implementations/_module.d.ts +0 -6
  1807. package/dist/types/serde/implementations/_shared/test-utilities/_module.d.ts +0 -2
  1808. package/dist/types/serde/implementations/_shared/test-utilities/flexible-serde.test-suite.d.ts +0 -17
  1809. package/dist/types/serde/implementations/_shared/test-utilities/serde.test-suite.d.ts +0 -17
  1810. package/dist/types/serde/implementations/mongodb-serde/_module.d.ts +0 -1
  1811. package/dist/types/serde/implementations/mongodb-serde/mongodb-serde.d.ts +0 -13
  1812. package/dist/types/serde/implementations/no-op-serde/_module.d.ts +0 -1
  1813. package/dist/types/serde/implementations/no-op-serde/no-op-serde.d.ts +0 -15
  1814. package/dist/types/serde/implementations/redis-serde/_module.d.ts +0 -1
  1815. package/dist/types/serde/implementations/redis-serde/redis-serde.d.ts +0 -13
  1816. package/dist/types/serde/implementations/sql-serde/_module.d.ts +0 -1
  1817. package/dist/types/serde/implementations/sql-serde/sql-serde.d.ts +0 -13
  1818. package/dist/types/serde/implementations/super-json-serde/_module.d.ts +0 -1
  1819. package/dist/types/serde/implementations/super-json-serde/super-json-serde.d.ts +0 -47
  1820. package/dist/types/utilities/_module.d.ts +0 -6
  1821. package/dist/types/utilities/contracts/_module.d.ts +0 -4
  1822. package/dist/types/utilities/contracts/buildable.contract.d.ts +0 -9
  1823. package/dist/types/utilities/contracts/deinitizable.contract.d.ts +0 -9
  1824. package/dist/types/utilities/contracts/initizable.contract.d.ts +0 -9
  1825. package/dist/types/utilities/contracts/serialized-error.contract.d.ts +0 -11
  1826. package/dist/types/utilities/errors.d.ts +0 -21
  1827. package/dist/types/utilities/functions.d.ts +0 -29
  1828. package/dist/types/utilities/kysely/_module.d.ts +0 -1
  1829. package/dist/types/utilities/time-span/_module.d.ts +0 -1
  1830. package/dist/types/utilities/time-span/time-span.d.ts +0 -62
  1831. package/dist/types/utilities/types.d.ts +0 -14
  1832. /package/dist/{types/async → async}/utilities/abort/abort-and-fail.d.ts +0 -0
  1833. /package/dist/{types/collection → collection}/implementations/async-iterable-collection/_shared/async-take-until-abort-iterable.d.ts +0 -0
  1834. /package/dist/{types/collection → collection}/implementations/iterable-collection/_shared/entries-iterable.d.ts +0 -0
  1835. /package/dist/{types/collection → collection}/implementations/iterable-collection/_shared/merge-iterable.d.ts +0 -0
  1836. /package/dist/{types/collection → collection}/implementations/iterable-collection/_shared/shuffle-iterable.d.ts +0 -0
  1837. /package/dist/{types/collection → collection}/implementations/iterable-collection/_shared/zip-iterable.d.ts +0 -0
  1838. /package/dist/{types/utilities → utilities}/kysely/kysely-table-name-transformer-plugin.d.ts +0 -0
@@ -0,0 +1,2315 @@
1
+ /**
2
+ * @module Lock
3
+ */
4
+ import {} from "vitest";
5
+ import { UnownedRefreshLockEvent, KeyForceReleasedLockEvent, KeyAlreadyAcquiredLockEvent, UnownedReleaseLockEvent, KeyReleasedLockEvent, KeyAcquiredLockEvent, KeyAlreadyAcquiredLockError, UnownedRefreshLockError, UnownedReleaseLockError, KeyRefreshedLockEvent, } from "../../../lock/contracts/_module-exports.js";
6
+ import {} from "../../../utilities/_module-exports.js";
7
+ import { TimeSpan } from "../../../utilities/_module-exports.js";
8
+ import { delay, LazyPromise } from "../../../async/_module-exports.js";
9
+ import { NoOpSerdeAdapter } from "../../../serde/implementations/adapters/_module-exports.js";
10
+ import { Serde } from "../../../serde/implementations/derivables/_module-exports.js";
11
+ /**
12
+ * The <i>lockProviderTestSuite</i> function simplifies the process of testing your custom implementation of <i>{@link ILock}</i> with <i>vitest</i>.
13
+ *
14
+ * IMPORT_PATH: ```"@daiso-tech/core/lock/implementations/test-utilities"```
15
+ * @group Utilities
16
+ * @example
17
+ * ```ts
18
+ * import { beforeEach, describe, expect, test } from "vitest";
19
+ * import { MemoryLockAdapter } from "@daiso-tech/core/lock/implementations/adapters";
20
+ * import { LockProvider } from "@daiso-tech/core/lock/implementations/derivables";
21
+ * import { EventBus } from "@daiso-tech/core/event-bus/implementations/derivables";
22
+ * import { MemoryEventBusAdapter } from "@daiso-tech/core/event-bus/implementations/adapters";
23
+ * import { lockProviderTestSuite } from "@daiso-tech/core/lock/implementations/test-utilities";
24
+ * import { Serde } from "@daiso-tech/core/serde/implementations/derivables";
25
+ * import { SuperJsonSerdeAdapter } from "@daiso-tech/core/serde/implementations/adapters";
26
+ * import type { ILockData } from "@daiso-tech/core/lock/contracts";
27
+ *
28
+ * describe("class: LockProvider", () => {
29
+ * const eventBus = new EventBus({
30
+ * adapter: new MemoryEventBusAdapter({
31
+ * rootGroup: "@global",
32
+ * }),
33
+ * });
34
+ * const serde = new Serde(new SuperJsonSerdeAdapter());
35
+ * let map: Map<string, ILockData>;
36
+ * beforeEach(() => {
37
+ * map = new Map();
38
+ * });
39
+ * lockProviderTestSuite({
40
+ * createLockProvider: () => {
41
+ * const lockProvider = new LockProvider({
42
+ * serde,
43
+ * adapter: new MemoryLockAdapter({
44
+ * rootGroup: "@a",
45
+ * map,
46
+ * }),
47
+ * eventBus,
48
+ * });
49
+ * return lockProvider;
50
+ * },
51
+ * beforeEach,
52
+ * describe,
53
+ * expect,
54
+ * test,
55
+ * serde,
56
+ * });
57
+ * });
58
+ * ```
59
+ */
60
+ export function lockProviderTestSuite(settings) {
61
+ const { expect, test, createLockProvider, describe, beforeEach, serde = new Serde(new NoOpSerdeAdapter()), } = settings;
62
+ let lockProviderA;
63
+ let lockProviderB;
64
+ beforeEach(async () => {
65
+ const lockProvider = await createLockProvider();
66
+ lockProviderA = lockProvider;
67
+ lockProviderB = lockProvider.withGroup("b");
68
+ });
69
+ const TTL = TimeSpan.fromMilliseconds(50);
70
+ describe("Api tests:", () => {
71
+ describe("method: run", () => {
72
+ test("Should return string when lock is available", async () => {
73
+ const key = "a";
74
+ const ttl = null;
75
+ const lock = lockProviderA.create(key, {
76
+ ttl,
77
+ });
78
+ const [result, error] = await lock.run(async () => {
79
+ await delay(TTL);
80
+ return "a";
81
+ });
82
+ expect(result).toBe("a");
83
+ expect(error).toBeNull();
84
+ });
85
+ test("Should return null when lock is already acquired", async () => {
86
+ const key = "a";
87
+ const ttl = null;
88
+ const lock = lockProviderA.create(key, {
89
+ ttl,
90
+ });
91
+ await lock.acquire();
92
+ const [result, error] = await lock.run(async () => {
93
+ await delay(TTL);
94
+ return "a";
95
+ });
96
+ expect(result).toBeNull();
97
+ expect(error).toBeInstanceOf(KeyAlreadyAcquiredLockError);
98
+ });
99
+ test("Should work with LazyPromise", async () => {
100
+ const key = "a";
101
+ const ttl = null;
102
+ const lock = lockProviderA.create(key, {
103
+ ttl,
104
+ });
105
+ const [result, error] = await lock.run(new LazyPromise(async () => {
106
+ await delay(TTL);
107
+ return "a";
108
+ }));
109
+ expect(result).toBe("a");
110
+ expect(error).toBeNull();
111
+ });
112
+ });
113
+ describe("method: runOrFail", () => {
114
+ test("Should return string when lock is available", async () => {
115
+ const key = "a";
116
+ const ttl = null;
117
+ const lock = lockProviderA.create(key, {
118
+ ttl,
119
+ });
120
+ const result = await lock.runOrFail(async () => {
121
+ await delay(TTL);
122
+ return "a";
123
+ });
124
+ expect(result).toBe("a");
125
+ });
126
+ test("Should throw KeyAlreadyAcquiredLockError when lock is already acquired", async () => {
127
+ const key = "a";
128
+ const ttl = null;
129
+ const lock = lockProviderA.create(key, {
130
+ ttl,
131
+ });
132
+ await lock.acquire();
133
+ const result = lock.runOrFail(async () => {
134
+ await delay(TTL);
135
+ return "a";
136
+ });
137
+ await expect(result).rejects.toBeInstanceOf(KeyAlreadyAcquiredLockError);
138
+ });
139
+ test("Should work with LazyPromise", async () => {
140
+ const key = "a";
141
+ const ttl = null;
142
+ const lock = lockProviderA.create(key, {
143
+ ttl,
144
+ });
145
+ const result = await lock.runOrFail(new LazyPromise(async () => {
146
+ await delay(TTL);
147
+ return "a";
148
+ }));
149
+ expect(result).toBe("a");
150
+ });
151
+ });
152
+ describe("method: runBlocking", () => {
153
+ test("Should return string when lock is available", async () => {
154
+ const key = "a";
155
+ const ttl = null;
156
+ const lock = lockProviderA.create(key, {
157
+ ttl,
158
+ });
159
+ const [result, error] = await lock.runBlocking(async () => {
160
+ await delay(TTL);
161
+ return "a";
162
+ }, {
163
+ time: TimeSpan.fromMilliseconds(1),
164
+ interval: TimeSpan.fromMilliseconds(1),
165
+ });
166
+ expect(result).toBe("a");
167
+ expect(error).toBeNull();
168
+ });
169
+ test("Should return null when lock is already acquired", async () => {
170
+ const key = "a";
171
+ const ttl = null;
172
+ const lock = lockProviderA.create(key, {
173
+ ttl,
174
+ });
175
+ await lock.acquire();
176
+ const [result, error] = await lock.runBlocking(async () => {
177
+ await delay(TTL);
178
+ return "a";
179
+ }, {
180
+ time: TimeSpan.fromMilliseconds(1),
181
+ interval: TimeSpan.fromMilliseconds(1),
182
+ });
183
+ expect(result).toBeNull();
184
+ expect(error).toBeInstanceOf(KeyAlreadyAcquiredLockError);
185
+ });
186
+ test("Should work with LazyPromise", async () => {
187
+ const key = "a";
188
+ const ttl = null;
189
+ const lock = lockProviderA.create(key, {
190
+ ttl,
191
+ });
192
+ const [result, error] = await lock.runBlocking(new LazyPromise(async () => {
193
+ await delay(TTL);
194
+ return "a";
195
+ }), {
196
+ time: TimeSpan.fromMilliseconds(1),
197
+ interval: TimeSpan.fromMilliseconds(1),
198
+ });
199
+ expect(result).toBe("a");
200
+ expect(error).toBeNull();
201
+ });
202
+ test("Should retry acquire the lock", async () => {
203
+ const key = "a";
204
+ const ttl = TimeSpan.fromMilliseconds(50);
205
+ const lock = lockProviderA.create(key, {
206
+ ttl,
207
+ });
208
+ await lock.acquire();
209
+ let index = 0;
210
+ await lock.addListener(KeyAlreadyAcquiredLockEvent, (_event) => {
211
+ index++;
212
+ });
213
+ await lock.runBlocking(async () => {
214
+ await delay(TTL);
215
+ }, {
216
+ time: TimeSpan.fromMilliseconds(55),
217
+ interval: TimeSpan.fromMilliseconds(5),
218
+ });
219
+ expect(index).toBeGreaterThan(1);
220
+ });
221
+ });
222
+ describe("method: acquire", () => {
223
+ test("Should return true when lock is available", async () => {
224
+ const key = "a";
225
+ const ttl = null;
226
+ const lock = lockProviderA.create(key, {
227
+ ttl,
228
+ });
229
+ const result = await lock.acquire();
230
+ expect(result).toBe(true);
231
+ });
232
+ test("Should return false when lock is already acquired", async () => {
233
+ const key = "a";
234
+ const ttl = null;
235
+ const lock = lockProviderA.create(key, {
236
+ ttl,
237
+ });
238
+ await lock.acquire();
239
+ const result = await lock.acquire();
240
+ expect(result).toBe(false);
241
+ });
242
+ test("Should not be expired when released by same owner", async () => {
243
+ const key = "a";
244
+ const ttl = null;
245
+ const owner = "b";
246
+ const lock = lockProviderA.create(key, {
247
+ ttl,
248
+ owner,
249
+ });
250
+ await lock.acquire();
251
+ const result = await lock.isExpired();
252
+ expect(result).toBe(false);
253
+ });
254
+ test("Should be loked when released by same owner", async () => {
255
+ const key = "a";
256
+ const ttl = null;
257
+ const owner = "b";
258
+ const lock = lockProviderA.create(key, {
259
+ ttl,
260
+ owner,
261
+ });
262
+ await lock.acquire();
263
+ const result = await lock.isLocked();
264
+ expect(result).toBe(true);
265
+ });
266
+ });
267
+ describe("method: acquireOrFail", () => {
268
+ test("Should not throw KeyAlreadyAcquiredLockError when lock is available", async () => {
269
+ const key = "a";
270
+ const ttl = null;
271
+ const lock = lockProviderA.create(key, {
272
+ ttl,
273
+ });
274
+ const result = lock.acquireOrFail();
275
+ await expect(result).resolves.toBeUndefined();
276
+ });
277
+ test("Should throw KeyAlreadyAcquiredLockError when lock is already acquired", async () => {
278
+ const key = "a";
279
+ const ttl = null;
280
+ const lock = lockProviderA.create(key, {
281
+ ttl,
282
+ });
283
+ await lock.acquireOrFail();
284
+ const result = lock.acquireOrFail();
285
+ await expect(result).rejects.toBeInstanceOf(KeyAlreadyAcquiredLockError);
286
+ });
287
+ });
288
+ describe("method: acquireBlocking", () => {
289
+ test("Should return true when lock is available", async () => {
290
+ const key = "a";
291
+ const ttl = null;
292
+ const lock = lockProviderA.create(key, {
293
+ ttl,
294
+ });
295
+ const result = await lock.acquireBlocking({
296
+ time: TimeSpan.fromMilliseconds(1),
297
+ interval: TimeSpan.fromMilliseconds(1),
298
+ });
299
+ expect(result).toBe(true);
300
+ });
301
+ test("Should return false when lock is already acquired", async () => {
302
+ const key = "a";
303
+ const ttl = null;
304
+ const lock = lockProviderA.create(key, {
305
+ ttl,
306
+ });
307
+ await lock.acquireBlocking({
308
+ time: TimeSpan.fromMilliseconds(0),
309
+ interval: TimeSpan.fromMilliseconds(0),
310
+ });
311
+ const result = await lock.acquireBlocking({
312
+ time: TimeSpan.fromMilliseconds(0),
313
+ interval: TimeSpan.fromMilliseconds(0),
314
+ });
315
+ expect(result).toBe(false);
316
+ });
317
+ test("Should not be expired when released by same owner", async () => {
318
+ const key = "a";
319
+ const ttl = null;
320
+ const owner = "b";
321
+ const lock = lockProviderA.create(key, {
322
+ ttl,
323
+ owner,
324
+ });
325
+ await lock.acquireBlocking({
326
+ time: TimeSpan.fromMilliseconds(0),
327
+ interval: TimeSpan.fromMilliseconds(0),
328
+ });
329
+ const result = await lock.isExpired();
330
+ expect(result).toBe(false);
331
+ });
332
+ test("Should be loked when released by same owner", async () => {
333
+ const key = "a";
334
+ const ttl = null;
335
+ const owner = "b";
336
+ const lock = lockProviderA.create(key, {
337
+ ttl,
338
+ owner,
339
+ });
340
+ await lock.acquireBlocking({
341
+ time: TimeSpan.fromMilliseconds(0),
342
+ interval: TimeSpan.fromMilliseconds(0),
343
+ });
344
+ const result = await lock.isLocked();
345
+ expect(result).toBe(true);
346
+ });
347
+ test("Should retry acquire the lock", async () => {
348
+ const key = "a";
349
+ const ttl = TimeSpan.fromMilliseconds(50);
350
+ const lock = lockProviderA.create(key, {
351
+ ttl,
352
+ });
353
+ await lock.acquire();
354
+ let index = 0;
355
+ await lock.addListener(KeyAlreadyAcquiredLockEvent, (_event) => {
356
+ index++;
357
+ });
358
+ await lock.acquireBlocking({
359
+ time: TimeSpan.fromMilliseconds(55),
360
+ interval: TimeSpan.fromMilliseconds(5),
361
+ });
362
+ expect(index).toBeGreaterThan(1);
363
+ });
364
+ });
365
+ describe("method: release", () => {
366
+ test("Should return true when released by same owner", async () => {
367
+ const key = "a";
368
+ const ttl = null;
369
+ const owner = "b";
370
+ const lock = lockProviderA.create(key, {
371
+ ttl,
372
+ owner,
373
+ });
374
+ await lock.acquire();
375
+ const result = await lock.release();
376
+ expect(result).toBe(true);
377
+ });
378
+ test("Should return false when released by different owner", async () => {
379
+ const key = "a";
380
+ const ttl = null;
381
+ const owner1 = "b";
382
+ const lock1 = lockProviderA.create(key, {
383
+ ttl,
384
+ owner: owner1,
385
+ });
386
+ await lock1.acquire();
387
+ const owner2 = "c";
388
+ const lock2 = lockProviderA.create(key, {
389
+ ttl,
390
+ owner: owner2,
391
+ });
392
+ const result = await lock2.release();
393
+ expect(result).toBe(false);
394
+ });
395
+ test("Should be expired when released by same owner", async () => {
396
+ const key = "a";
397
+ const ttl = null;
398
+ const owner = "b";
399
+ const lock = lockProviderA.create(key, {
400
+ ttl,
401
+ owner,
402
+ });
403
+ await lock.acquire();
404
+ await lock.release();
405
+ const result = await lock.isExpired();
406
+ expect(result).toBe(true);
407
+ });
408
+ test("Should be not loked when released by same owner", async () => {
409
+ const key = "a";
410
+ const ttl = null;
411
+ const owner = "b";
412
+ const lock = lockProviderA.create(key, {
413
+ ttl,
414
+ owner,
415
+ });
416
+ await lock.acquire();
417
+ await lock.release();
418
+ const result = await lock.isLocked();
419
+ expect(result).toBe(false);
420
+ });
421
+ });
422
+ describe("method: releaseOrFail", () => {
423
+ test("Should not throw UnownedReleaseLockError when released by same owner", async () => {
424
+ const key = "a";
425
+ const ttl = null;
426
+ const owner = "b";
427
+ const lock = lockProviderA.create(key, {
428
+ ttl,
429
+ owner,
430
+ });
431
+ await lock.acquire();
432
+ const result = lock.releaseOrFail();
433
+ await expect(result).resolves.toBeUndefined();
434
+ });
435
+ test("Should throw UnownedReleaseLockError when released by different owner", async () => {
436
+ const key = "a";
437
+ const ttl = null;
438
+ const owner1 = "b";
439
+ const lock1 = lockProviderA.create(key, {
440
+ ttl,
441
+ owner: owner1,
442
+ });
443
+ await lock1.acquire();
444
+ const owner2 = "c";
445
+ const lock2 = lockProviderA.create(key, {
446
+ ttl,
447
+ owner: owner2,
448
+ });
449
+ const result = lock2.releaseOrFail();
450
+ await expect(result).rejects.toBeInstanceOf(UnownedReleaseLockError);
451
+ });
452
+ test("Should be expired when released by same owner", async () => {
453
+ const key = "a";
454
+ const ttl = null;
455
+ const owner = "b";
456
+ const lock = lockProviderA.create(key, {
457
+ ttl,
458
+ owner,
459
+ });
460
+ await lock.acquire();
461
+ await lock.releaseOrFail();
462
+ const result = await lock.isExpired();
463
+ expect(result).toBe(true);
464
+ });
465
+ test("Should be not loked when released by same owner", async () => {
466
+ const key = "a";
467
+ const ttl = null;
468
+ const owner = "b";
469
+ const lock = lockProviderA.create(key, {
470
+ ttl,
471
+ owner,
472
+ });
473
+ await lock.acquire();
474
+ await lock.releaseOrFail();
475
+ const result = await lock.isLocked();
476
+ expect(result).toBe(false);
477
+ });
478
+ });
479
+ describe("method: forceRelease", () => {
480
+ test("Should release lock no regardless of the owner", async () => {
481
+ const key = "a";
482
+ const ttl = null;
483
+ const owner1 = "b";
484
+ const lock1 = lockProviderA.create(key, {
485
+ ttl,
486
+ owner: owner1,
487
+ });
488
+ await lock1.acquire();
489
+ const owner2 = "c";
490
+ const lock2 = lockProviderA.create(key, {
491
+ ttl,
492
+ owner: owner2,
493
+ });
494
+ await lock2.forceRelease();
495
+ const result = await lock1.acquire();
496
+ expect(result).toBe(true);
497
+ });
498
+ test("Should be expired when released", async () => {
499
+ const key = "a";
500
+ const ttl = null;
501
+ const owner = "b";
502
+ const lock = lockProviderA.create(key, {
503
+ ttl,
504
+ owner,
505
+ });
506
+ await lock.acquire();
507
+ await lock.forceRelease();
508
+ const result = await lock.isExpired();
509
+ expect(result).toBe(true);
510
+ });
511
+ test("Should be not loked when released", async () => {
512
+ const key = "a";
513
+ const ttl = null;
514
+ const owner = "b";
515
+ const lock = lockProviderA.create(key, {
516
+ ttl,
517
+ owner,
518
+ });
519
+ await lock.acquire();
520
+ await lock.forceRelease();
521
+ const result = await lock.isLocked();
522
+ expect(result).toBe(false);
523
+ });
524
+ });
525
+ describe("method: isExpired", () => {
526
+ test("Should return false when lock has no expiration", async () => {
527
+ const key = "a";
528
+ const ttl = null;
529
+ const owner = "b";
530
+ const lock = lockProviderA.create(key, {
531
+ ttl,
532
+ owner,
533
+ });
534
+ await lock.acquire();
535
+ const result = await lock.isExpired();
536
+ expect(result).toBe(false);
537
+ });
538
+ test("Should return false when lock has not expired", async () => {
539
+ const key = "a";
540
+ const owner = "b";
541
+ const ttl = TTL;
542
+ const lock = lockProviderA.create(key, {
543
+ ttl,
544
+ owner,
545
+ });
546
+ await lock.acquire();
547
+ const result = await lock.isExpired();
548
+ expect(result).toBe(false);
549
+ });
550
+ test("Should return true when lock has expired", async () => {
551
+ const key = "a";
552
+ const owner = "b";
553
+ const ttl = TTL;
554
+ const lock = lockProviderA.create(key, {
555
+ ttl,
556
+ owner,
557
+ });
558
+ await lock.acquire();
559
+ await delay(ttl.addMilliseconds(25));
560
+ const result = await lock.isExpired();
561
+ expect(result).toBe(true);
562
+ });
563
+ });
564
+ describe("method: isLocked", () => {
565
+ test("Should return true when lock has no expiration", async () => {
566
+ const key = "a";
567
+ const ttl = null;
568
+ const owner = "b";
569
+ const lock = lockProviderA.create(key, {
570
+ ttl,
571
+ owner,
572
+ });
573
+ await lock.acquire();
574
+ const result = await lock.isLocked();
575
+ expect(result).toBe(true);
576
+ });
577
+ test("Should return true when lock has not expired", async () => {
578
+ const key = "a";
579
+ const owner = "b";
580
+ const ttl = TTL;
581
+ const lock = lockProviderA.create(key, {
582
+ ttl,
583
+ owner,
584
+ });
585
+ await lock.acquire();
586
+ const result = await lock.isLocked();
587
+ expect(result).toBe(true);
588
+ });
589
+ test("Should return false when lock has expired", async () => {
590
+ const key = "a";
591
+ const owner = "b";
592
+ const ttl = TTL;
593
+ const lock = lockProviderA.create(key, {
594
+ ttl,
595
+ owner,
596
+ });
597
+ await lock.acquire();
598
+ await delay(ttl.addMilliseconds(25));
599
+ const result = await lock.isLocked();
600
+ expect(result).toBe(false);
601
+ });
602
+ });
603
+ describe("method: refresh", () => {
604
+ test("Should return true when refreshed by same owner", async () => {
605
+ const key = "a";
606
+ const ttl = TTL;
607
+ const owner = "b";
608
+ const lock = lockProviderA.create(key, {
609
+ ttl,
610
+ owner,
611
+ });
612
+ await lock.acquire();
613
+ await delay(ttl);
614
+ const result = await lock.refresh();
615
+ expect(result).toBe(true);
616
+ });
617
+ test("Should return false when refreshed by different owner", async () => {
618
+ const key = "a";
619
+ const ttl = TTL;
620
+ const owner1 = "b";
621
+ const lock1 = lockProviderA.create(key, {
622
+ ttl,
623
+ owner: owner1,
624
+ });
625
+ await lock1.acquire();
626
+ const owner2 = "c";
627
+ const lock2 = lockProviderA.create(key, {
628
+ ttl,
629
+ owner: owner2,
630
+ });
631
+ const result = await lock2.refresh();
632
+ expect(result).toBe(false);
633
+ });
634
+ test("Should refresh expiration by same owner", async () => {
635
+ const key = "a";
636
+ const ttl = TTL;
637
+ const owner = "b";
638
+ const lock = lockProviderA.create(key, {
639
+ ttl,
640
+ owner,
641
+ });
642
+ await lock.acquire();
643
+ await delay(ttl.subtractMilliseconds(10));
644
+ await lock.refresh();
645
+ const time = await lock.getRemainingTime();
646
+ expect(time?.toMilliseconds()).toBeGreaterThan(0);
647
+ });
648
+ });
649
+ describe("method: refreshOrFail", () => {
650
+ test("Should not throw UnownedRefreshLockError when refreshed by same owner", async () => {
651
+ const key = "a";
652
+ const ttl = TTL;
653
+ const owner = "b";
654
+ const lock = lockProviderA.create(key, {
655
+ ttl,
656
+ owner,
657
+ });
658
+ await lock.acquire();
659
+ await delay(ttl);
660
+ const result = lock.refreshOrFail();
661
+ await expect(result).resolves.toBeUndefined();
662
+ });
663
+ test("Should throw UnownedRefreshLockError when refreshed by different owner", async () => {
664
+ const key = "a";
665
+ const ttl = TTL;
666
+ const owner1 = "b";
667
+ const lock1 = lockProviderA.create(key, {
668
+ ttl,
669
+ owner: owner1,
670
+ });
671
+ await lock1.acquire();
672
+ const owner2 = "c";
673
+ const lock2 = lockProviderA.create(key, {
674
+ ttl,
675
+ owner: owner2,
676
+ });
677
+ const result = lock2.refreshOrFail();
678
+ await expect(result).rejects.toBeInstanceOf(UnownedRefreshLockError);
679
+ });
680
+ test("Should refresh expiration by same owner", async () => {
681
+ const key = "a";
682
+ const ttl = TTL;
683
+ const owner = "b";
684
+ const lock = lockProviderA.create(key, {
685
+ ttl,
686
+ owner,
687
+ });
688
+ await lock.acquireOrFail();
689
+ await delay(ttl.subtractMilliseconds(10));
690
+ await lock.refresh();
691
+ const time = await lock.getRemainingTime();
692
+ expect(time?.toMilliseconds()).toBeGreaterThan(0);
693
+ });
694
+ });
695
+ describe("method: getRemainingTime", () => {
696
+ test("Should return null when lock is not acquired", async () => {
697
+ const key = "a";
698
+ const ttl = null;
699
+ const owner = "b";
700
+ const lock = lockProviderA.create(key, {
701
+ ttl,
702
+ owner,
703
+ });
704
+ const result = await lock.getRemainingTime();
705
+ expect(result).toBeNull();
706
+ });
707
+ test("Should return null when lock is acquired and has expiration", async () => {
708
+ const key = "a";
709
+ const ttl = null;
710
+ const owner = "b";
711
+ const lock = lockProviderA.create(key, {
712
+ ttl,
713
+ owner,
714
+ });
715
+ await lock.acquire();
716
+ const result = await lock.getRemainingTime();
717
+ expect(result).toBeNull();
718
+ });
719
+ test("Should return remaining time when lock is not acquired", async () => {
720
+ const key = "a";
721
+ const ttl = TTL;
722
+ const owner = "b";
723
+ const lock = lockProviderA.create(key, {
724
+ ttl,
725
+ owner,
726
+ });
727
+ await lock.acquire();
728
+ const result = await lock.getRemainingTime();
729
+ expect(result?.toMilliseconds()).toBe(ttl.toMilliseconds());
730
+ });
731
+ });
732
+ describe("method: getOwner", () => {
733
+ test("Should return the owner", async () => {
734
+ const key = "a";
735
+ const owner = "b";
736
+ const lock = lockProviderA.create(key, {
737
+ owner,
738
+ });
739
+ const result = await lock.getOwner();
740
+ expect(result).toBe(owner);
741
+ });
742
+ test("Should return the auto generated owner", async () => {
743
+ const key = "a";
744
+ const lock = lockProviderA.create(key);
745
+ const result = await lock.getOwner();
746
+ expect(result).toBeDefined();
747
+ expect(typeof result).toBe("string");
748
+ });
749
+ });
750
+ });
751
+ describe("Event tests:", () => {
752
+ describe("calss: Lock", () => {
753
+ describe("method: run", () => {
754
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
755
+ const key = "a";
756
+ const owner = "b";
757
+ const lock = lockProviderA.create(key, {
758
+ owner,
759
+ ttl: TTL,
760
+ });
761
+ let event_ = null;
762
+ const unsubscribe = await lock.subscribe(KeyAcquiredLockEvent, (event) => {
763
+ event_ = event;
764
+ });
765
+ await lock.run(async () => {
766
+ await delay(TTL);
767
+ });
768
+ await delay(TTL);
769
+ expect(event_?.fields.key).toBe("a");
770
+ expect(event_?.fields.owner).toBe(owner);
771
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
772
+ await unsubscribe();
773
+ });
774
+ test("Should dispatch KeyReleasedLockEvent when lock is not acquired", async () => {
775
+ const key = "a";
776
+ const owner = "b";
777
+ const lock = lockProviderA.create(key, {
778
+ owner,
779
+ ttl: TTL,
780
+ });
781
+ let event_ = null;
782
+ const unsubscribe = await lock.subscribe(KeyReleasedLockEvent, (event) => {
783
+ event_ = event;
784
+ });
785
+ await lock.run(async () => {
786
+ await delay(TTL);
787
+ });
788
+ await delay(TTL);
789
+ expect(event_?.fields.key).toBe(key);
790
+ expect(event_?.fields.owner).toBe(owner);
791
+ await unsubscribe();
792
+ });
793
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
794
+ const key = "a";
795
+ const owner = "b";
796
+ const lock = lockProviderA.create(key, {
797
+ owner,
798
+ });
799
+ let event_ = null;
800
+ await lock.acquire();
801
+ const unsubscribe = await lock.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
802
+ event_ = event;
803
+ });
804
+ await lock.run(async () => {
805
+ await delay(TTL);
806
+ });
807
+ await delay(TTL);
808
+ expect(event_?.fields.key).toBe("a");
809
+ expect(event_?.fields.owner).toBe(owner);
810
+ await unsubscribe();
811
+ });
812
+ });
813
+ describe("method: runBlocking", () => {
814
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
815
+ const key = "a";
816
+ const owner = "b";
817
+ const lock = lockProviderA.create(key, {
818
+ owner,
819
+ ttl: TTL,
820
+ });
821
+ let event_ = null;
822
+ const unsubscribe = await lock.subscribe(KeyAcquiredLockEvent, (event) => {
823
+ event_ = event;
824
+ });
825
+ await lock.runBlocking(async () => {
826
+ await delay(TTL);
827
+ }, {
828
+ time: TimeSpan.fromMilliseconds(1),
829
+ interval: TimeSpan.fromMilliseconds(1),
830
+ });
831
+ await delay(TTL);
832
+ expect(event_?.fields.key).toBe("a");
833
+ expect(event_?.fields.owner).toBe(owner);
834
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
835
+ await unsubscribe();
836
+ });
837
+ test("Should dispatch KeyReleasedLockEvent when lock is not acquired", async () => {
838
+ const key = "a";
839
+ const owner = "b";
840
+ const lock = lockProviderA.create(key, {
841
+ owner,
842
+ ttl: TTL,
843
+ });
844
+ let event_ = null;
845
+ const unsubscribe = await lock.subscribe(KeyReleasedLockEvent, (event) => {
846
+ event_ = event;
847
+ });
848
+ await lock.runBlocking(async () => {
849
+ await delay(TTL);
850
+ }, {
851
+ time: TimeSpan.fromMilliseconds(1),
852
+ interval: TimeSpan.fromMilliseconds(1),
853
+ });
854
+ await delay(TTL);
855
+ expect(event_?.fields.key).toBe(key);
856
+ expect(event_?.fields.owner).toBe(owner);
857
+ await unsubscribe();
858
+ });
859
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
860
+ const key = "a";
861
+ const owner = "b";
862
+ const lock = lockProviderA.create(key, {
863
+ owner,
864
+ });
865
+ let event_ = null;
866
+ await lock.acquire();
867
+ const unsubscribe = await lock.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
868
+ event_ = event;
869
+ });
870
+ await lock.runBlocking(async () => {
871
+ await delay(TTL);
872
+ }, {
873
+ time: TimeSpan.fromMilliseconds(1),
874
+ interval: TimeSpan.fromMilliseconds(1),
875
+ });
876
+ await delay(TTL);
877
+ expect(event_?.fields.key).toBe("a");
878
+ expect(event_?.fields.owner).toBe(owner);
879
+ await unsubscribe();
880
+ });
881
+ });
882
+ describe("method: runOrFail", () => {
883
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
884
+ const key = "a";
885
+ const owner = "b";
886
+ const lock = lockProviderA.create(key, {
887
+ owner,
888
+ ttl: TTL,
889
+ });
890
+ let event_ = null;
891
+ const unsubscribe = await lock.subscribe(KeyAcquiredLockEvent, (event) => {
892
+ event_ = event;
893
+ });
894
+ await lock.runOrFail(async () => {
895
+ await delay(TTL);
896
+ });
897
+ await delay(TTL);
898
+ expect(event_?.fields.key).toBe("a");
899
+ expect(event_?.fields.owner).toBe(owner);
900
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
901
+ await unsubscribe();
902
+ });
903
+ test("Should dispatch KeyReleasedLockEvent when lock is not acquired", async () => {
904
+ const key = "a";
905
+ const owner = "b";
906
+ const lock = lockProviderA.create(key, {
907
+ owner,
908
+ ttl: TTL,
909
+ });
910
+ let event_ = null;
911
+ const unsubscribe = await lock.subscribe(KeyReleasedLockEvent, (event) => {
912
+ event_ = event;
913
+ });
914
+ await lock.runOrFail(async () => {
915
+ await delay(TTL);
916
+ });
917
+ await delay(TTL);
918
+ expect(event_?.fields.key).toBe(key);
919
+ expect(event_?.fields.owner).toBe(owner);
920
+ await unsubscribe();
921
+ });
922
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
923
+ const key = "a";
924
+ const owner = "b";
925
+ const lock = lockProviderA.create(key, {
926
+ owner,
927
+ });
928
+ let event_ = null;
929
+ await lock.acquire();
930
+ const unsubscribe = await lock.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
931
+ event_ = event;
932
+ });
933
+ try {
934
+ await lock.runOrFail(async () => {
935
+ await delay(TTL);
936
+ });
937
+ await delay(TTL);
938
+ }
939
+ catch {
940
+ /* Empty */
941
+ }
942
+ expect(event_?.fields.key).toBe("a");
943
+ expect(event_?.fields.owner).toBe(owner);
944
+ await unsubscribe();
945
+ });
946
+ });
947
+ describe("method: acquire", () => {
948
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
949
+ const key = "a";
950
+ const owner = "b";
951
+ const lock = lockProviderA.create(key, {
952
+ owner,
953
+ ttl: TTL,
954
+ });
955
+ let event_ = null;
956
+ const unsubscribe = await lock.subscribe(KeyAcquiredLockEvent, (event) => {
957
+ event_ = event;
958
+ });
959
+ await lock.acquire();
960
+ await delay(TTL);
961
+ expect(event_?.fields.key).toBe("a");
962
+ expect(event_?.fields.owner).toBe(owner);
963
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
964
+ await unsubscribe();
965
+ });
966
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
967
+ const key = "a";
968
+ const owner = "b";
969
+ const lock = lockProviderA.create(key, {
970
+ owner,
971
+ });
972
+ let event_ = null;
973
+ await lock.acquire();
974
+ const unsubscribe = await lock.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
975
+ event_ = event;
976
+ });
977
+ await lock.acquire();
978
+ await delay(TTL);
979
+ expect(event_?.fields.key).toBe("a");
980
+ expect(event_?.fields.owner).toBe(owner);
981
+ await unsubscribe();
982
+ });
983
+ });
984
+ describe("method: acquireBlocking", () => {
985
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
986
+ const key = "a";
987
+ const owner = "b";
988
+ const lock = lockProviderA.create(key, {
989
+ owner,
990
+ ttl: TTL,
991
+ });
992
+ let event_ = null;
993
+ const unsubscribe = await lock.subscribe(KeyAcquiredLockEvent, (event) => {
994
+ event_ = event;
995
+ });
996
+ await lock.acquireBlocking({
997
+ time: TimeSpan.fromMilliseconds(1),
998
+ interval: TimeSpan.fromMilliseconds(1),
999
+ });
1000
+ await delay(TTL);
1001
+ expect(event_?.fields.key).toBe("a");
1002
+ expect(event_?.fields.owner).toBe(owner);
1003
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
1004
+ await unsubscribe();
1005
+ });
1006
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
1007
+ const key = "a";
1008
+ const owner = "b";
1009
+ const lock = lockProviderA.create(key, {
1010
+ owner,
1011
+ });
1012
+ let event_ = null;
1013
+ await lock.acquireBlocking({
1014
+ time: TimeSpan.fromMilliseconds(1),
1015
+ interval: TimeSpan.fromMilliseconds(1),
1016
+ });
1017
+ const unsubscribe = await lock.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
1018
+ event_ = event;
1019
+ });
1020
+ await lock.acquireBlocking({
1021
+ time: TimeSpan.fromMilliseconds(1),
1022
+ interval: TimeSpan.fromMilliseconds(1),
1023
+ });
1024
+ await delay(TTL);
1025
+ expect(event_?.fields.key).toBe("a");
1026
+ expect(event_?.fields.owner).toBe(owner);
1027
+ await unsubscribe();
1028
+ });
1029
+ });
1030
+ describe("method: acquireOrFail", () => {
1031
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
1032
+ const key = "a";
1033
+ const owner = "b";
1034
+ const lock = lockProviderA.create(key, {
1035
+ owner,
1036
+ ttl: TTL,
1037
+ });
1038
+ let event_ = null;
1039
+ const unsubscribe = await lock.subscribe(KeyAcquiredLockEvent, (event) => {
1040
+ event_ = event;
1041
+ });
1042
+ await lock.acquireOrFail();
1043
+ await delay(TTL);
1044
+ expect(event_?.fields.key).toBe("a");
1045
+ expect(event_?.fields.owner).toBe(owner);
1046
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
1047
+ await unsubscribe();
1048
+ });
1049
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
1050
+ const key = "a";
1051
+ const owner = "b";
1052
+ const lock = lockProviderA.create(key, {
1053
+ owner,
1054
+ });
1055
+ let event_ = null;
1056
+ await lock.acquireOrFail();
1057
+ const unsubscribe = await lock.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
1058
+ event_ = event;
1059
+ });
1060
+ try {
1061
+ await lock.acquireOrFail();
1062
+ await delay(TTL);
1063
+ }
1064
+ catch {
1065
+ /* Empty */
1066
+ }
1067
+ expect(event_?.fields.key).toBe("a");
1068
+ expect(event_?.fields.owner).toBe(owner);
1069
+ await unsubscribe();
1070
+ });
1071
+ });
1072
+ describe("method: release", () => {
1073
+ test("Should dispatch KeyReleasedLockEvent when released by same owner", async () => {
1074
+ const key = "a";
1075
+ const owner = "b";
1076
+ const lock = lockProviderA.create(key, {
1077
+ owner,
1078
+ });
1079
+ await lock.acquire();
1080
+ let event_ = null;
1081
+ const unsubscribe = await lock.subscribe(KeyReleasedLockEvent, (event) => {
1082
+ event_ = event;
1083
+ });
1084
+ await lock.release();
1085
+ await delay(TTL);
1086
+ expect(event_?.fields.key).toBe(key);
1087
+ expect(event_?.fields.owner).toBe(owner);
1088
+ await unsubscribe();
1089
+ });
1090
+ test("Should dispatch UnownedReleaseLockEvent when released by same owner", async () => {
1091
+ const key = "a";
1092
+ const owner1 = "b";
1093
+ const lock1 = lockProviderA.create(key, {
1094
+ owner: owner1,
1095
+ });
1096
+ await lock1.acquire();
1097
+ const owner2 = "c";
1098
+ const lock2 = lockProviderA.create(key, {
1099
+ owner: owner2,
1100
+ });
1101
+ let event_ = null;
1102
+ const unsubscribe = await lock1.subscribe(UnownedReleaseLockEvent, (event) => {
1103
+ event_ = event;
1104
+ });
1105
+ await lock2.release();
1106
+ await delay(TTL);
1107
+ expect(event_?.fields.key).toBe(key);
1108
+ expect(event_?.fields.owner).toBe(owner2);
1109
+ await unsubscribe();
1110
+ });
1111
+ });
1112
+ describe("method: releaseOrFail", () => {
1113
+ test("Should dispatch KeyReleasedLockEvent when released by same owner", async () => {
1114
+ const key = "a";
1115
+ const owner = "b";
1116
+ const lock = lockProviderA.create(key, {
1117
+ owner,
1118
+ });
1119
+ await lock.acquire();
1120
+ let event_ = null;
1121
+ const unsubscribe = await lock.subscribe(KeyReleasedLockEvent, (event) => {
1122
+ event_ = event;
1123
+ });
1124
+ await lock.releaseOrFail();
1125
+ await delay(TTL);
1126
+ expect(event_?.fields.key).toBe(key);
1127
+ expect(event_?.fields.owner).toBe(owner);
1128
+ await unsubscribe();
1129
+ });
1130
+ test("Should dispatch UnownedReleaseLockEvent when released by same owner", async () => {
1131
+ const key = "a";
1132
+ const owner1 = "b";
1133
+ const lock1 = lockProviderA.create(key, {
1134
+ owner: owner1,
1135
+ });
1136
+ await lock1.acquire();
1137
+ const owner2 = "c";
1138
+ const lock2 = lockProviderA.create(key, {
1139
+ owner: owner2,
1140
+ });
1141
+ let event_ = null;
1142
+ const unsubscribe = await lock1.subscribe(UnownedReleaseLockEvent, (event) => {
1143
+ event_ = event;
1144
+ });
1145
+ try {
1146
+ await lock2.releaseOrFail();
1147
+ await delay(TTL);
1148
+ }
1149
+ catch {
1150
+ /* Empty */
1151
+ }
1152
+ expect(event_?.fields.key).toBe(key);
1153
+ expect(event_?.fields.owner).toBe(owner2);
1154
+ await unsubscribe();
1155
+ });
1156
+ });
1157
+ describe("method: forceRelease", () => {
1158
+ test("Should dispatch KeyForceReleasedLockEvent when lock forcefully released", async () => {
1159
+ const key = "a";
1160
+ const owner1 = "b";
1161
+ const lock1 = lockProviderA.create(key, {
1162
+ owner: owner1,
1163
+ });
1164
+ await lock1.acquire();
1165
+ const owner2 = "c";
1166
+ const lock2 = lockProviderA.create(key, {
1167
+ owner: owner2,
1168
+ });
1169
+ let event_ = null;
1170
+ const unsubscribe = await lock1.subscribe(KeyForceReleasedLockEvent, (event) => {
1171
+ event_ = event;
1172
+ });
1173
+ await lock2.forceRelease();
1174
+ await delay(TTL);
1175
+ expect(event_?.fields.key).toBe(key);
1176
+ await unsubscribe();
1177
+ });
1178
+ });
1179
+ describe("method: refresh", () => {
1180
+ test("Should dispatch KeyRefreshedLockEvent when refreshed by same owner", async () => {
1181
+ const key = "a";
1182
+ const owner = "b";
1183
+ const lock = lockProviderA.create(key, {
1184
+ owner,
1185
+ ttl: TTL,
1186
+ });
1187
+ await lock.acquire();
1188
+ let event_ = null;
1189
+ const unsubscribe = await lock.subscribe(KeyRefreshedLockEvent, (event) => {
1190
+ event_ = event;
1191
+ });
1192
+ await delay(TTL.divide(2));
1193
+ const newTTL = TTL.multiply(2);
1194
+ await lock.refresh(newTTL);
1195
+ await delay(TTL);
1196
+ expect(event_?.fields.key).toBe(key);
1197
+ expect(event_?.fields.owner).toBe(owner);
1198
+ expect(event_?.fields.ttl.toMilliseconds()).toBe(newTTL.toMilliseconds());
1199
+ await unsubscribe();
1200
+ });
1201
+ test("Should dispatch UnownedRefreshLockEvent when refreshed by different owner", async () => {
1202
+ const key = "a";
1203
+ const owner1 = "b";
1204
+ const lock1 = lockProviderA.create(key, {
1205
+ owner: owner1,
1206
+ ttl: TTL,
1207
+ });
1208
+ await lock1.acquire();
1209
+ const owner2 = "c";
1210
+ const lock2 = lockProviderA.create(key, {
1211
+ owner: owner2,
1212
+ });
1213
+ let event_ = null;
1214
+ const unsubscribe = await lock1.subscribe(UnownedRefreshLockEvent, (event) => {
1215
+ event_ = event;
1216
+ });
1217
+ await delay(TTL.divide(2));
1218
+ const newTTL = TTL.multiply(2);
1219
+ await lock2.refresh(newTTL);
1220
+ await delay(TTL);
1221
+ expect(event_?.fields.key).toBe(key);
1222
+ expect(event_?.fields.owner).toBe(owner2);
1223
+ await unsubscribe();
1224
+ });
1225
+ });
1226
+ describe("method: refreshOrFail", () => {
1227
+ test("Should dispatch KeyRefreshedLockEvent when refreshed by same owner", async () => {
1228
+ const key = "a";
1229
+ const owner = "b";
1230
+ const lock = lockProviderA.create(key, {
1231
+ owner,
1232
+ ttl: TTL,
1233
+ });
1234
+ await lock.acquire();
1235
+ let event_ = null;
1236
+ const unsubscribe = await lock.subscribe(KeyRefreshedLockEvent, (event) => {
1237
+ event_ = event;
1238
+ });
1239
+ await delay(TTL.divide(2));
1240
+ const newTTL = TTL.multiply(2);
1241
+ await lock.refreshOrFail(newTTL);
1242
+ await delay(TTL);
1243
+ expect(event_?.fields.key).toBe(key);
1244
+ expect(event_?.fields.owner).toBe(owner);
1245
+ expect(event_?.fields.ttl.toMilliseconds()).toBe(newTTL.toMilliseconds());
1246
+ await unsubscribe();
1247
+ });
1248
+ test("Should dispatch UnownedRefreshLockEvent when refreshed by different owner", async () => {
1249
+ const key = "a";
1250
+ const owner1 = "b";
1251
+ const lock1 = lockProviderA.create(key, {
1252
+ owner: owner1,
1253
+ ttl: TTL,
1254
+ });
1255
+ await lock1.acquire();
1256
+ const owner2 = "c";
1257
+ const lock2 = lockProviderA.create(key, {
1258
+ owner: owner2,
1259
+ });
1260
+ let event_ = null;
1261
+ const unsubscribe = await lock1.subscribe(UnownedRefreshLockEvent, (event) => {
1262
+ event_ = event;
1263
+ });
1264
+ await delay(TTL.divide(2));
1265
+ const newTTL = TTL.multiply(2);
1266
+ try {
1267
+ await lock2.refreshOrFail(newTTL);
1268
+ await delay(TTL);
1269
+ }
1270
+ catch {
1271
+ /* Empty */
1272
+ }
1273
+ expect(event_?.fields.key).toBe(key);
1274
+ expect(event_?.fields.owner).toBe(owner2);
1275
+ await unsubscribe();
1276
+ });
1277
+ });
1278
+ });
1279
+ describe("LockProvider:", () => {
1280
+ describe("method: run", () => {
1281
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
1282
+ const key = "a";
1283
+ const owner = "b";
1284
+ const lock = lockProviderA.create(key, {
1285
+ owner,
1286
+ ttl: TTL,
1287
+ });
1288
+ let event_ = null;
1289
+ const unsubscribe = await lockProviderA.subscribe(KeyAcquiredLockEvent, (event) => {
1290
+ event_ = event;
1291
+ });
1292
+ await lock.run(async () => {
1293
+ await delay(TTL);
1294
+ });
1295
+ await delay(TTL);
1296
+ expect(event_?.fields.key).toBe("a");
1297
+ expect(event_?.fields.owner).toBe(owner);
1298
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
1299
+ await unsubscribe();
1300
+ });
1301
+ test("Should dispatch KeyReleasedLockEvent when lock is not acquired", async () => {
1302
+ const key = "a";
1303
+ const owner = "b";
1304
+ const lock = lockProviderA.create(key, {
1305
+ owner,
1306
+ ttl: TTL,
1307
+ });
1308
+ let event_ = null;
1309
+ const unsubscribe = await lockProviderA.subscribe(KeyReleasedLockEvent, (event) => {
1310
+ event_ = event;
1311
+ });
1312
+ await lock.run(async () => {
1313
+ await delay(TTL);
1314
+ });
1315
+ await delay(TTL);
1316
+ expect(event_?.fields.key).toBe(key);
1317
+ expect(event_?.fields.owner).toBe(owner);
1318
+ await unsubscribe();
1319
+ });
1320
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
1321
+ const key = "a";
1322
+ const owner = "b";
1323
+ const lock = lockProviderA.create(key, {
1324
+ owner,
1325
+ });
1326
+ let event_ = null;
1327
+ await lock.acquire();
1328
+ const unsubscribe = await lockProviderA.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
1329
+ event_ = event;
1330
+ });
1331
+ await lock.run(async () => {
1332
+ await delay(TTL);
1333
+ });
1334
+ await delay(TTL);
1335
+ expect(event_?.fields.key).toBe("a");
1336
+ expect(event_?.fields.owner).toBe(owner);
1337
+ await unsubscribe();
1338
+ });
1339
+ });
1340
+ describe("method: runBlocking", () => {
1341
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
1342
+ const key = "a";
1343
+ const owner = "b";
1344
+ const lock = lockProviderA.create(key, {
1345
+ owner,
1346
+ ttl: TTL,
1347
+ });
1348
+ let event_ = null;
1349
+ const unsubscribe = await lockProviderA.subscribe(KeyAcquiredLockEvent, (event) => {
1350
+ event_ = event;
1351
+ });
1352
+ await lock.runBlocking(async () => {
1353
+ await delay(TTL);
1354
+ }, {
1355
+ time: TimeSpan.fromMilliseconds(1),
1356
+ interval: TimeSpan.fromMilliseconds(1),
1357
+ });
1358
+ await delay(TTL);
1359
+ expect(event_?.fields.key).toBe("a");
1360
+ expect(event_?.fields.owner).toBe(owner);
1361
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
1362
+ await unsubscribe();
1363
+ });
1364
+ test("Should dispatch KeyReleasedLockEvent when lock is not acquired", async () => {
1365
+ const key = "a";
1366
+ const owner = "b";
1367
+ const lock = lockProviderA.create(key, {
1368
+ owner,
1369
+ ttl: TTL,
1370
+ });
1371
+ let event_ = null;
1372
+ const unsubscribe = await lockProviderA.subscribe(KeyReleasedLockEvent, (event) => {
1373
+ event_ = event;
1374
+ });
1375
+ await lock.runBlocking(async () => {
1376
+ await delay(TTL);
1377
+ }, {
1378
+ time: TimeSpan.fromMilliseconds(1),
1379
+ interval: TimeSpan.fromMilliseconds(1),
1380
+ });
1381
+ await delay(TTL);
1382
+ expect(event_?.fields.key).toBe(key);
1383
+ expect(event_?.fields.owner).toBe(owner);
1384
+ await unsubscribe();
1385
+ });
1386
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
1387
+ const key = "a";
1388
+ const owner = "b";
1389
+ const lock = lockProviderA.create(key, {
1390
+ owner,
1391
+ });
1392
+ let event_ = null;
1393
+ await lock.acquire();
1394
+ const unsubscribe = await lockProviderA.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
1395
+ event_ = event;
1396
+ });
1397
+ await lock.runBlocking(async () => {
1398
+ await delay(TTL);
1399
+ }, {
1400
+ time: TimeSpan.fromMilliseconds(1),
1401
+ interval: TimeSpan.fromMilliseconds(1),
1402
+ });
1403
+ await delay(TTL);
1404
+ expect(event_?.fields.key).toBe("a");
1405
+ expect(event_?.fields.owner).toBe(owner);
1406
+ await unsubscribe();
1407
+ });
1408
+ });
1409
+ describe("method: runOrFail", () => {
1410
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
1411
+ const key = "a";
1412
+ const owner = "b";
1413
+ const lock = lockProviderA.create(key, {
1414
+ owner,
1415
+ ttl: TTL,
1416
+ });
1417
+ let event_ = null;
1418
+ const unsubscribe = await lockProviderA.subscribe(KeyAcquiredLockEvent, (event) => {
1419
+ event_ = event;
1420
+ });
1421
+ await lock.runOrFail(async () => {
1422
+ await delay(TTL);
1423
+ });
1424
+ await delay(TTL);
1425
+ expect(event_?.fields.key).toBe("a");
1426
+ expect(event_?.fields.owner).toBe(owner);
1427
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
1428
+ await unsubscribe();
1429
+ });
1430
+ test("Should dispatch KeyReleasedLockEvent when lock is not acquired", async () => {
1431
+ const key = "a";
1432
+ const owner = "b";
1433
+ const lock = lockProviderA.create(key, {
1434
+ owner,
1435
+ ttl: TTL,
1436
+ });
1437
+ let event_ = null;
1438
+ const unsubscribe = await lockProviderA.subscribe(KeyReleasedLockEvent, (event) => {
1439
+ event_ = event;
1440
+ });
1441
+ await lock.runOrFail(async () => {
1442
+ await delay(TTL);
1443
+ });
1444
+ await delay(TTL);
1445
+ expect(event_?.fields.key).toBe(key);
1446
+ expect(event_?.fields.owner).toBe(owner);
1447
+ await unsubscribe();
1448
+ });
1449
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
1450
+ const key = "a";
1451
+ const owner = "b";
1452
+ const lock = lockProviderA.create(key, {
1453
+ owner,
1454
+ });
1455
+ let event_ = null;
1456
+ await lock.acquire();
1457
+ const unsubscribe = await lockProviderA.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
1458
+ event_ = event;
1459
+ });
1460
+ try {
1461
+ await lock.runOrFail(async () => {
1462
+ await delay(TTL);
1463
+ });
1464
+ await delay(TTL);
1465
+ }
1466
+ catch {
1467
+ /* Empty */
1468
+ }
1469
+ expect(event_?.fields.key).toBe("a");
1470
+ expect(event_?.fields.owner).toBe(owner);
1471
+ await unsubscribe();
1472
+ });
1473
+ });
1474
+ describe("method: acquire", () => {
1475
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
1476
+ const key = "a";
1477
+ const owner = "b";
1478
+ const lock = lockProviderA.create(key, {
1479
+ owner,
1480
+ ttl: TTL,
1481
+ });
1482
+ let event_ = null;
1483
+ const unsubscribe = await lockProviderA.subscribe(KeyAcquiredLockEvent, (event) => {
1484
+ event_ = event;
1485
+ });
1486
+ await lock.acquire();
1487
+ await delay(TTL);
1488
+ expect(event_?.fields.key).toBe("a");
1489
+ expect(event_?.fields.owner).toBe(owner);
1490
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
1491
+ await unsubscribe();
1492
+ });
1493
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
1494
+ const key = "a";
1495
+ const owner = "b";
1496
+ const lock = lockProviderA.create(key, {
1497
+ owner,
1498
+ });
1499
+ let event_ = null;
1500
+ await lock.acquire();
1501
+ const unsubscribe = await lockProviderA.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
1502
+ event_ = event;
1503
+ });
1504
+ await lock.acquire();
1505
+ await delay(TTL);
1506
+ expect(event_?.fields.key).toBe("a");
1507
+ expect(event_?.fields.owner).toBe(owner);
1508
+ await unsubscribe();
1509
+ });
1510
+ });
1511
+ describe("method: acquireBlocking", () => {
1512
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
1513
+ const key = "a";
1514
+ const owner = "b";
1515
+ const lock = lockProviderA.create(key, {
1516
+ owner,
1517
+ ttl: TTL,
1518
+ });
1519
+ let event_ = null;
1520
+ const unsubscribe = await lockProviderA.subscribe(KeyAcquiredLockEvent, (event) => {
1521
+ event_ = event;
1522
+ });
1523
+ await lock.acquire();
1524
+ await delay(TTL);
1525
+ expect(event_?.fields.key).toBe("a");
1526
+ expect(event_?.fields.owner).toBe(owner);
1527
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
1528
+ await unsubscribe();
1529
+ });
1530
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
1531
+ const key = "a";
1532
+ const owner = "b";
1533
+ const lock = lockProviderA.create(key, {
1534
+ owner,
1535
+ });
1536
+ let event_ = null;
1537
+ await lock.acquire();
1538
+ const unsubscribe = await lockProviderA.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
1539
+ event_ = event;
1540
+ });
1541
+ await lock.acquire();
1542
+ await delay(TTL);
1543
+ expect(event_?.fields.key).toBe("a");
1544
+ expect(event_?.fields.owner).toBe(owner);
1545
+ await unsubscribe();
1546
+ });
1547
+ });
1548
+ describe("method: acquireOrFail", () => {
1549
+ test("Should dispatch KeyAcquiredLockEvent when lock is not acquired", async () => {
1550
+ const key = "a";
1551
+ const owner = "b";
1552
+ const lock = lockProviderA.create(key, {
1553
+ owner,
1554
+ ttl: TTL,
1555
+ });
1556
+ let event_ = null;
1557
+ const unsubscribe = await lockProviderA.subscribe(KeyAcquiredLockEvent, (event) => {
1558
+ event_ = event;
1559
+ });
1560
+ await lock.acquireOrFail();
1561
+ await delay(TTL);
1562
+ expect(event_?.fields.key).toBe("a");
1563
+ expect(event_?.fields.owner).toBe(owner);
1564
+ expect(event_?.fields.ttl?.toMilliseconds()).toBe(TTL.toMilliseconds());
1565
+ await unsubscribe();
1566
+ });
1567
+ test("Should dispatch KeyAlreadyAcquiredLockEvent when lock is acquired", async () => {
1568
+ const key = "a";
1569
+ const owner = "b";
1570
+ const lock = lockProviderA.create(key, {
1571
+ owner,
1572
+ });
1573
+ let event_ = null;
1574
+ await lock.acquireOrFail();
1575
+ const unsubscribe = await lockProviderA.subscribe(KeyAlreadyAcquiredLockEvent, (event) => {
1576
+ event_ = event;
1577
+ });
1578
+ try {
1579
+ await lock.acquireOrFail();
1580
+ await delay(TTL);
1581
+ }
1582
+ catch {
1583
+ /* Empty */
1584
+ }
1585
+ expect(event_?.fields.key).toBe("a");
1586
+ expect(event_?.fields.owner).toBe(owner);
1587
+ await unsubscribe();
1588
+ });
1589
+ });
1590
+ describe("method: release", () => {
1591
+ test("Should dispatch KeyReleasedLockEvent when released by same owner", async () => {
1592
+ const key = "a";
1593
+ const owner = "b";
1594
+ const lock = lockProviderA.create(key, {
1595
+ owner,
1596
+ });
1597
+ await lock.acquire();
1598
+ let event_ = null;
1599
+ const unsubscribe = await lockProviderA.subscribe(KeyReleasedLockEvent, (event) => {
1600
+ event_ = event;
1601
+ });
1602
+ await lock.release();
1603
+ await delay(TTL);
1604
+ expect(event_?.fields.key).toBe(key);
1605
+ expect(event_?.fields.owner).toBe(owner);
1606
+ await unsubscribe();
1607
+ });
1608
+ test("Should dispatch UnownedReleaseLockEvent when released by same owner", async () => {
1609
+ const key = "a";
1610
+ const owner1 = "b";
1611
+ const lock1 = lockProviderA.create(key, {
1612
+ owner: owner1,
1613
+ });
1614
+ await lock1.acquire();
1615
+ const owner2 = "c";
1616
+ const lock2 = lockProviderA.create(key, {
1617
+ owner: owner2,
1618
+ });
1619
+ let event_ = null;
1620
+ const unsubscribe = await lock1.subscribe(UnownedReleaseLockEvent, (event) => {
1621
+ event_ = event;
1622
+ });
1623
+ await lock2.release();
1624
+ await delay(TTL);
1625
+ expect(event_?.fields.key).toBe(key);
1626
+ expect(event_?.fields.owner).toBe(owner2);
1627
+ await unsubscribe();
1628
+ });
1629
+ });
1630
+ describe("method: releaseOrFail", () => {
1631
+ test("Should dispatch KeyReleasedLockEvent when released by same owner", async () => {
1632
+ const key = "a";
1633
+ const owner = "b";
1634
+ const lock = lockProviderA.create(key, {
1635
+ owner,
1636
+ });
1637
+ await lock.acquire();
1638
+ let event_ = null;
1639
+ const unsubscribe = await lockProviderA.subscribe(KeyReleasedLockEvent, (event) => {
1640
+ event_ = event;
1641
+ });
1642
+ await lock.releaseOrFail();
1643
+ await delay(TTL);
1644
+ expect(event_?.fields.key).toBe(key);
1645
+ expect(event_?.fields.owner).toBe(owner);
1646
+ await unsubscribe();
1647
+ });
1648
+ test("Should dispatch UnownedReleaseLockEvent when released by same owner", async () => {
1649
+ const key = "a";
1650
+ const owner1 = "b";
1651
+ const lock1 = lockProviderA.create(key, {
1652
+ owner: owner1,
1653
+ });
1654
+ await lock1.acquire();
1655
+ const owner2 = "c";
1656
+ const lock2 = lockProviderA.create(key, {
1657
+ owner: owner2,
1658
+ });
1659
+ let event_ = null;
1660
+ const unsubscribe = await lock1.subscribe(UnownedReleaseLockEvent, (event) => {
1661
+ event_ = event;
1662
+ });
1663
+ try {
1664
+ await lock2.releaseOrFail();
1665
+ await delay(TTL);
1666
+ }
1667
+ catch {
1668
+ /* Empty */
1669
+ }
1670
+ expect(event_?.fields.key).toBe(key);
1671
+ expect(event_?.fields.owner).toBe(owner2);
1672
+ await unsubscribe();
1673
+ });
1674
+ });
1675
+ describe("method: forceRelease", () => {
1676
+ test("Should dispatch KeyForceReleasedLockEvent when lock forcefully released", async () => {
1677
+ const key = "a";
1678
+ const owner1 = "b";
1679
+ const lock1 = lockProviderA.create(key, {
1680
+ owner: owner1,
1681
+ });
1682
+ await lock1.acquire();
1683
+ const owner2 = "c";
1684
+ const lock2 = lockProviderA.create(key, {
1685
+ owner: owner2,
1686
+ });
1687
+ let event_ = null;
1688
+ const unsubscribe = await lock1.subscribe(KeyForceReleasedLockEvent, (event) => {
1689
+ event_ = event;
1690
+ });
1691
+ await lock2.forceRelease();
1692
+ await delay(TTL);
1693
+ expect(event_?.fields.key).toBe(key);
1694
+ await unsubscribe();
1695
+ });
1696
+ });
1697
+ describe("method: refresh", () => {
1698
+ test("Should dispatch KeyRefreshedLockEvent when refreshed by same owner", async () => {
1699
+ const key = "a";
1700
+ const owner = "b";
1701
+ const lock = lockProviderA.create(key, {
1702
+ owner,
1703
+ ttl: TTL,
1704
+ });
1705
+ await lock.acquire();
1706
+ let event_ = null;
1707
+ const unsubscribe = await lockProviderA.subscribe(KeyRefreshedLockEvent, (event) => {
1708
+ event_ = event;
1709
+ });
1710
+ await delay(TTL.divide(2));
1711
+ const newTTL = TTL.multiply(2);
1712
+ await lock.refresh(newTTL);
1713
+ await delay(TTL);
1714
+ expect(event_?.fields.key).toBe(key);
1715
+ expect(event_?.fields.owner).toBe(owner);
1716
+ expect(event_?.fields.ttl.toMilliseconds()).toBe(newTTL.toMilliseconds());
1717
+ await unsubscribe();
1718
+ });
1719
+ test("Should dispatch UnownedRefreshLockEvent when refreshed by different owner", async () => {
1720
+ const key = "a";
1721
+ const owner1 = "b";
1722
+ const lock1 = lockProviderA.create(key, {
1723
+ owner: owner1,
1724
+ ttl: TTL,
1725
+ });
1726
+ await lock1.acquire();
1727
+ const owner2 = "c";
1728
+ const lock2 = lockProviderA.create(key, {
1729
+ owner: owner2,
1730
+ });
1731
+ let event_ = null;
1732
+ const unsubscribe = await lock1.subscribe(UnownedRefreshLockEvent, (event) => {
1733
+ event_ = event;
1734
+ });
1735
+ await delay(TTL.divide(2));
1736
+ const newTTL = TTL.multiply(2);
1737
+ await lock2.refresh(newTTL);
1738
+ await delay(TTL);
1739
+ expect(event_?.fields.key).toBe(key);
1740
+ expect(event_?.fields.owner).toBe(owner2);
1741
+ await unsubscribe();
1742
+ });
1743
+ });
1744
+ describe("method: refreshOrFail", () => {
1745
+ test("Should dispatch KeyRefreshedLockEvent when refreshed by same owner", async () => {
1746
+ const key = "a";
1747
+ const owner = "b";
1748
+ const lock = lockProviderA.create(key, {
1749
+ owner,
1750
+ ttl: TTL,
1751
+ });
1752
+ await lock.acquire();
1753
+ let event_ = null;
1754
+ const unsubscribe = await lockProviderA.subscribe(KeyRefreshedLockEvent, (event) => {
1755
+ event_ = event;
1756
+ });
1757
+ await delay(TTL.divide(2));
1758
+ const newTTL = TTL.multiply(2);
1759
+ await lock.refreshOrFail(newTTL);
1760
+ await delay(TTL);
1761
+ expect(event_?.fields.key).toBe(key);
1762
+ expect(event_?.fields.owner).toBe(owner);
1763
+ expect(event_?.fields.ttl.toMilliseconds()).toBe(newTTL.toMilliseconds());
1764
+ await unsubscribe();
1765
+ });
1766
+ test("Should dispatch UnownedRefreshLockEvent when refreshed by different owner", async () => {
1767
+ const key = "a";
1768
+ const owner1 = "b";
1769
+ const lock1 = lockProviderA.create(key, {
1770
+ owner: owner1,
1771
+ ttl: TTL,
1772
+ });
1773
+ await lock1.acquire();
1774
+ const owner2 = "c";
1775
+ const lock2 = lockProviderA.create(key, {
1776
+ owner: owner2,
1777
+ });
1778
+ let event_ = null;
1779
+ const unsubscribe = await lock1.subscribe(UnownedRefreshLockEvent, (event) => {
1780
+ event_ = event;
1781
+ });
1782
+ await delay(TTL.divide(2));
1783
+ const newTTL = TTL.multiply(2);
1784
+ try {
1785
+ await lock2.refreshOrFail(newTTL);
1786
+ await delay(TTL);
1787
+ }
1788
+ catch {
1789
+ /* Empty */
1790
+ }
1791
+ expect(event_?.fields.key).toBe(key);
1792
+ expect(event_?.fields.owner).toBe(owner2);
1793
+ await unsubscribe();
1794
+ });
1795
+ });
1796
+ });
1797
+ });
1798
+ describe("Group tests:", () => {
1799
+ test("method: run", async () => {
1800
+ const key = "a";
1801
+ const ownerA = "b";
1802
+ const lockA = lockProviderA.create(key, {
1803
+ owner: ownerA,
1804
+ });
1805
+ const promiseA = lockA.run(async () => {
1806
+ await delay(TTL);
1807
+ return "a";
1808
+ });
1809
+ const ownerB = "c";
1810
+ const lockB = lockProviderB.create(key, {
1811
+ owner: ownerB,
1812
+ });
1813
+ const promiseB = lockB.run(async () => {
1814
+ await delay(TTL);
1815
+ return "a";
1816
+ });
1817
+ const [[resultA, errorA], [resultB, errorB]] = await Promise.all([
1818
+ promiseA,
1819
+ promiseB,
1820
+ ]);
1821
+ expect(resultA).toBe("a");
1822
+ expect(errorA).toBeNull();
1823
+ expect(resultB).toBe("a");
1824
+ expect(errorB).toBeNull();
1825
+ });
1826
+ test("method: runBlocking", async () => {
1827
+ const key = "a";
1828
+ const ownerA = "b";
1829
+ const lockA = lockProviderA.create(key, {
1830
+ owner: ownerA,
1831
+ });
1832
+ const promiseA = lockA.run(async () => {
1833
+ await delay(TTL);
1834
+ return "a";
1835
+ });
1836
+ const ownerB = "c";
1837
+ const lockB = lockProviderB.create(key, {
1838
+ owner: ownerB,
1839
+ });
1840
+ const promiseB = lockB.runBlocking(async () => {
1841
+ await delay(TTL);
1842
+ return "a";
1843
+ }, {
1844
+ time: TimeSpan.fromMilliseconds(1),
1845
+ interval: TimeSpan.fromMilliseconds(1),
1846
+ });
1847
+ const [[resultA, errorA], [resultB, errorB]] = await Promise.all([
1848
+ promiseA,
1849
+ promiseB,
1850
+ ]);
1851
+ expect(resultA).toBe("a");
1852
+ expect(errorA).toBeNull();
1853
+ expect(resultB).toBe("a");
1854
+ expect(errorB).toBeNull();
1855
+ });
1856
+ test("method: runOrFail", async () => {
1857
+ const key = "a";
1858
+ const ownerA = "b";
1859
+ const lockA = lockProviderA.create(key, {
1860
+ owner: ownerA,
1861
+ });
1862
+ const promiseA = lockA.runOrFail(async () => {
1863
+ await delay(TTL);
1864
+ return "a";
1865
+ });
1866
+ const ownerB = "c";
1867
+ const lockB = lockProviderB.create(key, {
1868
+ owner: ownerB,
1869
+ });
1870
+ const promiseB = lockB.runOrFail(async () => {
1871
+ await delay(TTL);
1872
+ return "a";
1873
+ });
1874
+ const [resultA, resultB] = await Promise.all([promiseA, promiseB]);
1875
+ expect(resultA).toBe("a");
1876
+ expect(resultB).toBe("a");
1877
+ });
1878
+ test("method: acquire", async () => {
1879
+ const key = "a";
1880
+ const ownerA = "b";
1881
+ const lockA = lockProviderA.create(key, {
1882
+ owner: ownerA,
1883
+ });
1884
+ const resultA = await lockA.acquire();
1885
+ const ownerB = "c";
1886
+ const lockB = lockProviderB.create(key, {
1887
+ owner: ownerB,
1888
+ });
1889
+ const resultB = await lockB.acquire();
1890
+ expect(resultA).toBe(true);
1891
+ expect(resultB).toBe(true);
1892
+ });
1893
+ test("method: acquireBlocking", async () => {
1894
+ const key = "a";
1895
+ const ownerA = "b";
1896
+ const lockA = lockProviderA.create(key, {
1897
+ owner: ownerA,
1898
+ });
1899
+ const resultA = await lockA.acquireBlocking({
1900
+ time: TimeSpan.fromMilliseconds(1),
1901
+ interval: TimeSpan.fromMilliseconds(1),
1902
+ });
1903
+ const ownerB = "c";
1904
+ const lockB = lockProviderB.create(key, {
1905
+ owner: ownerB,
1906
+ });
1907
+ const resultB = await lockB.acquire();
1908
+ expect(resultA).toBe(true);
1909
+ expect(resultB).toBe(true);
1910
+ });
1911
+ test("method: acquireOrFail", async () => {
1912
+ const key = "a";
1913
+ const ownerA = "b";
1914
+ const lockA = lockProviderA.create(key, {
1915
+ owner: ownerA,
1916
+ });
1917
+ const promiseA = lockA.acquireOrFail();
1918
+ const ownerB = "c";
1919
+ const lockB = lockProviderB.create(key, {
1920
+ owner: ownerB,
1921
+ });
1922
+ const promiseB = lockB.acquireOrFail();
1923
+ await expect(promiseA).resolves.toBeUndefined();
1924
+ await expect(promiseB).resolves.toBeUndefined();
1925
+ });
1926
+ test("method: release", async () => {
1927
+ const key = "a";
1928
+ const owner = "b";
1929
+ const lockA = lockProviderA.create(key, {
1930
+ owner,
1931
+ });
1932
+ await lockA.acquire();
1933
+ const lockB = lockProviderB.create(key, {
1934
+ owner,
1935
+ });
1936
+ await lockB.acquire();
1937
+ await lockA.release();
1938
+ const resultA = await lockA.isLocked();
1939
+ const resultB = await lockB.isLocked();
1940
+ expect(resultA).toBe(false);
1941
+ expect(resultB).toBe(true);
1942
+ });
1943
+ test("method: releaseOrFail", async () => {
1944
+ const key = "a";
1945
+ const owner = "b";
1946
+ const lockA = lockProviderA.create(key, {
1947
+ owner,
1948
+ });
1949
+ await lockA.acquire();
1950
+ const lockB = lockProviderB.create(key, {
1951
+ owner,
1952
+ });
1953
+ await lockB.acquire();
1954
+ await lockA.releaseOrFail();
1955
+ const resultA = await lockA.isLocked();
1956
+ const resultB = await lockB.isLocked();
1957
+ expect(resultA).toBe(false);
1958
+ expect(resultB).toBe(true);
1959
+ });
1960
+ test("method: forceRelease", async () => {
1961
+ const key = "a";
1962
+ const owner = "b";
1963
+ const lockA = lockProviderA.create(key, {
1964
+ owner,
1965
+ });
1966
+ await lockA.acquire();
1967
+ const lockB = lockProviderB.create(key, {
1968
+ owner,
1969
+ });
1970
+ await lockB.acquire();
1971
+ await lockA.forceRelease();
1972
+ const resultA = await lockA.isLocked();
1973
+ const resultB = await lockB.isLocked();
1974
+ expect(resultA).toBe(false);
1975
+ expect(resultB).toBe(true);
1976
+ });
1977
+ test("method: isExpired", async () => {
1978
+ const key = "a";
1979
+ const owner = "b";
1980
+ const lockA = lockProviderA.create(key, { owner });
1981
+ const lockB = lockProviderB.create(key, { owner });
1982
+ await lockA.acquire();
1983
+ await lockB.acquire();
1984
+ await lockA.release();
1985
+ const resultA = await lockA.isExpired();
1986
+ const resultB = await lockB.isExpired();
1987
+ expect(resultA).toBe(true);
1988
+ expect(resultB).toBe(false);
1989
+ });
1990
+ test("method: isLocked", async () => {
1991
+ const key = "a";
1992
+ const owner = "b";
1993
+ const lockA = lockProviderA.create(key, { owner });
1994
+ const lockB = lockProviderB.create(key, { owner });
1995
+ await lockA.acquire();
1996
+ await lockB.acquire();
1997
+ await lockA.release();
1998
+ const resultA = await lockA.isLocked();
1999
+ const resultB = await lockB.isLocked();
2000
+ expect(resultA).toBe(false);
2001
+ expect(resultB).toBe(true);
2002
+ });
2003
+ test("method: refresh", async () => {
2004
+ const key = "a";
2005
+ const owner = "b";
2006
+ const ttl = TTL;
2007
+ const lockA = lockProviderA.create(key, {
2008
+ owner,
2009
+ ttl,
2010
+ });
2011
+ const lockB = lockProviderB.create(key, {
2012
+ owner,
2013
+ ttl,
2014
+ });
2015
+ await Promise.all([lockA.acquire(), lockB.acquire()]);
2016
+ await delay(ttl.divide(2));
2017
+ await lockA.refresh();
2018
+ await delay(ttl.divide(2));
2019
+ const resultA = await lockA.isExpired();
2020
+ const resultB = await lockB.isExpired();
2021
+ expect(resultA).toBe(false);
2022
+ expect(resultB).toBe(true);
2023
+ });
2024
+ test("method: refreshOrFail", async () => {
2025
+ const key = "a";
2026
+ const owner = "b";
2027
+ const ttl = TTL;
2028
+ const lockA = lockProviderA.create(key, {
2029
+ owner,
2030
+ ttl,
2031
+ });
2032
+ const lockB = lockProviderB.create(key, {
2033
+ owner,
2034
+ ttl,
2035
+ });
2036
+ await Promise.all([lockA.acquire(), lockB.acquire()]);
2037
+ await delay(ttl.divide(2));
2038
+ await lockA.refreshOrFail();
2039
+ await delay(ttl.divide(2));
2040
+ const resultA = await lockA.isExpired();
2041
+ const resultB = await lockB.isExpired();
2042
+ expect(resultA).toBe(false);
2043
+ expect(resultB).toBe(true);
2044
+ });
2045
+ describe("class: Lock", () => {
2046
+ test("method: addListener / dispatch", async () => {
2047
+ let result_a = null;
2048
+ const key = "a";
2049
+ const lockA = lockProviderA.create(key);
2050
+ await lockA.addListener(KeyAcquiredLockEvent, (event) => {
2051
+ result_a = event;
2052
+ });
2053
+ let result_b = null;
2054
+ const lockB = lockProviderB.create(key);
2055
+ await lockB.addListener(KeyAcquiredLockEvent, (event) => {
2056
+ result_b = event;
2057
+ });
2058
+ await lockA.acquire();
2059
+ await delay(TTL);
2060
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2061
+ expect(result_b).toBeNull();
2062
+ });
2063
+ test("method: addListenerMany / dispatch", async () => {
2064
+ let result_a = null;
2065
+ const key = "a";
2066
+ const lockA = lockProviderA.create(key);
2067
+ await lockA.addListenerMany([KeyAcquiredLockEvent], (event) => {
2068
+ result_a = event;
2069
+ });
2070
+ let result_b = null;
2071
+ const lockB = lockProviderB.create(key);
2072
+ await lockB.addListenerMany([KeyAcquiredLockEvent], (event) => {
2073
+ result_b = event;
2074
+ });
2075
+ await lockA.acquire();
2076
+ await delay(TTL);
2077
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2078
+ expect(result_b).toBeNull();
2079
+ });
2080
+ test("method: removeListener / addListener / dispatch", async () => {
2081
+ let result_a = null;
2082
+ const key = "a";
2083
+ const lockA = lockProviderA.create(key);
2084
+ await lockA.addListener(KeyAcquiredLockEvent, (event) => {
2085
+ result_a = event;
2086
+ });
2087
+ let result_b = null;
2088
+ const listenerB = (event) => {
2089
+ result_b = event;
2090
+ };
2091
+ const lockB = lockProviderB.create(key);
2092
+ await lockB.addListener(KeyAcquiredLockEvent, listenerB);
2093
+ await lockB.removeListener(KeyAcquiredLockEvent, listenerB);
2094
+ await lockA.acquire();
2095
+ await lockB.acquire();
2096
+ await delay(TTL);
2097
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2098
+ expect(result_b).toBeNull();
2099
+ });
2100
+ test("method: removeListenerMany / addListener / dispatch", async () => {
2101
+ let result_a = null;
2102
+ const key = "a";
2103
+ const lockA = lockProviderA.create(key);
2104
+ await lockA.addListener(KeyAcquiredLockEvent, (event) => {
2105
+ result_a = event;
2106
+ });
2107
+ let result_b = null;
2108
+ const listenerB = (event) => {
2109
+ result_b = event;
2110
+ };
2111
+ const lockB = lockProviderB.create(key);
2112
+ await lockB.addListener(KeyAcquiredLockEvent, listenerB);
2113
+ await lockB.removeListenerMany([KeyAcquiredLockEvent], listenerB);
2114
+ await lockA.acquire();
2115
+ await lockB.acquire();
2116
+ await delay(TTL);
2117
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2118
+ expect(result_b).toBeNull();
2119
+ });
2120
+ test("method: subscribe / dispatch", async () => {
2121
+ let result_a = null;
2122
+ const key = "a";
2123
+ const lockA = lockProviderA.create(key);
2124
+ await lockA.subscribe(KeyAcquiredLockEvent, (event) => {
2125
+ result_a = event;
2126
+ });
2127
+ let result_b = null;
2128
+ const listenerB = (event) => {
2129
+ result_b = event;
2130
+ };
2131
+ const lockB = lockProviderB.create(key);
2132
+ const unsubscribe = await lockB.subscribe(KeyAcquiredLockEvent, listenerB);
2133
+ await unsubscribe();
2134
+ await lockA.acquire();
2135
+ await lockB.acquire();
2136
+ await delay(TTL);
2137
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2138
+ expect(result_b).toBeNull();
2139
+ });
2140
+ test("method: subscribeMany / dispatch", async () => {
2141
+ let result_a = null;
2142
+ const key = "a";
2143
+ const lockA = lockProviderA.create(key);
2144
+ await lockA.subscribeMany([KeyAcquiredLockEvent], (event) => {
2145
+ result_a = event;
2146
+ });
2147
+ let result_b = null;
2148
+ const listenerB = (event) => {
2149
+ result_b = event;
2150
+ };
2151
+ const lockB = lockProviderB.create(key);
2152
+ const unsubscribe = await lockB.subscribeMany([KeyAcquiredLockEvent], listenerB);
2153
+ await unsubscribe();
2154
+ await lockA.acquire();
2155
+ await lockB.acquire();
2156
+ await delay(TTL);
2157
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2158
+ expect(result_b).toBeNull();
2159
+ });
2160
+ });
2161
+ describe("class: LockProvider", () => {
2162
+ test("method: addListener / dispatch", async () => {
2163
+ let result_a = null;
2164
+ const key = "a";
2165
+ const lockA = lockProviderA.create(key);
2166
+ await lockProviderA.addListener(KeyAcquiredLockEvent, (event) => {
2167
+ result_a = event;
2168
+ });
2169
+ let result_b = null;
2170
+ await lockProviderB.addListener(KeyAcquiredLockEvent, (event) => {
2171
+ result_b = event;
2172
+ });
2173
+ await lockA.acquire();
2174
+ await delay(TTL);
2175
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2176
+ expect(result_b).toBeNull();
2177
+ });
2178
+ test("method: addListenerMany / dispatch", async () => {
2179
+ let result_a = null;
2180
+ const key = "a";
2181
+ const lockA = lockProviderA.create(key);
2182
+ await lockProviderA.addListenerMany([KeyAcquiredLockEvent], (event) => {
2183
+ result_a = event;
2184
+ });
2185
+ let result_b = null;
2186
+ await lockProviderB.addListenerMany([KeyAcquiredLockEvent], (event) => {
2187
+ result_b = event;
2188
+ });
2189
+ await lockA.acquire();
2190
+ await delay(TTL);
2191
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2192
+ expect(result_b).toBeNull();
2193
+ });
2194
+ test("method: removeListener / addListener / dispatch", async () => {
2195
+ let result_a = null;
2196
+ const key = "a";
2197
+ const lockA = lockProviderA.create(key);
2198
+ await lockProviderA.addListener(KeyAcquiredLockEvent, (event) => {
2199
+ result_a = event;
2200
+ });
2201
+ let result_b = null;
2202
+ const listenerB = (event) => {
2203
+ result_b = event;
2204
+ };
2205
+ const lockB = lockProviderB.create(key);
2206
+ await lockProviderB.addListener(KeyAcquiredLockEvent, listenerB);
2207
+ await lockProviderB.removeListener(KeyAcquiredLockEvent, listenerB);
2208
+ await lockA.acquire();
2209
+ await lockB.acquire();
2210
+ await delay(TTL);
2211
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2212
+ expect(result_b).toBeNull();
2213
+ });
2214
+ test("method: removeListenerMany / addListener / dispatch", async () => {
2215
+ let result_a = null;
2216
+ const key = "a";
2217
+ const lockA = lockProviderA.create(key);
2218
+ await lockProviderA.addListener(KeyAcquiredLockEvent, (event) => {
2219
+ result_a = event;
2220
+ });
2221
+ let result_b = null;
2222
+ const listenerB = (event) => {
2223
+ result_b = event;
2224
+ };
2225
+ const lockB = lockProviderB.create(key);
2226
+ await lockProviderB.addListener(KeyAcquiredLockEvent, listenerB);
2227
+ await lockProviderB.removeListenerMany([KeyAcquiredLockEvent], listenerB);
2228
+ await lockA.acquire();
2229
+ await lockB.acquire();
2230
+ await delay(TTL);
2231
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2232
+ expect(result_b).toBeNull();
2233
+ });
2234
+ test("method: subscribe / dispatch", async () => {
2235
+ let result_a = null;
2236
+ const key = "a";
2237
+ const lockA = lockProviderA.create(key);
2238
+ await lockProviderA.subscribe(KeyAcquiredLockEvent, (event) => {
2239
+ result_a = event;
2240
+ });
2241
+ let result_b = null;
2242
+ const listenerB = (event) => {
2243
+ result_b = event;
2244
+ };
2245
+ const lockB = lockProviderB.create(key);
2246
+ const unsubscribe = await lockProviderB.subscribe(KeyAcquiredLockEvent, listenerB);
2247
+ await unsubscribe();
2248
+ await lockA.acquire();
2249
+ await lockB.acquire();
2250
+ await delay(TTL);
2251
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2252
+ expect(result_b).toBeNull();
2253
+ });
2254
+ test("method: subscribeMany / dispatch", async () => {
2255
+ let result_a = null;
2256
+ const key = "a";
2257
+ const lockA = lockProviderA.create(key);
2258
+ await lockProviderA.subscribeMany([KeyAcquiredLockEvent], (event) => {
2259
+ result_a = event;
2260
+ });
2261
+ let result_b = null;
2262
+ const listenerB = (event) => {
2263
+ result_b = event;
2264
+ };
2265
+ const lockB = lockProviderB.create(key);
2266
+ const unsubscribe = await lockProviderB.subscribeMany([KeyAcquiredLockEvent], listenerB);
2267
+ await unsubscribe();
2268
+ await lockA.acquire();
2269
+ await lockB.acquire();
2270
+ await delay(TTL);
2271
+ expect(result_a).toBeInstanceOf(KeyAcquiredLockEvent);
2272
+ expect(result_b).toBeNull();
2273
+ });
2274
+ });
2275
+ });
2276
+ describe("Serde tests:", () => {
2277
+ test("Should preserve state", async () => {
2278
+ const key = "a";
2279
+ const owner = "b";
2280
+ const lock = lockProviderB.create(key, {
2281
+ owner,
2282
+ });
2283
+ await lock.acquire();
2284
+ const deserializedLock = serde.deserialize(serde.serialize(lock));
2285
+ expect(await deserializedLock.isLocked()).toBe(true);
2286
+ expect(await deserializedLock.isExpired()).toBe(false);
2287
+ });
2288
+ test("Should preserve owner", async () => {
2289
+ const key = "a";
2290
+ const owner = "b";
2291
+ const lock = lockProviderB.create(key, {
2292
+ owner,
2293
+ });
2294
+ const deserializedLock = serde.deserialize(serde.serialize(lock));
2295
+ expect(await deserializedLock.getOwner()).toBe(owner);
2296
+ });
2297
+ test("Should preserve ttl", async () => {
2298
+ const key = "a";
2299
+ const owner = "b";
2300
+ const ttl = TTL.multiply(2);
2301
+ const lock = lockProviderB.create(key, {
2302
+ owner,
2303
+ ttl,
2304
+ });
2305
+ await lock.acquire();
2306
+ const deserializedLock = serde.deserialize(serde.serialize(lock));
2307
+ const delayTime = TTL;
2308
+ await delay(delayTime);
2309
+ expect(await deserializedLock.isLocked()).toBe(true);
2310
+ await delay(delayTime);
2311
+ expect(await deserializedLock.isLocked()).toBe(false);
2312
+ });
2313
+ });
2314
+ }
2315
+ //# sourceMappingURL=lock-provider.test-suite.js.map