@adtrackify/at-service-common 3.19.20 → 3.19.22

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 (810) hide show
  1. package/dist/cjs/__tests__/clients/acuity-client.spec.d.ts +1 -1
  2. package/dist/cjs/__tests__/clients/acuity-client.spec.js +43 -43
  3. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
  4. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.js +364 -354
  5. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.js.map +1 -1
  6. package/dist/cjs/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
  7. package/dist/cjs/__tests__/clients/dynamodb-client.spec.js +194 -194
  8. package/dist/cjs/__tests__/clients/dynamodb-client.spec.js.map +1 -1
  9. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
  10. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.js +941 -931
  11. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.js.map +1 -1
  12. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
  13. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.js +573 -563
  14. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.js.map +1 -1
  15. package/dist/cjs/__tests__/clients/sqs-client.spec.d.ts +1 -1
  16. package/dist/cjs/__tests__/clients/sqs-client.spec.js +191 -191
  17. package/dist/cjs/__tests__/clients/sqs-client.spec.js.map +1 -1
  18. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
  19. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.js +1357 -1357
  20. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.js.map +1 -1
  21. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
  22. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.js +68 -68
  23. package/dist/cjs/__tests__/db/destinations-db-service.spec.d.ts +1 -1
  24. package/dist/cjs/__tests__/db/destinations-db-service.spec.js +125 -125
  25. package/dist/cjs/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
  26. package/dist/cjs/__tests__/db/shared-read-db-services.spec.js +89 -89
  27. package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
  28. package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.js +104 -104
  29. package/dist/cjs/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
  30. package/dist/cjs/__tests__/db/subscriptions-db-service.spec.js +95 -95
  31. package/dist/cjs/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
  32. package/dist/cjs/__tests__/db/user-accounts-db-service.spec.js +76 -76
  33. package/dist/cjs/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  34. package/dist/cjs/__tests__/helpers/account-users-helper.spec.js +220 -220
  35. package/dist/cjs/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
  36. package/dist/cjs/__tests__/helpers/acuity-helper.spec.js +69 -69
  37. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
  38. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.js +82 -82
  39. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  40. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js +674 -674
  41. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
  42. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1140 -1140
  43. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js.map +1 -1
  44. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  45. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js +588 -588
  46. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
  47. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.js +584 -584
  48. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.js.map +1 -1
  49. package/dist/cjs/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  50. package/dist/cjs/__tests__/libs/compress-decompress.spec.js +16 -16
  51. package/dist/cjs/__tests__/libs/contacts.spec.d.ts +1 -1
  52. package/dist/cjs/__tests__/libs/contacts.spec.js +294 -294
  53. package/dist/cjs/__tests__/libs/currency.spec.d.ts +1 -1
  54. package/dist/cjs/__tests__/libs/currency.spec.js +220 -220
  55. package/dist/cjs/__tests__/libs/dates.spec.d.ts +1 -1
  56. package/dist/cjs/__tests__/libs/dates.spec.js +130 -130
  57. package/dist/cjs/__tests__/libs/dates.spec.js.map +1 -1
  58. package/dist/cjs/__tests__/libs/domain.spec.d.ts +1 -1
  59. package/dist/cjs/__tests__/libs/domain.spec.js +107 -107
  60. package/dist/cjs/__tests__/libs/numbers.spec.d.ts +1 -1
  61. package/dist/cjs/__tests__/libs/numbers.spec.js +261 -261
  62. package/dist/cjs/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  63. package/dist/cjs/__tests__/s3-client/s3-client.spec.js +33 -33
  64. package/dist/cjs/__tests__/services/acuity-api-service.spec.d.ts +1 -1
  65. package/dist/cjs/__tests__/services/acuity-api-service.spec.js +71 -71
  66. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
  67. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.js +93 -93
  68. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
  69. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.js +57 -57
  70. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  71. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.js +35 -35
  72. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
  73. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.js +191 -181
  74. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.js.map +1 -1
  75. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
  76. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.js +69 -69
  77. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
  78. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.js +139 -139
  79. package/dist/cjs/clients/generic/cognito-client.d.ts +23 -23
  80. package/dist/cjs/clients/generic/cognito-client.js +209 -209
  81. package/dist/cjs/clients/generic/cognito-client.js.map +1 -1
  82. package/dist/cjs/clients/generic/dynamodb-client.d.ts +20 -20
  83. package/dist/cjs/clients/generic/dynamodb-client.js +235 -229
  84. package/dist/cjs/clients/generic/dynamodb-client.js.map +1 -1
  85. package/dist/cjs/clients/generic/eventbridge-client.d.ts +14 -14
  86. package/dist/cjs/clients/generic/eventbridge-client.js +51 -51
  87. package/dist/cjs/clients/generic/http-client.d.ts +14 -14
  88. package/dist/cjs/clients/generic/http-client.js +61 -61
  89. package/dist/cjs/clients/generic/http-client.js.map +1 -1
  90. package/dist/cjs/clients/generic/index.d.ts +13 -13
  91. package/dist/cjs/clients/generic/index.js +29 -29
  92. package/dist/cjs/clients/generic/lambda-invoke-client.d.ts +10 -10
  93. package/dist/cjs/clients/generic/lambda-invoke-client.js +39 -39
  94. package/dist/cjs/clients/generic/lambda-invoke-client.js.map +1 -1
  95. package/dist/cjs/clients/generic/location-client.d.ts +8 -8
  96. package/dist/cjs/clients/generic/location-client.js +31 -31
  97. package/dist/cjs/clients/generic/location-client.js.map +1 -1
  98. package/dist/cjs/clients/generic/redis-client.d.ts +33 -33
  99. package/dist/cjs/clients/generic/redis-client.js +191 -191
  100. package/dist/cjs/clients/generic/redis-client.js.map +1 -1
  101. package/dist/cjs/clients/generic/s3-client.d.ts +22 -23
  102. package/dist/cjs/clients/generic/s3-client.js +216 -216
  103. package/dist/cjs/clients/generic/s3-client.js.map +1 -1
  104. package/dist/cjs/clients/generic/singlestore-db-client.d.ts +14 -14
  105. package/dist/cjs/clients/generic/singlestore-db-client.js +77 -67
  106. package/dist/cjs/clients/generic/singlestore-db-client.js.map +1 -1
  107. package/dist/cjs/clients/generic/sqs-bundled-client.d.ts +15 -15
  108. package/dist/cjs/clients/generic/sqs-bundled-client.js +311 -311
  109. package/dist/cjs/clients/generic/sqs-bundled-client.js.map +1 -1
  110. package/dist/cjs/clients/generic/sqs-bundled-client.types.d.ts +53 -53
  111. package/dist/cjs/clients/generic/sqs-bundled-client.types.js +17 -17
  112. package/dist/cjs/clients/generic/sqs-bundled-client.types.js.map +1 -1
  113. package/dist/cjs/clients/generic/sqs-client.d.ts +53 -53
  114. package/dist/cjs/clients/generic/sqs-client.js +285 -285
  115. package/dist/cjs/clients/generic/sqs-client.js.map +1 -1
  116. package/dist/cjs/clients/generic/sqs-unbundle.d.ts +32 -32
  117. package/dist/cjs/clients/generic/sqs-unbundle.js +143 -144
  118. package/dist/cjs/clients/generic/sqs-unbundle.js.map +1 -1
  119. package/dist/cjs/clients/index.d.ts +3 -3
  120. package/dist/cjs/clients/index.js +19 -19
  121. package/dist/cjs/clients/internal-api/accounts-client.d.ts +91 -91
  122. package/dist/cjs/clients/internal-api/accounts-client.js +129 -129
  123. package/dist/cjs/clients/internal-api/accounts-client.js.map +1 -1
  124. package/dist/cjs/clients/internal-api/cache-lambda-client.d.ts +26 -26
  125. package/dist/cjs/clients/internal-api/cache-lambda-client.js +89 -89
  126. package/dist/cjs/clients/internal-api/cache-lambda-client.js.map +1 -1
  127. package/dist/cjs/clients/internal-api/db-management-client.d.ts +18 -18
  128. package/dist/cjs/clients/internal-api/db-management-client.js +36 -36
  129. package/dist/cjs/clients/internal-api/destinations-client.d.ts +34 -34
  130. package/dist/cjs/clients/internal-api/destinations-client.js +79 -79
  131. package/dist/cjs/clients/internal-api/destinations-client.js.map +1 -1
  132. package/dist/cjs/clients/internal-api/event-collector-client.d.ts +20 -20
  133. package/dist/cjs/clients/internal-api/event-collector-client.js +36 -36
  134. package/dist/cjs/clients/internal-api/identity-client.d.ts +31 -31
  135. package/dist/cjs/clients/internal-api/identity-client.js +91 -91
  136. package/dist/cjs/clients/internal-api/identity-client.js.map +1 -1
  137. package/dist/cjs/clients/internal-api/index.d.ts +9 -9
  138. package/dist/cjs/clients/internal-api/index.js +25 -25
  139. package/dist/cjs/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  140. package/dist/cjs/clients/internal-api/shopify-app-install-client.js +81 -81
  141. package/dist/cjs/clients/internal-api/subscriptions-client.d.ts +26 -26
  142. package/dist/cjs/clients/internal-api/subscriptions-client.js +77 -77
  143. package/dist/cjs/clients/internal-api/users-auth-client.d.ts +35 -35
  144. package/dist/cjs/clients/internal-api/users-auth-client.js +110 -110
  145. package/dist/cjs/clients/internal-api/users-auth-client.js.map +1 -1
  146. package/dist/cjs/clients/third-party/acuity-client.d.ts +10 -10
  147. package/dist/cjs/clients/third-party/acuity-client.js +40 -40
  148. package/dist/cjs/clients/third-party/emailable-client.d.ts +7 -7
  149. package/dist/cjs/clients/third-party/emailable-client.js +25 -25
  150. package/dist/cjs/clients/third-party/emailable-client.js.map +1 -1
  151. package/dist/cjs/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  152. package/dist/cjs/clients/third-party/exchange-rate-api-client.js +19 -19
  153. package/dist/cjs/clients/third-party/index.d.ts +5 -5
  154. package/dist/cjs/clients/third-party/index.js +21 -21
  155. package/dist/cjs/clients/third-party/loops-client.d.ts +10 -10
  156. package/dist/cjs/clients/third-party/loops-client.js +30 -30
  157. package/dist/cjs/clients/third-party/loops-client.js.map +1 -1
  158. package/dist/cjs/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
  159. package/dist/cjs/clients/third-party/shopify/graphql-order-queries.js +4 -4
  160. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  161. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.js +5 -5
  162. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
  163. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.js +161 -161
  164. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.js.map +1 -1
  165. package/dist/cjs/clients/third-party/shopify-client.d.ts +29 -29
  166. package/dist/cjs/clients/third-party/shopify-client.js +146 -146
  167. package/dist/cjs/clients/third-party/shopify-client.js.map +1 -1
  168. package/dist/cjs/constants/index.d.ts +1 -1
  169. package/dist/cjs/constants/index.js +17 -17
  170. package/dist/cjs/constants/sqs.d.ts +20 -20
  171. package/dist/cjs/constants/sqs.js +26 -26
  172. package/dist/cjs/constants/sqs.js.map +1 -1
  173. package/dist/cjs/helpers/account-users-helper.d.ts +2 -2
  174. package/dist/cjs/helpers/account-users-helper.js +22 -22
  175. package/dist/cjs/helpers/account-users-helper.js.map +1 -1
  176. package/dist/cjs/helpers/acuity-helper.d.ts +4 -4
  177. package/dist/cjs/helpers/acuity-helper.js +56 -56
  178. package/dist/cjs/helpers/acuity-helper.js.map +1 -1
  179. package/dist/cjs/helpers/api-key-auth-helper.d.ts +10 -9
  180. package/dist/cjs/helpers/api-key-auth-helper.js +40 -40
  181. package/dist/cjs/helpers/api-key-auth-helper.js.map +1 -1
  182. package/dist/cjs/helpers/api-key-authorizer-helper.d.ts +36 -36
  183. package/dist/cjs/helpers/api-key-authorizer-helper.js +87 -87
  184. package/dist/cjs/helpers/api-key-authorizer-helper.js.map +1 -1
  185. package/dist/cjs/helpers/identity-cache-helper.d.ts +21 -21
  186. package/dist/cjs/helpers/identity-cache-helper.js +157 -157
  187. package/dist/cjs/helpers/identity-cache-helper.js.map +1 -1
  188. package/dist/cjs/helpers/index.d.ts +10 -10
  189. package/dist/cjs/helpers/index.js +26 -26
  190. package/dist/cjs/helpers/input-validation-helper.d.ts +3 -3
  191. package/dist/cjs/helpers/input-validation-helper.js +22 -22
  192. package/dist/cjs/helpers/input-validation-helper.js.map +1 -1
  193. package/dist/cjs/helpers/logging-helper.d.ts +16 -16
  194. package/dist/cjs/helpers/logging-helper.js +94 -84
  195. package/dist/cjs/helpers/logging-helper.js.map +1 -1
  196. package/dist/cjs/helpers/response-helper.d.ts +18 -18
  197. package/dist/cjs/helpers/response-helper.js +43 -43
  198. package/dist/cjs/helpers/response-helper.js.map +1 -1
  199. package/dist/cjs/helpers/shopify-helper.d.ts +9 -9
  200. package/dist/cjs/helpers/shopify-helper.js +26 -26
  201. package/dist/cjs/helpers/shopify-helper.js.map +1 -1
  202. package/dist/cjs/helpers/sqs-utils.d.ts +6 -6
  203. package/dist/cjs/helpers/sqs-utils.js +13 -14
  204. package/dist/cjs/helpers/sqs-utils.js.map +1 -1
  205. package/dist/cjs/index.d.ts +7 -7
  206. package/dist/cjs/index.js +23 -23
  207. package/dist/cjs/libs/api-router/index.d.ts +2 -2
  208. package/dist/cjs/libs/api-router/index.js +18 -18
  209. package/dist/cjs/libs/api-router/public-api-router.d.ts +3 -3
  210. package/dist/cjs/libs/api-router/public-api-router.js +36 -36
  211. package/dist/cjs/libs/api-router/public-api-router.js.map +1 -1
  212. package/dist/cjs/libs/api-router/route-matcher.d.ts +21 -21
  213. package/dist/cjs/libs/api-router/route-matcher.js +36 -36
  214. package/dist/cjs/libs/api-router/route-matcher.js.map +1 -1
  215. package/dist/cjs/libs/click-id-parser.d.ts +23 -23
  216. package/dist/cjs/libs/click-id-parser.js +49 -49
  217. package/dist/cjs/libs/click-id-parser.js.map +1 -1
  218. package/dist/cjs/libs/compression.d.ts +2 -2
  219. package/dist/cjs/libs/compression.js +33 -33
  220. package/dist/cjs/libs/compression.js.map +1 -1
  221. package/dist/cjs/libs/contacts.d.ts +7 -7
  222. package/dist/cjs/libs/contacts.js +152 -152
  223. package/dist/cjs/libs/contacts.js.map +1 -1
  224. package/dist/cjs/libs/cookie.d.ts +17 -17
  225. package/dist/cjs/libs/cookie.js +76 -76
  226. package/dist/cjs/libs/cookie.js.map +1 -1
  227. package/dist/cjs/libs/crypto.d.ts +4 -4
  228. package/dist/cjs/libs/crypto.js +25 -25
  229. package/dist/cjs/libs/csv.d.ts +2 -2
  230. package/dist/cjs/libs/csv.js +35 -35
  231. package/dist/cjs/libs/csv.js.map +1 -1
  232. package/dist/cjs/libs/currency.d.ts +1 -1
  233. package/dist/cjs/libs/currency.js +29 -29
  234. package/dist/cjs/libs/currency.js.map +1 -1
  235. package/dist/cjs/libs/dates.d.ts +12 -12
  236. package/dist/cjs/libs/dates.js +96 -96
  237. package/dist/cjs/libs/dates.js.map +1 -1
  238. package/dist/cjs/libs/domain.d.ts +2 -2
  239. package/dist/cjs/libs/domain.js +38 -38
  240. package/dist/cjs/libs/domain.js.map +1 -1
  241. package/dist/cjs/libs/emails.d.ts +8 -8
  242. package/dist/cjs/libs/emails.js +154 -154
  243. package/dist/cjs/libs/emails.js.map +1 -1
  244. package/dist/cjs/libs/http-error.d.ts +21 -21
  245. package/dist/cjs/libs/http-error.js +63 -63
  246. package/dist/cjs/libs/http-error.js.map +1 -1
  247. package/dist/cjs/libs/http-status-codes.d.ts +58 -58
  248. package/dist/cjs/libs/http-status-codes.js +62 -62
  249. package/dist/cjs/libs/http-status-codes.js.map +1 -1
  250. package/dist/cjs/libs/index.d.ts +19 -19
  251. package/dist/cjs/libs/index.js +35 -35
  252. package/dist/cjs/libs/numbers.d.ts +1 -1
  253. package/dist/cjs/libs/numbers.js +15 -15
  254. package/dist/cjs/libs/numbers.js.map +1 -1
  255. package/dist/cjs/libs/referrer-parser/index.d.ts +2 -2
  256. package/dist/cjs/libs/referrer-parser/index.js +18 -18
  257. package/dist/cjs/libs/referrer-parser/referrer-data.d.ts +9 -9
  258. package/dist/cjs/libs/referrer-parser/referrer-data.js +3307 -3307
  259. package/dist/cjs/libs/referrer-parser/referrer-parser-util.d.ts +19 -20
  260. package/dist/cjs/libs/referrer-parser/referrer-parser-util.js +131 -131
  261. package/dist/cjs/libs/referrer-parser/referrer-parser-util.js.map +1 -1
  262. package/dist/cjs/libs/strings.d.ts +3 -3
  263. package/dist/cjs/libs/strings.js +46 -46
  264. package/dist/cjs/libs/strings.js.map +1 -1
  265. package/dist/cjs/libs/traits.d.ts +6 -6
  266. package/dist/cjs/libs/traits.js +65 -65
  267. package/dist/cjs/libs/traits.js.map +1 -1
  268. package/dist/cjs/libs/url.d.ts +1 -1
  269. package/dist/cjs/libs/url.js +13 -13
  270. package/dist/cjs/services/acuity-api-service.d.ts +9 -9
  271. package/dist/cjs/services/acuity-api-service.js +73 -73
  272. package/dist/cjs/services/acuity-api-service.js.map +1 -1
  273. package/dist/cjs/services/cache/generic-cached-object.d.ts +5 -5
  274. package/dist/cjs/services/cache/generic-cached-object.js +2 -2
  275. package/dist/cjs/services/cache/index.d.ts +1 -1
  276. package/dist/cjs/services/cache/index.js +17 -17
  277. package/dist/cjs/services/cache/product-cache-service.d.ts +21 -21
  278. package/dist/cjs/services/cache/product-cache-service.js +76 -76
  279. package/dist/cjs/services/cache/product-cache-service.js.map +1 -1
  280. package/dist/cjs/services/currency-exchange-rate-lookup-service.d.ts +11 -11
  281. package/dist/cjs/services/currency-exchange-rate-lookup-service.js +66 -66
  282. package/dist/cjs/services/currency-exchange-rate-lookup-service.js.map +1 -1
  283. package/dist/cjs/services/db/accounts-db-service.d.ts +9 -9
  284. package/dist/cjs/services/db/accounts-db-service.js +33 -33
  285. package/dist/cjs/services/db/accounts-db-service.js.map +1 -1
  286. package/dist/cjs/services/db/api-keys-db-service.d.ts +10 -10
  287. package/dist/cjs/services/db/api-keys-db-service.js +36 -36
  288. package/dist/cjs/services/db/api-keys-db-service.js.map +1 -1
  289. package/dist/cjs/services/db/contact-enrichments-db-service.d.ts +15 -15
  290. package/dist/cjs/services/db/contact-enrichments-db-service.js +94 -94
  291. package/dist/cjs/services/db/contact-enrichments-db-service.js.map +1 -1
  292. package/dist/cjs/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  293. package/dist/cjs/services/db/currency-exchange-rates-db-service.js +39 -39
  294. package/dist/cjs/services/db/custom-measures-db-service.d.ts +14 -14
  295. package/dist/cjs/services/db/custom-measures-db-service.js +48 -48
  296. package/dist/cjs/services/db/custom-measures-db-service.js.map +1 -1
  297. package/dist/cjs/services/db/destinations-db-service.d.ts +13 -13
  298. package/dist/cjs/services/db/destinations-db-service.js +74 -74
  299. package/dist/cjs/services/db/identity-cache-db-service.d.ts +28 -28
  300. package/dist/cjs/services/db/identity-cache-db-service.js +320 -320
  301. package/dist/cjs/services/db/identity-cache-db-service.js.map +1 -1
  302. package/dist/cjs/services/db/identity-cache-dynamodb-service.d.ts +28 -28
  303. package/dist/cjs/services/db/identity-cache-dynamodb-service.js +377 -377
  304. package/dist/cjs/services/db/identity-cache-dynamodb-service.js.map +1 -1
  305. package/dist/cjs/services/db/index.d.ts +17 -17
  306. package/dist/cjs/services/db/index.js +33 -33
  307. package/dist/cjs/services/db/log-events-db-service.d.ts +11 -11
  308. package/dist/cjs/services/db/log-events-db-service.js +181 -181
  309. package/dist/cjs/services/db/log-events-db-service.js.map +1 -1
  310. package/dist/cjs/services/db/pixels-db-service.d.ts +8 -8
  311. package/dist/cjs/services/db/pixels-db-service.js +35 -35
  312. package/dist/cjs/services/db/purchasable-contacts-db-service.d.ts +9 -9
  313. package/dist/cjs/services/db/purchasable-contacts-db-service.js +43 -43
  314. package/dist/cjs/services/db/purchasable-contacts-db-service.js.map +1 -1
  315. package/dist/cjs/services/db/purchased-contacts/index.d.ts +2 -2
  316. package/dist/cjs/services/db/purchased-contacts/index.js +18 -18
  317. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
  318. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.js +152 -152
  319. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.js.map +1 -1
  320. package/dist/cjs/services/db/purchased-contacts/types.d.ts +11 -11
  321. package/dist/cjs/services/db/purchased-contacts/types.js +2 -2
  322. package/dist/cjs/services/db/shopify-app-installs-db-service.d.ts +10 -10
  323. package/dist/cjs/services/db/shopify-app-installs-db-service.js +52 -52
  324. package/dist/cjs/services/db/shopify-app-installs-db-service.js.map +1 -1
  325. package/dist/cjs/services/db/shopify-products-cache-db-service.d.ts +16 -16
  326. package/dist/cjs/services/db/shopify-products-cache-db-service.js +73 -73
  327. package/dist/cjs/services/db/shopify-products-cache-db-service.js.map +1 -1
  328. package/dist/cjs/services/db/subscriptions-db-service.d.ts +11 -11
  329. package/dist/cjs/services/db/subscriptions-db-service.js +38 -38
  330. package/dist/cjs/services/db/subscriptions-db-service.js.map +1 -1
  331. package/dist/cjs/services/db/tracking-events-db-service.d.ts +21 -21
  332. package/dist/cjs/services/db/tracking-events-db-service.js +188 -188
  333. package/dist/cjs/services/db/tracking-events-db-service.js.map +1 -1
  334. package/dist/cjs/services/db/user-accounts-db-service.d.ts +7 -7
  335. package/dist/cjs/services/db/user-accounts-db-service.js +17 -17
  336. package/dist/cjs/services/email-verification/contact-email-verification-service.d.ts +7 -7
  337. package/dist/cjs/services/email-verification/contact-email-verification-service.js +101 -101
  338. package/dist/cjs/services/email-verification/contact-email-verification-service.js.map +1 -1
  339. package/dist/cjs/services/email-verification/email-verification-service.d.ts +19 -19
  340. package/dist/cjs/services/email-verification/email-verification-service.js +131 -131
  341. package/dist/cjs/services/email-verification/email-verification-service.js.map +1 -1
  342. package/dist/cjs/services/email-verification/index.d.ts +2 -2
  343. package/dist/cjs/services/email-verification/index.js +18 -18
  344. package/dist/cjs/services/eventbridge-integration-service.d.ts +9 -9
  345. package/dist/cjs/services/eventbridge-integration-service.js +28 -28
  346. package/dist/cjs/services/events/index.d.ts +3 -3
  347. package/dist/cjs/services/events/index.js +19 -19
  348. package/dist/cjs/services/events/log-event-service.d.ts +19 -19
  349. package/dist/cjs/services/events/log-event-service.js +77 -77
  350. package/dist/cjs/services/events/log-event-service.js.map +1 -1
  351. package/dist/cjs/services/events/metric-event-service.d.ts +9 -9
  352. package/dist/cjs/services/events/metric-event-service.js +49 -49
  353. package/dist/cjs/services/events/tracking-event-sqs-service.d.ts +8 -8
  354. package/dist/cjs/services/events/tracking-event-sqs-service.js +34 -34
  355. package/dist/cjs/services/events/tracking-event-sqs-service.js.map +1 -1
  356. package/dist/cjs/services/generic-cache-service.d.ts +7 -7
  357. package/dist/cjs/services/generic-cache-service.js +33 -33
  358. package/dist/cjs/services/generic-cache-service.js.map +1 -1
  359. package/dist/cjs/services/index.d.ts +10 -10
  360. package/dist/cjs/services/index.js +26 -26
  361. package/dist/cjs/services/ipdata-lookup-service.d.ts +20 -20
  362. package/dist/cjs/services/ipdata-lookup-service.js +112 -112
  363. package/dist/cjs/services/ipdata-lookup-service.js.map +1 -1
  364. package/dist/cjs/services/shopify/index.d.ts +2 -2
  365. package/dist/cjs/services/shopify/index.js +18 -18
  366. package/dist/cjs/services/shopify/products/index.d.ts +1 -1
  367. package/dist/cjs/services/shopify/products/index.js +17 -17
  368. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  369. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.js +112 -112
  370. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.js.map +1 -1
  371. package/dist/cjs/services/shopify/shopify-graphql-transformer.d.ts +8 -8
  372. package/dist/cjs/services/shopify/shopify-graphql-transformer.js +141 -141
  373. package/dist/cjs/services/shopify/shopify-graphql-transformer.js.map +1 -1
  374. package/dist/cjs/types/acuity-types.d.ts +74 -74
  375. package/dist/cjs/types/acuity-types.js +2 -2
  376. package/dist/cjs/types/api-response.d.ts +6 -6
  377. package/dist/cjs/types/api-response.js +2 -2
  378. package/dist/cjs/types/index.d.ts +4 -4
  379. package/dist/cjs/types/index.js +43 -33
  380. package/dist/cjs/types/index.js.map +1 -1
  381. package/dist/cjs/types/internal-events/event-detail-types.d.ts +20 -20
  382. package/dist/cjs/types/internal-events/event-detail-types.js +27 -27
  383. package/dist/cjs/types/internal-events/event-detail-types.js.map +1 -1
  384. package/dist/cjs/types/internal-events/index.d.ts +1 -1
  385. package/dist/cjs/types/internal-events/index.js +17 -17
  386. package/dist/cjs/types/shopify-graphql-types/admin.generated.d.ts +123 -123
  387. package/dist/cjs/types/shopify-graphql-types/admin.generated.js +2 -2
  388. package/dist/cjs/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  389. package/dist/cjs/types/shopify-graphql-types/admin.types.js +5311 -5311
  390. package/dist/cjs/types/shopify-graphql-types/admin.types.js.map +1 -1
  391. package/dist/cjs/types/shopify-graphql-types/index.d.ts +2 -2
  392. package/dist/cjs/types/shopify-graphql-types/index.js +18 -18
  393. package/dist/cjs/types/shopify-rest-types.d.ts +767 -767
  394. package/dist/cjs/types/shopify-rest-types.js +2 -2
  395. package/dist/cjs/utils/compression.d.ts +34 -36
  396. package/dist/cjs/utils/compression.js +198 -198
  397. package/dist/cjs/utils/compression.js.map +1 -1
  398. package/dist/cjs/utils/custom-measure-formula-utils.d.ts +6 -6
  399. package/dist/cjs/utils/custom-measure-formula-utils.js +209 -209
  400. package/dist/cjs/utils/custom-measure-formula-utils.js.map +1 -1
  401. package/dist/cjs/utils/index.d.ts +4 -4
  402. package/dist/cjs/utils/index.js +20 -20
  403. package/dist/cjs/utils/retry-envelope.d.ts +12 -12
  404. package/dist/cjs/utils/retry-envelope.js +27 -28
  405. package/dist/cjs/utils/retry-envelope.js.map +1 -1
  406. package/dist/cjs/utils/size.d.ts +2 -2
  407. package/dist/cjs/utils/size.js +48 -49
  408. package/dist/cjs/utils/size.js.map +1 -1
  409. package/dist/esm/__tests__/clients/acuity-client.spec.d.ts +1 -1
  410. package/dist/esm/__tests__/clients/acuity-client.spec.js +41 -41
  411. package/dist/esm/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
  412. package/dist/esm/__tests__/clients/cross-platform-compression.spec.js +329 -329
  413. package/dist/esm/__tests__/clients/cross-platform-compression.spec.js.map +1 -1
  414. package/dist/esm/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
  415. package/dist/esm/__tests__/clients/dynamodb-client.spec.js +192 -192
  416. package/dist/esm/__tests__/clients/dynamodb-client.spec.js.map +1 -1
  417. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
  418. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.js +906 -906
  419. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.js.map +1 -1
  420. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
  421. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.js +538 -538
  422. package/dist/esm/__tests__/clients/sqs-client.spec.d.ts +1 -1
  423. package/dist/esm/__tests__/clients/sqs-client.spec.js +189 -189
  424. package/dist/esm/__tests__/clients/sqs-client.spec.js.map +1 -1
  425. package/dist/esm/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
  426. package/dist/esm/__tests__/clients/sqs-unbundle.spec.js +1355 -1355
  427. package/dist/esm/__tests__/clients/sqs-unbundle.spec.js.map +1 -1
  428. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
  429. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.js +66 -66
  430. package/dist/esm/__tests__/db/destinations-db-service.spec.d.ts +1 -1
  431. package/dist/esm/__tests__/db/destinations-db-service.spec.js +123 -123
  432. package/dist/esm/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
  433. package/dist/esm/__tests__/db/shared-read-db-services.spec.js +87 -87
  434. package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
  435. package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.js +102 -102
  436. package/dist/esm/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
  437. package/dist/esm/__tests__/db/subscriptions-db-service.spec.js +93 -93
  438. package/dist/esm/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
  439. package/dist/esm/__tests__/db/user-accounts-db-service.spec.js +74 -74
  440. package/dist/esm/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  441. package/dist/esm/__tests__/helpers/account-users-helper.spec.js +218 -218
  442. package/dist/esm/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
  443. package/dist/esm/__tests__/helpers/acuity-helper.spec.js +67 -67
  444. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
  445. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.js +80 -80
  446. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  447. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js +672 -672
  448. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
  449. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1138 -1138
  450. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js.map +1 -1
  451. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  452. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js +586 -586
  453. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
  454. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.js +582 -582
  455. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.js.map +1 -1
  456. package/dist/esm/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  457. package/dist/esm/__tests__/libs/compress-decompress.spec.js +14 -14
  458. package/dist/esm/__tests__/libs/contacts.spec.d.ts +1 -1
  459. package/dist/esm/__tests__/libs/contacts.spec.js +292 -292
  460. package/dist/esm/__tests__/libs/currency.spec.d.ts +1 -1
  461. package/dist/esm/__tests__/libs/currency.spec.js +218 -218
  462. package/dist/esm/__tests__/libs/dates.spec.d.ts +1 -1
  463. package/dist/esm/__tests__/libs/dates.spec.js +128 -128
  464. package/dist/esm/__tests__/libs/dates.spec.js.map +1 -1
  465. package/dist/esm/__tests__/libs/domain.spec.d.ts +1 -1
  466. package/dist/esm/__tests__/libs/domain.spec.js +105 -105
  467. package/dist/esm/__tests__/libs/numbers.spec.d.ts +1 -1
  468. package/dist/esm/__tests__/libs/numbers.spec.js +259 -259
  469. package/dist/esm/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  470. package/dist/esm/__tests__/s3-client/s3-client.spec.js +31 -31
  471. package/dist/esm/__tests__/services/acuity-api-service.spec.d.ts +1 -1
  472. package/dist/esm/__tests__/services/acuity-api-service.spec.js +69 -69
  473. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
  474. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.js +91 -91
  475. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
  476. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.js +55 -55
  477. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  478. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.js +33 -33
  479. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
  480. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.js +156 -156
  481. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.js.map +1 -1
  482. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
  483. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.js +67 -67
  484. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
  485. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.js +137 -137
  486. package/dist/esm/clients/generic/cognito-client.d.ts +23 -23
  487. package/dist/esm/clients/generic/cognito-client.js +204 -204
  488. package/dist/esm/clients/generic/cognito-client.js.map +1 -1
  489. package/dist/esm/clients/generic/dynamodb-client.d.ts +20 -20
  490. package/dist/esm/clients/generic/dynamodb-client.js +231 -225
  491. package/dist/esm/clients/generic/dynamodb-client.js.map +1 -1
  492. package/dist/esm/clients/generic/eventbridge-client.d.ts +14 -14
  493. package/dist/esm/clients/generic/eventbridge-client.js +47 -47
  494. package/dist/esm/clients/generic/http-client.d.ts +14 -14
  495. package/dist/esm/clients/generic/http-client.js +53 -53
  496. package/dist/esm/clients/generic/http-client.js.map +1 -1
  497. package/dist/esm/clients/generic/index.d.ts +13 -13
  498. package/dist/esm/clients/generic/index.js +13 -13
  499. package/dist/esm/clients/generic/lambda-invoke-client.d.ts +10 -10
  500. package/dist/esm/clients/generic/lambda-invoke-client.js +35 -35
  501. package/dist/esm/clients/generic/lambda-invoke-client.js.map +1 -1
  502. package/dist/esm/clients/generic/location-client.d.ts +8 -8
  503. package/dist/esm/clients/generic/location-client.js +27 -27
  504. package/dist/esm/clients/generic/location-client.js.map +1 -1
  505. package/dist/esm/clients/generic/redis-client.d.ts +33 -33
  506. package/dist/esm/clients/generic/redis-client.js +184 -184
  507. package/dist/esm/clients/generic/redis-client.js.map +1 -1
  508. package/dist/esm/clients/generic/s3-client.d.ts +22 -23
  509. package/dist/esm/clients/generic/s3-client.js +209 -209
  510. package/dist/esm/clients/generic/s3-client.js.map +1 -1
  511. package/dist/esm/clients/generic/singlestore-db-client.d.ts +14 -14
  512. package/dist/esm/clients/generic/singlestore-db-client.js +40 -40
  513. package/dist/esm/clients/generic/singlestore-db-client.js.map +1 -1
  514. package/dist/esm/clients/generic/sqs-bundled-client.d.ts +15 -15
  515. package/dist/esm/clients/generic/sqs-bundled-client.js +307 -307
  516. package/dist/esm/clients/generic/sqs-bundled-client.js.map +1 -1
  517. package/dist/esm/clients/generic/sqs-bundled-client.types.d.ts +53 -53
  518. package/dist/esm/clients/generic/sqs-bundled-client.types.js +14 -14
  519. package/dist/esm/clients/generic/sqs-client.d.ts +53 -53
  520. package/dist/esm/clients/generic/sqs-client.js +281 -281
  521. package/dist/esm/clients/generic/sqs-client.js.map +1 -1
  522. package/dist/esm/clients/generic/sqs-unbundle.d.ts +32 -32
  523. package/dist/esm/clients/generic/sqs-unbundle.js +137 -137
  524. package/dist/esm/clients/generic/sqs-unbundle.js.map +1 -1
  525. package/dist/esm/clients/index.d.ts +3 -3
  526. package/dist/esm/clients/index.js +3 -3
  527. package/dist/esm/clients/internal-api/accounts-client.d.ts +91 -91
  528. package/dist/esm/clients/internal-api/accounts-client.js +125 -125
  529. package/dist/esm/clients/internal-api/accounts-client.js.map +1 -1
  530. package/dist/esm/clients/internal-api/cache-lambda-client.d.ts +26 -26
  531. package/dist/esm/clients/internal-api/cache-lambda-client.js +85 -85
  532. package/dist/esm/clients/internal-api/cache-lambda-client.js.map +1 -1
  533. package/dist/esm/clients/internal-api/db-management-client.d.ts +18 -18
  534. package/dist/esm/clients/internal-api/db-management-client.js +32 -32
  535. package/dist/esm/clients/internal-api/destinations-client.d.ts +34 -34
  536. package/dist/esm/clients/internal-api/destinations-client.js +75 -75
  537. package/dist/esm/clients/internal-api/destinations-client.js.map +1 -1
  538. package/dist/esm/clients/internal-api/event-collector-client.d.ts +20 -20
  539. package/dist/esm/clients/internal-api/event-collector-client.js +32 -32
  540. package/dist/esm/clients/internal-api/identity-client.d.ts +31 -31
  541. package/dist/esm/clients/internal-api/identity-client.js +87 -87
  542. package/dist/esm/clients/internal-api/identity-client.js.map +1 -1
  543. package/dist/esm/clients/internal-api/index.d.ts +9 -9
  544. package/dist/esm/clients/internal-api/index.js +9 -9
  545. package/dist/esm/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  546. package/dist/esm/clients/internal-api/shopify-app-install-client.js +77 -77
  547. package/dist/esm/clients/internal-api/subscriptions-client.d.ts +26 -26
  548. package/dist/esm/clients/internal-api/subscriptions-client.js +73 -73
  549. package/dist/esm/clients/internal-api/users-auth-client.d.ts +35 -35
  550. package/dist/esm/clients/internal-api/users-auth-client.js +106 -106
  551. package/dist/esm/clients/internal-api/users-auth-client.js.map +1 -1
  552. package/dist/esm/clients/third-party/acuity-client.d.ts +10 -10
  553. package/dist/esm/clients/third-party/acuity-client.js +36 -36
  554. package/dist/esm/clients/third-party/emailable-client.d.ts +7 -7
  555. package/dist/esm/clients/third-party/emailable-client.js +21 -21
  556. package/dist/esm/clients/third-party/emailable-client.js.map +1 -1
  557. package/dist/esm/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  558. package/dist/esm/clients/third-party/exchange-rate-api-client.js +15 -15
  559. package/dist/esm/clients/third-party/index.d.ts +5 -5
  560. package/dist/esm/clients/third-party/index.js +5 -5
  561. package/dist/esm/clients/third-party/loops-client.d.ts +10 -10
  562. package/dist/esm/clients/third-party/loops-client.js +26 -26
  563. package/dist/esm/clients/third-party/loops-client.js.map +1 -1
  564. package/dist/esm/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
  565. package/dist/esm/clients/third-party/shopify/graphql-order-queries.js +1 -1
  566. package/dist/esm/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  567. package/dist/esm/clients/third-party/shopify/graphql-product-queries.js +2 -2
  568. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
  569. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.js +157 -157
  570. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.js.map +1 -1
  571. package/dist/esm/clients/third-party/shopify-client.d.ts +29 -29
  572. package/dist/esm/clients/third-party/shopify-client.js +142 -142
  573. package/dist/esm/clients/third-party/shopify-client.js.map +1 -1
  574. package/dist/esm/constants/index.d.ts +1 -1
  575. package/dist/esm/constants/index.js +1 -1
  576. package/dist/esm/constants/sqs.d.ts +20 -20
  577. package/dist/esm/constants/sqs.js +22 -22
  578. package/dist/esm/constants/sqs.js.map +1 -1
  579. package/dist/esm/helpers/account-users-helper.d.ts +2 -2
  580. package/dist/esm/helpers/account-users-helper.js +18 -18
  581. package/dist/esm/helpers/account-users-helper.js.map +1 -1
  582. package/dist/esm/helpers/acuity-helper.d.ts +4 -4
  583. package/dist/esm/helpers/acuity-helper.js +51 -51
  584. package/dist/esm/helpers/acuity-helper.js.map +1 -1
  585. package/dist/esm/helpers/api-key-auth-helper.d.ts +10 -9
  586. package/dist/esm/helpers/api-key-auth-helper.js +35 -35
  587. package/dist/esm/helpers/api-key-auth-helper.js.map +1 -1
  588. package/dist/esm/helpers/api-key-authorizer-helper.d.ts +36 -36
  589. package/dist/esm/helpers/api-key-authorizer-helper.js +83 -83
  590. package/dist/esm/helpers/api-key-authorizer-helper.js.map +1 -1
  591. package/dist/esm/helpers/identity-cache-helper.d.ts +21 -21
  592. package/dist/esm/helpers/identity-cache-helper.js +152 -152
  593. package/dist/esm/helpers/identity-cache-helper.js.map +1 -1
  594. package/dist/esm/helpers/index.d.ts +10 -10
  595. package/dist/esm/helpers/index.js +10 -10
  596. package/dist/esm/helpers/input-validation-helper.d.ts +3 -3
  597. package/dist/esm/helpers/input-validation-helper.js +18 -18
  598. package/dist/esm/helpers/input-validation-helper.js.map +1 -1
  599. package/dist/esm/helpers/logging-helper.d.ts +16 -16
  600. package/dist/esm/helpers/logging-helper.js +56 -56
  601. package/dist/esm/helpers/logging-helper.js.map +1 -1
  602. package/dist/esm/helpers/response-helper.d.ts +18 -18
  603. package/dist/esm/helpers/response-helper.js +37 -37
  604. package/dist/esm/helpers/response-helper.js.map +1 -1
  605. package/dist/esm/helpers/shopify-helper.d.ts +9 -9
  606. package/dist/esm/helpers/shopify-helper.js +21 -21
  607. package/dist/esm/helpers/shopify-helper.js.map +1 -1
  608. package/dist/esm/helpers/sqs-utils.d.ts +6 -6
  609. package/dist/esm/helpers/sqs-utils.js +9 -9
  610. package/dist/esm/index.d.ts +7 -7
  611. package/dist/esm/index.js +7 -7
  612. package/dist/esm/libs/api-router/index.d.ts +2 -2
  613. package/dist/esm/libs/api-router/index.js +2 -2
  614. package/dist/esm/libs/api-router/public-api-router.d.ts +3 -3
  615. package/dist/esm/libs/api-router/public-api-router.js +32 -32
  616. package/dist/esm/libs/api-router/public-api-router.js.map +1 -1
  617. package/dist/esm/libs/api-router/route-matcher.d.ts +21 -21
  618. package/dist/esm/libs/api-router/route-matcher.js +30 -30
  619. package/dist/esm/libs/api-router/route-matcher.js.map +1 -1
  620. package/dist/esm/libs/click-id-parser.d.ts +23 -23
  621. package/dist/esm/libs/click-id-parser.js +45 -45
  622. package/dist/esm/libs/click-id-parser.js.map +1 -1
  623. package/dist/esm/libs/compression.d.ts +2 -2
  624. package/dist/esm/libs/compression.js +25 -25
  625. package/dist/esm/libs/compression.js.map +1 -1
  626. package/dist/esm/libs/contacts.d.ts +7 -7
  627. package/dist/esm/libs/contacts.js +143 -143
  628. package/dist/esm/libs/contacts.js.map +1 -1
  629. package/dist/esm/libs/cookie.d.ts +17 -17
  630. package/dist/esm/libs/cookie.js +70 -70
  631. package/dist/esm/libs/cookie.js.map +1 -1
  632. package/dist/esm/libs/crypto.d.ts +4 -4
  633. package/dist/esm/libs/crypto.js +15 -15
  634. package/dist/esm/libs/csv.d.ts +2 -2
  635. package/dist/esm/libs/csv.js +30 -30
  636. package/dist/esm/libs/csv.js.map +1 -1
  637. package/dist/esm/libs/currency.d.ts +1 -1
  638. package/dist/esm/libs/currency.js +22 -22
  639. package/dist/esm/libs/currency.js.map +1 -1
  640. package/dist/esm/libs/dates.d.ts +12 -12
  641. package/dist/esm/libs/dates.js +83 -83
  642. package/dist/esm/libs/dates.js.map +1 -1
  643. package/dist/esm/libs/domain.d.ts +2 -2
  644. package/dist/esm/libs/domain.js +33 -33
  645. package/dist/esm/libs/domain.js.map +1 -1
  646. package/dist/esm/libs/emails.d.ts +8 -8
  647. package/dist/esm/libs/emails.js +146 -146
  648. package/dist/esm/libs/emails.js.map +1 -1
  649. package/dist/esm/libs/http-error.d.ts +21 -21
  650. package/dist/esm/libs/http-error.js +59 -59
  651. package/dist/esm/libs/http-error.js.map +1 -1
  652. package/dist/esm/libs/http-status-codes.d.ts +58 -58
  653. package/dist/esm/libs/http-status-codes.js +59 -59
  654. package/dist/esm/libs/index.d.ts +19 -19
  655. package/dist/esm/libs/index.js +19 -19
  656. package/dist/esm/libs/numbers.d.ts +1 -1
  657. package/dist/esm/libs/numbers.js +11 -11
  658. package/dist/esm/libs/numbers.js.map +1 -1
  659. package/dist/esm/libs/referrer-parser/index.d.ts +2 -2
  660. package/dist/esm/libs/referrer-parser/index.js +2 -2
  661. package/dist/esm/libs/referrer-parser/referrer-data.d.ts +9 -9
  662. package/dist/esm/libs/referrer-parser/referrer-data.js +3304 -3304
  663. package/dist/esm/libs/referrer-parser/referrer-parser-util.d.ts +19 -20
  664. package/dist/esm/libs/referrer-parser/referrer-parser-util.js +124 -124
  665. package/dist/esm/libs/referrer-parser/referrer-parser-util.js.map +1 -1
  666. package/dist/esm/libs/strings.d.ts +3 -3
  667. package/dist/esm/libs/strings.js +40 -40
  668. package/dist/esm/libs/strings.js.map +1 -1
  669. package/dist/esm/libs/traits.d.ts +6 -6
  670. package/dist/esm/libs/traits.js +54 -54
  671. package/dist/esm/libs/traits.js.map +1 -1
  672. package/dist/esm/libs/url.d.ts +1 -1
  673. package/dist/esm/libs/url.js +9 -9
  674. package/dist/esm/services/acuity-api-service.d.ts +9 -9
  675. package/dist/esm/services/acuity-api-service.js +69 -69
  676. package/dist/esm/services/acuity-api-service.js.map +1 -1
  677. package/dist/esm/services/cache/generic-cached-object.d.ts +5 -5
  678. package/dist/esm/services/cache/generic-cached-object.js +1 -1
  679. package/dist/esm/services/cache/index.d.ts +1 -1
  680. package/dist/esm/services/cache/index.js +1 -1
  681. package/dist/esm/services/cache/product-cache-service.d.ts +21 -21
  682. package/dist/esm/services/cache/product-cache-service.js +68 -68
  683. package/dist/esm/services/cache/product-cache-service.js.map +1 -1
  684. package/dist/esm/services/currency-exchange-rate-lookup-service.d.ts +11 -11
  685. package/dist/esm/services/currency-exchange-rate-lookup-service.js +62 -62
  686. package/dist/esm/services/currency-exchange-rate-lookup-service.js.map +1 -1
  687. package/dist/esm/services/db/accounts-db-service.d.ts +9 -9
  688. package/dist/esm/services/db/accounts-db-service.js +29 -29
  689. package/dist/esm/services/db/accounts-db-service.js.map +1 -1
  690. package/dist/esm/services/db/api-keys-db-service.d.ts +10 -10
  691. package/dist/esm/services/db/api-keys-db-service.js +32 -32
  692. package/dist/esm/services/db/api-keys-db-service.js.map +1 -1
  693. package/dist/esm/services/db/contact-enrichments-db-service.d.ts +15 -15
  694. package/dist/esm/services/db/contact-enrichments-db-service.js +90 -90
  695. package/dist/esm/services/db/contact-enrichments-db-service.js.map +1 -1
  696. package/dist/esm/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  697. package/dist/esm/services/db/currency-exchange-rates-db-service.js +35 -35
  698. package/dist/esm/services/db/custom-measures-db-service.d.ts +14 -14
  699. package/dist/esm/services/db/custom-measures-db-service.js +44 -44
  700. package/dist/esm/services/db/custom-measures-db-service.js.map +1 -1
  701. package/dist/esm/services/db/destinations-db-service.d.ts +13 -13
  702. package/dist/esm/services/db/destinations-db-service.js +70 -70
  703. package/dist/esm/services/db/identity-cache-db-service.d.ts +28 -28
  704. package/dist/esm/services/db/identity-cache-db-service.js +313 -313
  705. package/dist/esm/services/db/identity-cache-db-service.js.map +1 -1
  706. package/dist/esm/services/db/identity-cache-dynamodb-service.d.ts +28 -28
  707. package/dist/esm/services/db/identity-cache-dynamodb-service.js +370 -370
  708. package/dist/esm/services/db/identity-cache-dynamodb-service.js.map +1 -1
  709. package/dist/esm/services/db/index.d.ts +17 -17
  710. package/dist/esm/services/db/index.js +17 -17
  711. package/dist/esm/services/db/log-events-db-service.d.ts +11 -11
  712. package/dist/esm/services/db/log-events-db-service.js +177 -177
  713. package/dist/esm/services/db/log-events-db-service.js.map +1 -1
  714. package/dist/esm/services/db/pixels-db-service.d.ts +8 -8
  715. package/dist/esm/services/db/pixels-db-service.js +31 -31
  716. package/dist/esm/services/db/purchasable-contacts-db-service.d.ts +9 -9
  717. package/dist/esm/services/db/purchasable-contacts-db-service.js +39 -39
  718. package/dist/esm/services/db/purchasable-contacts-db-service.js.map +1 -1
  719. package/dist/esm/services/db/purchased-contacts/index.d.ts +2 -2
  720. package/dist/esm/services/db/purchased-contacts/index.js +2 -2
  721. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
  722. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.js +148 -148
  723. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.js.map +1 -1
  724. package/dist/esm/services/db/purchased-contacts/types.d.ts +11 -11
  725. package/dist/esm/services/db/purchased-contacts/types.js +1 -1
  726. package/dist/esm/services/db/shopify-app-installs-db-service.d.ts +10 -10
  727. package/dist/esm/services/db/shopify-app-installs-db-service.js +48 -48
  728. package/dist/esm/services/db/shopify-app-installs-db-service.js.map +1 -1
  729. package/dist/esm/services/db/shopify-products-cache-db-service.d.ts +16 -16
  730. package/dist/esm/services/db/shopify-products-cache-db-service.js +66 -66
  731. package/dist/esm/services/db/shopify-products-cache-db-service.js.map +1 -1
  732. package/dist/esm/services/db/subscriptions-db-service.d.ts +11 -11
  733. package/dist/esm/services/db/subscriptions-db-service.js +34 -34
  734. package/dist/esm/services/db/subscriptions-db-service.js.map +1 -1
  735. package/dist/esm/services/db/tracking-events-db-service.d.ts +21 -21
  736. package/dist/esm/services/db/tracking-events-db-service.js +184 -184
  737. package/dist/esm/services/db/tracking-events-db-service.js.map +1 -1
  738. package/dist/esm/services/db/user-accounts-db-service.d.ts +7 -7
  739. package/dist/esm/services/db/user-accounts-db-service.js +13 -13
  740. package/dist/esm/services/email-verification/contact-email-verification-service.d.ts +7 -7
  741. package/dist/esm/services/email-verification/contact-email-verification-service.js +97 -97
  742. package/dist/esm/services/email-verification/contact-email-verification-service.js.map +1 -1
  743. package/dist/esm/services/email-verification/email-verification-service.d.ts +19 -19
  744. package/dist/esm/services/email-verification/email-verification-service.js +127 -127
  745. package/dist/esm/services/email-verification/email-verification-service.js.map +1 -1
  746. package/dist/esm/services/email-verification/index.d.ts +2 -2
  747. package/dist/esm/services/email-verification/index.js +2 -2
  748. package/dist/esm/services/eventbridge-integration-service.d.ts +9 -9
  749. package/dist/esm/services/eventbridge-integration-service.js +24 -24
  750. package/dist/esm/services/events/index.d.ts +3 -3
  751. package/dist/esm/services/events/index.js +3 -3
  752. package/dist/esm/services/events/log-event-service.d.ts +19 -19
  753. package/dist/esm/services/events/log-event-service.js +73 -73
  754. package/dist/esm/services/events/log-event-service.js.map +1 -1
  755. package/dist/esm/services/events/metric-event-service.d.ts +9 -9
  756. package/dist/esm/services/events/metric-event-service.js +45 -45
  757. package/dist/esm/services/events/tracking-event-sqs-service.d.ts +8 -8
  758. package/dist/esm/services/events/tracking-event-sqs-service.js +30 -30
  759. package/dist/esm/services/events/tracking-event-sqs-service.js.map +1 -1
  760. package/dist/esm/services/generic-cache-service.d.ts +7 -7
  761. package/dist/esm/services/generic-cache-service.js +29 -29
  762. package/dist/esm/services/generic-cache-service.js.map +1 -1
  763. package/dist/esm/services/index.d.ts +10 -10
  764. package/dist/esm/services/index.js +10 -10
  765. package/dist/esm/services/ipdata-lookup-service.d.ts +20 -20
  766. package/dist/esm/services/ipdata-lookup-service.js +108 -108
  767. package/dist/esm/services/ipdata-lookup-service.js.map +1 -1
  768. package/dist/esm/services/shopify/index.d.ts +2 -2
  769. package/dist/esm/services/shopify/index.js +2 -2
  770. package/dist/esm/services/shopify/products/index.d.ts +1 -1
  771. package/dist/esm/services/shopify/products/index.js +1 -1
  772. package/dist/esm/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  773. package/dist/esm/services/shopify/products/shopify-products-serviceV2.js +108 -108
  774. package/dist/esm/services/shopify/products/shopify-products-serviceV2.js.map +1 -1
  775. package/dist/esm/services/shopify/shopify-graphql-transformer.d.ts +8 -8
  776. package/dist/esm/services/shopify/shopify-graphql-transformer.js +138 -138
  777. package/dist/esm/services/shopify/shopify-graphql-transformer.js.map +1 -1
  778. package/dist/esm/types/acuity-types.d.ts +74 -74
  779. package/dist/esm/types/acuity-types.js +1 -1
  780. package/dist/esm/types/api-response.d.ts +6 -6
  781. package/dist/esm/types/api-response.js +1 -1
  782. package/dist/esm/types/index.d.ts +4 -4
  783. package/dist/esm/types/index.js +4 -4
  784. package/dist/esm/types/internal-events/event-detail-types.d.ts +20 -20
  785. package/dist/esm/types/internal-events/event-detail-types.js +24 -24
  786. package/dist/esm/types/internal-events/index.d.ts +1 -1
  787. package/dist/esm/types/internal-events/index.js +1 -1
  788. package/dist/esm/types/shopify-graphql-types/admin.generated.d.ts +123 -123
  789. package/dist/esm/types/shopify-graphql-types/admin.generated.js +1 -1
  790. package/dist/esm/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  791. package/dist/esm/types/shopify-graphql-types/admin.types.js +5299 -5299
  792. package/dist/esm/types/shopify-graphql-types/index.d.ts +2 -2
  793. package/dist/esm/types/shopify-graphql-types/index.js +2 -2
  794. package/dist/esm/types/shopify-rest-types.d.ts +767 -767
  795. package/dist/esm/types/shopify-rest-types.js +1 -1
  796. package/dist/esm/utils/compression.d.ts +34 -36
  797. package/dist/esm/utils/compression.js +187 -187
  798. package/dist/esm/utils/compression.js.map +1 -1
  799. package/dist/esm/utils/custom-measure-formula-utils.d.ts +6 -6
  800. package/dist/esm/utils/custom-measure-formula-utils.js +201 -201
  801. package/dist/esm/utils/custom-measure-formula-utils.js.map +1 -1
  802. package/dist/esm/utils/index.d.ts +4 -4
  803. package/dist/esm/utils/index.js +4 -4
  804. package/dist/esm/utils/retry-envelope.d.ts +12 -12
  805. package/dist/esm/utils/retry-envelope.js +22 -22
  806. package/dist/esm/utils/retry-envelope.js.map +1 -1
  807. package/dist/esm/utils/size.d.ts +2 -2
  808. package/dist/esm/utils/size.js +44 -44
  809. package/dist/esm/utils/size.js.map +1 -1
  810. package/package.json +2 -2
@@ -1,932 +1,942 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- const sqs_bundled_client_1 = require("../../clients/generic/sqs-bundled-client");
27
- const sqs_bundled_client_types_1 = require("../../clients/generic/sqs-bundled-client.types");
28
- const sqs_1 = require("../../constants/sqs");
29
- jest.mock('../../helpers/logging-helper', () => ({
30
- Logger: {
31
- debug: jest.fn(),
32
- info: jest.fn(),
33
- warn: jest.fn(),
34
- error: jest.fn(),
35
- },
36
- }));
37
- const actualSizeModule = jest.requireActual('../../utils/size');
38
- const mockSizeInBytes = jest.fn(actualSizeModule.sizeInBytes);
39
- jest.mock('../../utils/size', () => ({
40
- ...jest.requireActual('../../utils/size'),
41
- sizeInBytes: (obj) => mockSizeInBytes(obj),
42
- }));
43
- function makeTestEvent(id, name = 'test', value) {
44
- return { id, name, value };
45
- }
46
- describe('BundledSQSClient', () => {
47
- let mockSqsClient;
48
- let bundledClient;
49
- beforeEach(() => {
50
- mockSqsClient = {
51
- buildAndSendMessagesV2: jest.fn().mockResolvedValue({
52
- successCount: 1,
53
- failedCount: 0,
54
- batchCount: 1,
55
- failedMessages: [],
56
- }),
57
- queueUrl: 'https://sqs.us-east-1.amazonaws.com/123456789/test-queue',
58
- limits: (0, sqs_1.createSqsLimits)(sqs_1.SQS_1MB),
59
- };
60
- bundledClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
61
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
62
- compressionLevel: 3,
63
- });
64
- });
65
- describe('sendBundled', () => {
66
- it('returns empty result for empty items array', async () => {
67
- const result = await bundledClient.sendBundled('test-message', []);
68
- expect(result.totalItems).toBe(0);
69
- expect(result.bundleCount).toBe(0);
70
- expect(result.messageCount).toBe(0);
71
- expect(mockSqsClient.buildAndSendMessagesV2).not.toHaveBeenCalled();
72
- });
73
- it('passes delaySeconds through to the underlying send', async () => {
74
- const items = [makeTestEvent('1'), makeTestEvent('2')];
75
- await bundledClient.sendBundled('test-message', items, 480);
76
- expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledWith('test-message', expect.any(Array), 480);
77
- });
78
- it('defaults delaySeconds to 0 when omitted', async () => {
79
- const items = [makeTestEvent('1')];
80
- await bundledClient.sendBundled('test-message', items);
81
- expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledWith('test-message', expect.any(Array), 0);
82
- });
83
- it('bundles and sends small items', async () => {
84
- const items = [makeTestEvent('1'), makeTestEvent('2'), makeTestEvent('3')];
85
- const result = await bundledClient.sendBundled('test-message', items);
86
- expect(result.totalItems).toBe(3);
87
- expect(result.bundleCount).toBeGreaterThanOrEqual(1);
88
- expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledTimes(1);
89
- const sentEnvelopes = mockSqsClient.buildAndSendMessagesV2.mock
90
- .calls[0][1];
91
- expect(sentEnvelopes.length).toBeGreaterThanOrEqual(1);
92
- const envelope = sentEnvelopes[0];
93
- expect(envelope.v).toBe(1);
94
- expect(envelope.c).toBe(sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD);
95
- expect(envelope.n).toBe(3);
96
- expect(typeof envelope.p).toBe('string');
97
- });
98
- it('tracks compression metrics', async () => {
99
- const items = Array.from({ length: 100 }, (_, i) => makeTestEvent(`event-${i}`, `name-${i}`, i * 100));
100
- const result = await bundledClient.sendBundled('test-message', items);
101
- expect(result.metrics.originalSizeBytes).toBeGreaterThan(0);
102
- expect(result.metrics.finalSizeBytes).toBeGreaterThan(0);
103
- expect(result.metrics.compressionRatio).toBeGreaterThan(1);
104
- expect(result.metrics.compressionTimeMs).toBeGreaterThanOrEqual(0);
105
- });
106
- it('sends items without compression when NONE specified', async () => {
107
- const noCompressionClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
108
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.NONE,
109
- });
110
- const items = [makeTestEvent('1')];
111
- await noCompressionClient.sendBundled('test-message', items);
112
- const sentEnvelopes = mockSqsClient.buildAndSendMessagesV2.mock
113
- .calls[0][1];
114
- const envelope = sentEnvelopes[0];
115
- expect(envelope.c).toBe(sqs_bundled_client_types_1.CompressionAlgorithm.NONE);
116
- expect(Array.isArray(envelope.p)).toBe(true);
117
- });
118
- it('respects maxItemsPerBundle config', async () => {
119
- const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
120
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
121
- maxItemsPerBundle: 10,
122
- });
123
- const items = Array.from({ length: 25 }, (_, i) => makeTestEvent(`${i}`));
124
- mockSqsClient.buildAndSendMessagesV2.mockResolvedValue({
125
- successCount: 3,
126
- failedCount: 0,
127
- batchCount: 1,
128
- failedMessages: [],
129
- });
130
- const result = await client.sendBundled('test-message', items);
131
- expect(result.totalItems).toBe(25);
132
- expect(result.bundleCount).toBeGreaterThanOrEqual(2);
133
- const sentEnvelopes = mockSqsClient.buildAndSendMessagesV2.mock
134
- .calls[0][1];
135
- for (const envelope of sentEnvelopes) {
136
- expect(envelope.n).toBeLessThanOrEqual(10);
137
- }
138
- });
139
- it('calculates billable requests based on size', async () => {
140
- const items = Array.from({ length: 50 }, (_, i) => makeTestEvent(`${i}`, 'name', i * 10));
141
- const result = await bundledClient.sendBundled('test-message', items);
142
- expect(result.billableRequests).toBeGreaterThanOrEqual(1);
143
- });
144
- });
145
- describe('retry behavior', () => {
146
- it('retries failed messages', async () => {
147
- mockSqsClient.buildAndSendMessagesV2
148
- .mockResolvedValueOnce({
149
- successCount: 0,
150
- failedCount: 1,
151
- batchCount: 1,
152
- failedMessages: [{ v: 1, c: 'zstd', n: 1, p: 'test' }],
153
- })
154
- .mockResolvedValueOnce({
155
- successCount: 1,
156
- failedCount: 0,
157
- batchCount: 1,
158
- failedMessages: [],
159
- });
160
- const items = [makeTestEvent('1')];
161
- const result = await bundledClient.sendBundled('test-message', items);
162
- expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledTimes(2);
163
- expect(result.failedBundles).toBe(0);
164
- });
165
- it('stops retrying after max retries', async () => {
166
- mockSqsClient.buildAndSendMessagesV2.mockResolvedValue({
167
- successCount: 0,
168
- failedCount: 1,
169
- batchCount: 1,
170
- failedMessages: [{ v: 1, c: 'zstd', n: 1, p: 'test' }],
171
- });
172
- const items = [makeTestEvent('1')];
173
- const result = await bundledClient.sendBundled('test-message', items);
174
- expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledTimes(3);
175
- expect(result.failedBundles).toBeGreaterThan(0);
176
- });
177
- });
178
- describe('auto-resize', () => {
179
- it('is enabled by default', () => {
180
- const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient);
181
- expect(client.config.autoResize).toBe(true);
182
- });
183
- it('can be configured to be disabled', () => {
184
- const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
185
- autoResize: false,
186
- });
187
- expect(client.config.autoResize).toBe(false);
188
- });
189
- });
190
- describe('skippedItems behavior', () => {
191
- afterEach(() => {
192
- mockSizeInBytes.mockImplementation(actualSizeModule.sizeInBytes);
193
- });
194
- it('reports skippedItems as 0 when all items sent successfully', async () => {
195
- const items = [makeTestEvent('1'), makeTestEvent('2')];
196
- const result = await bundledClient.sendBundled('test-message', items);
197
- expect(result.skippedItems).toBe(0);
198
- expect(result.totalItems).toBe(2);
199
- expect(result.failedBundles).toBe(0);
200
- });
201
- it('tracks skippedItems when autoResize disabled and bundle exceeds limit', async () => {
202
- const noResizeClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
203
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
204
- autoResize: false,
205
- });
206
- const items = [makeTestEvent('1'), makeTestEvent('2'), makeTestEvent('3')];
207
- mockSizeInBytes.mockImplementation((obj) => {
208
- if (typeof obj === 'object' && obj !== null && 'v' in obj) {
209
- return 2000000;
210
- }
211
- return 100;
212
- });
213
- const result = await noResizeClient.sendBundled('test-message', items);
214
- expect(result.skippedItems).toBe(3);
215
- expect(result.totalItems).toBe(3);
216
- expect(mockSqsClient.buildAndSendMessagesV2).not.toHaveBeenCalled();
217
- });
218
- it('tracks skippedItems when single item cannot fit (splitAndRetry terminates)', async () => {
219
- const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
220
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
221
- autoResize: true,
222
- });
223
- const items = [makeTestEvent('oversized-item')];
224
- mockSizeInBytes.mockImplementation((obj) => {
225
- if (typeof obj === 'object' && obj !== null && 'v' in obj) {
226
- return 2000000;
227
- }
228
- return 100;
229
- });
230
- const result = await client.sendBundled('test-message', items);
231
- expect(result.skippedItems).toBe(1);
232
- expect(result.totalItems).toBe(1);
233
- });
234
- it('reports partial skippedItems when some items are too large', async () => {
235
- const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
236
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
237
- autoResize: true,
238
- maxItemsPerBundle: 1,
239
- });
240
- const items = [makeTestEvent('small-1'), makeTestEvent('oversized'), makeTestEvent('small-2')];
241
- let envelopeValidationCount = 0;
242
- mockSizeInBytes.mockImplementation((obj) => {
243
- if (typeof obj === 'object' && obj !== null && 'v' in obj) {
244
- envelopeValidationCount++;
245
- if (envelopeValidationCount === 2) {
246
- return 2000000;
247
- }
248
- return 500;
249
- }
250
- return 100;
251
- });
252
- const result = await client.sendBundled('test-message', items);
253
- expect(result.skippedItems).toBe(1);
254
- expect(result.totalItems).toBe(3);
255
- expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalled();
256
- });
257
- it('emptyResult returns skippedItems as 0', async () => {
258
- const result = await bundledClient.sendBundled('test-message', []);
259
- expect(result.skippedItems).toBe(0);
260
- expect(result.totalItems).toBe(0);
261
- });
262
- });
263
- describe('integration: end-to-end bundle flow', () => {
264
- it('produces envelopes that unbundleRecords can process', async () => {
265
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
266
- const items = [
267
- makeTestEvent('event-1', 'purchase', 99.99),
268
- makeTestEvent('event-2', 'add_to_cart', 29.99),
269
- makeTestEvent('event-3', 'page_view'),
270
- ];
271
- let capturedEnvelope = null;
272
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_type, envelopes) => {
273
- capturedEnvelope = envelopes[0];
274
- return {
275
- successCount: envelopes.length,
276
- failedCount: 0,
277
- batchCount: 1,
278
- failedMessages: [],
279
- };
280
- });
281
- await bundledClient.sendBundled('test-message', items);
282
- expect(capturedEnvelope).not.toBeNull();
283
- const sqsRecord = {
284
- messageId: 'msg-1',
285
- body: JSON.stringify({ messageBody: capturedEnvelope }),
286
- };
287
- const { items: unbundledItems, stats } = await unbundleRecords([sqsRecord]);
288
- expect(unbundledItems).toHaveLength(3);
289
- expect(unbundledItems[0]).toEqual({ id: 'event-1', name: 'purchase', value: 99.99 });
290
- expect(unbundledItems[1]).toEqual({ id: 'event-2', name: 'add_to_cart', value: 29.99 });
291
- expect(unbundledItems[2]).toEqual({ id: 'event-3', name: 'page_view' });
292
- expect(stats.bundledSqsRecords).toBe(1);
293
- });
294
- it('maintains compatibility with large bundles', async () => {
295
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
296
- const items = Array.from({ length: 200 }, (_, i) => makeTestEvent(`event-${i}`, `type-${i % 5}`, i * 1.5));
297
- let capturedEnvelopes = [];
298
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_type, envelopes) => {
299
- capturedEnvelopes = envelopes;
300
- return {
301
- successCount: envelopes.length,
302
- failedCount: 0,
303
- batchCount: 1,
304
- failedMessages: [],
305
- };
306
- });
307
- await bundledClient.sendBundled('test-message', items);
308
- const sqsRecords = capturedEnvelopes.map((env, i) => ({
309
- messageId: `msg-${i}`,
310
- body: JSON.stringify({ messageBody: env }),
311
- }));
312
- const { items: unbundledItems } = await unbundleRecords(sqsRecords);
313
- expect(unbundledItems).toHaveLength(200);
314
- expect(unbundledItems[0].id).toBe('event-0');
315
- expect(unbundledItems[199].id).toBe('event-199');
316
- });
317
- });
318
- describe('producer edge cases - real sequences', () => {
319
- it('handles 1000 items with real bundling and verifies envelope structure', async () => {
320
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
321
- const items = Array.from({ length: 1000 }, (_, i) => ({
322
- id: `item-${i}`,
323
- name: `payload-${i}`,
324
- value: i * 10,
325
- data: `extra-data-${i}`,
326
- }));
327
- const capturedEnvelopes = [];
328
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
329
- capturedEnvelopes.push(...envelopes);
330
- return {
331
- successCount: envelopes.length,
332
- failedCount: 0,
333
- batchCount: 1,
334
- failedMessages: [],
335
- };
336
- });
337
- const result = await bundledClient.sendBundled('test', items);
338
- expect(result.totalItems).toBe(1000);
339
- expect(capturedEnvelopes.length).toBeGreaterThan(0);
340
- let totalItemsInEnvelopes = 0;
341
- for (const env of capturedEnvelopes) {
342
- expect(env.v).toBe(1);
343
- expect(env.c).toBe(sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD);
344
- expect(typeof env.p).toBe('string');
345
- expect(typeof env.n).toBe('number');
346
- expect(env.n).toBeGreaterThan(0);
347
- totalItemsInEnvelopes += env.n;
348
- }
349
- expect(totalItemsInEnvelopes).toBe(1000);
350
- const sqsRecords = capturedEnvelopes.map((env, i) => ({
351
- messageId: `msg-${i}`,
352
- body: JSON.stringify({ messageBody: env }),
353
- }));
354
- const { items: unbundledItems } = await unbundleRecords(sqsRecords);
355
- expect(unbundledItems).toHaveLength(1000);
356
- expect(unbundledItems[0]).toEqual({ id: 'item-0', name: 'payload-0', value: 0, data: 'extra-data-0' });
357
- expect(unbundledItems[999]).toEqual({ id: 'item-999', name: 'payload-999', value: 9990, data: 'extra-data-999' });
358
- });
359
- it('achieves compression effectiveness with repetitive data', async () => {
360
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
361
- const repetitiveText = 'AAAAAAAAAA'.repeat(100);
362
- const items = Array.from({ length: 100 }, (_, i) => ({
363
- id: `item-${i}`,
364
- name: 'repetitive-test',
365
- value: i,
366
- data: repetitiveText,
367
- }));
368
- const capturedEnvelopes = [];
369
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
370
- capturedEnvelopes.push(envelopes[0]);
371
- return {
372
- successCount: envelopes.length,
373
- failedCount: 0,
374
- batchCount: 1,
375
- failedMessages: [],
376
- };
377
- });
378
- const result = await bundledClient.sendBundled('test', items);
379
- expect(result.metrics.compressionRatio).toBeGreaterThan(1);
380
- expect(result.metrics.finalSizeBytes).toBeLessThan(result.metrics.originalSizeBytes);
381
- expect(result.metrics.compressionRatio).toBeGreaterThan(5);
382
- expect(capturedEnvelopes).toHaveLength(1);
383
- const envelope = capturedEnvelopes[0];
384
- expect(typeof envelope.p).toBe('string');
385
- const { items: unbundledItems } = await unbundleRecords([
386
- {
387
- messageId: 'msg-1',
388
- body: JSON.stringify({ messageBody: envelope }),
389
- },
390
- ]);
391
- expect(unbundledItems).toHaveLength(100);
392
- expect(unbundledItems[0].data).toBe(repetitiveText);
393
- expect(unbundledItems[99].data).toBe(repetitiveText);
394
- });
395
- it('handles various item sizes correctly', async () => {
396
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
397
- const tinyItems = Array.from({ length: 10 }, (_, i) => ({
398
- id: `tiny-${i}`,
399
- name: 't',
400
- }));
401
- const smallItems = Array.from({ length: 10 }, (_, i) => ({
402
- id: `small-${i}`,
403
- name: 'small-item',
404
- value: i,
405
- data: 'x'.repeat(100),
406
- }));
407
- const mediumItems = Array.from({ length: 10 }, (_, i) => ({
408
- id: `medium-${i}`,
409
- name: 'medium-item',
410
- value: i,
411
- data: 'y'.repeat(10000),
412
- }));
413
- const largerItems = Array.from({ length: 5 }, (_, i) => ({
414
- id: `larger-${i}`,
415
- name: 'larger-item',
416
- value: i,
417
- data: 'z'.repeat(100000),
418
- }));
419
- const allItems = [...tinyItems, ...smallItems, ...mediumItems, ...largerItems];
420
- const totalExpectedItems = allItems.length;
421
- const capturedEnvelopes = [];
422
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
423
- capturedEnvelopes.push(...envelopes);
424
- return {
425
- successCount: envelopes.length,
426
- failedCount: 0,
427
- batchCount: 1,
428
- failedMessages: [],
429
- };
430
- });
431
- const result = await bundledClient.sendBundled('test', allItems);
432
- expect(result.totalItems).toBe(totalExpectedItems);
433
- expect(result.skippedItems).toBe(0);
434
- const totalInEnvelopes = capturedEnvelopes.reduce((sum, env) => sum + env.n, 0);
435
- expect(totalInEnvelopes).toBe(totalExpectedItems);
436
- const sqsRecords = capturedEnvelopes.map((env, i) => ({
437
- messageId: `msg-${i}`,
438
- body: JSON.stringify({ messageBody: env }),
439
- }));
440
- const { items: unbundledItems } = await unbundleRecords(sqsRecords);
441
- expect(unbundledItems).toHaveLength(totalExpectedItems);
442
- const unbundledTiny = unbundledItems.filter((item) => item.id.startsWith('tiny-'));
443
- const unbundledSmall = unbundledItems.filter((item) => item.id.startsWith('small-'));
444
- const unbundledMedium = unbundledItems.filter((item) => item.id.startsWith('medium-'));
445
- const unbundledLarger = unbundledItems.filter((item) => item.id.startsWith('larger-'));
446
- expect(unbundledTiny).toHaveLength(10);
447
- expect(unbundledSmall).toHaveLength(10);
448
- expect(unbundledMedium).toHaveLength(10);
449
- expect(unbundledLarger).toHaveLength(5);
450
- expect(unbundledSmall[0].data).toBe('x'.repeat(100));
451
- expect(unbundledMedium[0].data).toBe('y'.repeat(10000));
452
- expect(unbundledLarger[0].data).toBe('z'.repeat(100000));
453
- });
454
- it('preserves unicode and special characters through compression', async () => {
455
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
456
- const unicodeItems = [
457
- {
458
- id: 'emoji',
459
- name: '🎉🚀💯🔥✨',
460
- data: 'Celebration 🎊 with many emojis 🌟⭐💫',
461
- },
462
- {
463
- id: 'chinese',
464
- name: '你好世界',
465
- data: '这是一个测试消息,包含中文字符。北京、上海、广州。',
466
- },
467
- {
468
- id: 'arabic',
469
- name: 'مرحبا بالعالم',
470
- data: 'هذه رسالة اختبار باللغة العربية',
471
- },
472
- {
473
- id: 'japanese',
474
- name: 'こんにちは世界',
475
- data: 'テスト メッセージです。東京、大阪、京都。',
476
- },
477
- {
478
- id: 'korean',
479
- name: '안녕하세요 세계',
480
- data: '테스트 메시지입니다. 서울, 부산, 인천.',
481
- },
482
- {
483
- id: 'special-symbols',
484
- name: '†‡§¶•‰™©®',
485
- data: 'Special: «»‹› ′″ ∞∑∏√∫ ≤≥≠≈ αβγδε',
486
- },
487
- {
488
- id: 'mixed-unicode',
489
- name: 'Mixed: Ñ ü ö ä ß',
490
- data: 'Ümlauts: äöüÄÖÜß dashes—and–more Ç ñ ¡¿',
491
- },
492
- {
493
- id: 'mathematical',
494
- name: '∀x∈ℝ: x² ≥ 0',
495
- data: 'Math: ∫₀^∞ e^(-x²) dx = √π/2, ∑_{n=1}^{∞} 1/n² = π²/6',
496
- },
497
- {
498
- id: 'currency',
499
- name: '€£¥₹₽¢',
500
- data: 'Prices: $100, €85, £70, ¥10000, ₹8000, ₽7500',
501
- },
502
- {
503
- id: 'newlines-tabs',
504
- name: 'control\tchars',
505
- data: 'Line 1\nLine 2\rLine 3\r\nLine 4\tTabbed',
506
- },
507
- ];
508
- let capturedEnvelope = null;
509
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
510
- capturedEnvelope = envelopes[0];
511
- return {
512
- successCount: envelopes.length,
513
- failedCount: 0,
514
- batchCount: 1,
515
- failedMessages: [],
516
- };
517
- });
518
- const result = await bundledClient.sendBundled('test', unicodeItems);
519
- expect(result.totalItems).toBe(unicodeItems.length);
520
- expect(result.skippedItems).toBe(0);
521
- expect(capturedEnvelope).not.toBeNull();
522
- const { items: unbundledItems } = await unbundleRecords([
523
- {
524
- messageId: 'msg-1',
525
- body: JSON.stringify({ messageBody: capturedEnvelope }),
526
- },
527
- ]);
528
- expect(unbundledItems).toHaveLength(unicodeItems.length);
529
- for (let i = 0; i < unicodeItems.length; i++) {
530
- expect(unbundledItems[i]).toEqual(unicodeItems[i]);
531
- }
532
- const emojiItem = unbundledItems.find((item) => item.id === 'emoji');
533
- expect(emojiItem?.name).toBe('🎉🚀💯🔥✨');
534
- const chineseItem = unbundledItems.find((item) => item.id === 'chinese');
535
- expect(chineseItem?.name).toBe('你好世界');
536
- const arabicItem = unbundledItems.find((item) => item.id === 'arabic');
537
- expect(arabicItem?.name).toBe('مرحبا بالعالم');
538
- });
539
- it('preserves deeply nested object structures', async () => {
540
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
541
- const nestedItems = [
542
- {
543
- id: 'deep-nested',
544
- name: 'deep',
545
- nested: {
546
- level1: {
547
- level2: {
548
- level3: {
549
- level4: {
550
- level5: {
551
- level6: {
552
- value: 'deep-value',
553
- number: 12345,
554
- boolean: true,
555
- },
556
- },
557
- },
558
- },
559
- },
560
- },
561
- },
562
- },
563
- {
564
- id: 'array-of-objects',
565
- name: 'arrays',
566
- items: [
567
- { subId: 'sub-1', data: { nested: { value: 'a' } } },
568
- { subId: 'sub-2', data: { nested: { value: 'b' } } },
569
- { subId: 'sub-3', data: { nested: { value: 'c' } } },
570
- ],
571
- },
572
- {
573
- id: 'mixed-structures',
574
- name: 'mixed',
575
- config: {
576
- settings: {
577
- features: ['feature-1', 'feature-2', 'feature-3'],
578
- metadata: {
579
- tags: {
580
- primary: ['tag-a', 'tag-b'],
581
- secondary: {
582
- group1: ['tag-c', 'tag-d'],
583
- group2: ['tag-e', 'tag-f'],
584
- },
585
- },
586
- },
587
- },
588
- },
589
- },
590
- {
591
- id: 'null-undefined-handling',
592
- name: 'nulls',
593
- value: null,
594
- nested: {
595
- nullField: null,
596
- emptyObject: {},
597
- emptyArray: [],
598
- zeroValue: 0,
599
- falseValue: false,
600
- emptyString: '',
601
- },
602
- },
603
- {
604
- id: 'large-array',
605
- name: 'large-array',
606
- items: Array.from({ length: 100 }, (_, i) => ({
607
- index: i,
608
- data: `item-${i}`,
609
- nested: { level: 1, value: i * 2 },
610
- })),
611
- },
612
- ];
613
- let capturedEnvelope = null;
614
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
615
- capturedEnvelope = envelopes[0];
616
- return {
617
- successCount: envelopes.length,
618
- failedCount: 0,
619
- batchCount: 1,
620
- failedMessages: [],
621
- };
622
- });
623
- const genericClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
624
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
625
- });
626
- const result = await genericClient.sendBundled('test', nestedItems);
627
- expect(result.totalItems).toBe(nestedItems.length);
628
- expect(result.skippedItems).toBe(0);
629
- const { items: unbundledItems } = await unbundleRecords([
630
- {
631
- messageId: 'msg-1',
632
- body: JSON.stringify({ messageBody: capturedEnvelope }),
633
- },
634
- ]);
635
- expect(unbundledItems).toHaveLength(nestedItems.length);
636
- const deepItem = unbundledItems.find((item) => item.id === 'deep-nested');
637
- expect(deepItem?.nested?.level1?.level2?.level3?.level4?.level5?.level6?.value).toBe('deep-value');
638
- expect(deepItem?.nested?.level1?.level2?.level3?.level4?.level5?.level6?.number).toBe(12345);
639
- expect(deepItem?.nested?.level1?.level2?.level3?.level4?.level5?.level6?.boolean).toBe(true);
640
- const arrayItem = unbundledItems.find((item) => item.id === 'array-of-objects');
641
- expect(arrayItem?.items?.length).toBe(3);
642
- expect(arrayItem?.items?.[0]?.data?.nested?.value).toBe('a');
643
- expect(arrayItem?.items?.[2]?.data?.nested?.value).toBe('c');
644
- const mixedItem = unbundledItems.find((item) => item.id === 'mixed-structures');
645
- expect(mixedItem?.config?.settings?.features).toEqual(['feature-1', 'feature-2', 'feature-3']);
646
- expect(mixedItem?.config?.settings?.metadata?.tags?.secondary?.group2).toEqual(['tag-e', 'tag-f']);
647
- const nullItem = unbundledItems.find((item) => item.id === 'null-undefined-handling');
648
- expect(nullItem?.value).toBeNull();
649
- expect(nullItem?.nested?.nullField).toBeNull();
650
- expect(nullItem?.nested?.emptyObject).toEqual({});
651
- expect(nullItem?.nested?.emptyArray).toEqual([]);
652
- expect(nullItem?.nested?.zeroValue).toBe(0);
653
- expect(nullItem?.nested?.falseValue).toBe(false);
654
- expect(nullItem?.nested?.emptyString).toBe('');
655
- const largeArrayItem = unbundledItems.find((item) => item.id === 'large-array');
656
- expect(largeArrayItem?.items).toHaveLength(100);
657
- expect(largeArrayItem?.items?.[0]).toEqual({ index: 0, data: 'item-0', nested: { level: 1, value: 0 } });
658
- expect(largeArrayItem?.items?.[99]).toEqual({ index: 99, data: 'item-99', nested: { level: 1, value: 198 } });
659
- });
660
- it('handles exactly 1 item', async () => {
661
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
662
- const items = [{ id: 'single', name: 'only-one', value: 42 }];
663
- const capturedEnvelopes = [];
664
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
665
- capturedEnvelopes.push(envelopes[0]);
666
- return {
667
- successCount: envelopes.length,
668
- failedCount: 0,
669
- batchCount: 1,
670
- failedMessages: [],
671
- };
672
- });
673
- const result = await bundledClient.sendBundled('test', items);
674
- expect(result.totalItems).toBe(1);
675
- expect(result.bundleCount).toBe(1);
676
- expect(result.messageCount).toBe(1);
677
- expect(capturedEnvelopes).toHaveLength(1);
678
- expect(capturedEnvelopes[0].n).toBe(1);
679
- const { items: unbundledItems } = await unbundleRecords([
680
- {
681
- messageId: 'msg-1',
682
- body: JSON.stringify({ messageBody: capturedEnvelopes[0] }),
683
- },
684
- ]);
685
- expect(unbundledItems).toHaveLength(1);
686
- expect(unbundledItems[0]).toEqual(items[0]);
687
- });
688
- it('handles exactly maxItemsPerBundle items', async () => {
689
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
690
- const maxItems = 50;
691
- const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
692
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
693
- maxItemsPerBundle: maxItems,
694
- });
695
- const items = Array.from({ length: maxItems }, (_, i) => ({
696
- id: `item-${i}`,
697
- name: `name-${i}`,
698
- value: i,
699
- }));
700
- const capturedEnvelopes = [];
701
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
702
- capturedEnvelopes.push(...envelopes);
703
- return {
704
- successCount: envelopes.length,
705
- failedCount: 0,
706
- batchCount: 1,
707
- failedMessages: [],
708
- };
709
- });
710
- const result = await client.sendBundled('test', items);
711
- expect(result.totalItems).toBe(maxItems);
712
- expect(capturedEnvelopes).toHaveLength(1);
713
- expect(capturedEnvelopes[0].n).toBe(maxItems);
714
- const sqsRecords = capturedEnvelopes.map((env, i) => ({
715
- messageId: `msg-${i}`,
716
- body: JSON.stringify({ messageBody: env }),
717
- }));
718
- const { items: unbundledItems } = await unbundleRecords(sqsRecords);
719
- expect(unbundledItems).toHaveLength(maxItems);
720
- });
721
- it('handles maxItemsPerBundle + 1 items (splits correctly)', async () => {
722
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
723
- const maxItems = 50;
724
- const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
725
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
726
- maxItemsPerBundle: maxItems,
727
- });
728
- const items = Array.from({ length: maxItems + 1 }, (_, i) => ({
729
- id: `item-${i}`,
730
- name: `name-${i}`,
731
- value: i,
732
- }));
733
- const capturedEnvelopes = [];
734
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
735
- capturedEnvelopes.push(...envelopes);
736
- return {
737
- successCount: envelopes.length,
738
- failedCount: 0,
739
- batchCount: 1,
740
- failedMessages: [],
741
- };
742
- });
743
- const result = await client.sendBundled('test', items);
744
- expect(result.totalItems).toBe(maxItems + 1);
745
- expect(capturedEnvelopes).toHaveLength(2);
746
- expect(capturedEnvelopes[0].n).toBe(maxItems);
747
- expect(capturedEnvelopes[1].n).toBe(1);
748
- const sqsRecords = capturedEnvelopes.map((env, i) => ({
749
- messageId: `msg-${i}`,
750
- body: JSON.stringify({ messageBody: env }),
751
- }));
752
- const { items: unbundledItems } = await unbundleRecords(sqsRecords);
753
- expect(unbundledItems).toHaveLength(maxItems + 1);
754
- });
755
- it('handles uncompressed mode (NONE) with various data', async () => {
756
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
757
- const noCompressionClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
758
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.NONE,
759
- });
760
- const items = Array.from({ length: 50 }, (_, i) => ({
761
- id: `uncompressed-${i}`,
762
- name: `test-${i}`,
763
- value: i * 100,
764
- data: `Some data for item ${i}`,
765
- }));
766
- const capturedEnvelopes = [];
767
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
768
- capturedEnvelopes.push(envelopes[0]);
769
- return {
770
- successCount: envelopes.length,
771
- failedCount: 0,
772
- batchCount: 1,
773
- failedMessages: [],
774
- };
775
- });
776
- const result = await noCompressionClient.sendBundled('test', items);
777
- expect(result.totalItems).toBe(50);
778
- expect(capturedEnvelopes).toHaveLength(1);
779
- const envelope = capturedEnvelopes[0];
780
- expect(envelope.c).toBe(sqs_bundled_client_types_1.CompressionAlgorithm.NONE);
781
- expect(Array.isArray(envelope.p)).toBe(true);
782
- expect(envelope.p.length).toBe(50);
783
- expect(result.metrics.compressionRatio).toBeCloseTo(1, 0);
784
- const { items: unbundledItems } = await unbundleRecords([
785
- {
786
- messageId: 'msg-1',
787
- body: JSON.stringify({ messageBody: envelope }),
788
- },
789
- ]);
790
- expect(unbundledItems).toHaveLength(50);
791
- expect(unbundledItems[0]).toEqual(items[0]);
792
- expect(unbundledItems[49]).toEqual(items[49]);
793
- });
794
- it('produces correct metrics for a large mixed batch', async () => {
795
- const items = Array.from({ length: 500 }, (_, i) => ({
796
- id: `metric-test-${i}`,
797
- name: `item-${i % 10}`,
798
- value: i,
799
- data: i % 5 === 0 ? 'repeated-data'.repeat(100) : `unique-${i}`,
800
- }));
801
- const capturedEnvelopes = [];
802
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
803
- capturedEnvelopes.push(...envelopes);
804
- return {
805
- successCount: envelopes.length,
806
- failedCount: 0,
807
- batchCount: 1,
808
- failedMessages: [],
809
- };
810
- });
811
- const result = await bundledClient.sendBundled('test', items);
812
- expect(result.totalItems).toBe(500);
813
- expect(result.metrics.originalSizeBytes).toBeGreaterThan(0);
814
- expect(result.metrics.finalSizeBytes).toBeGreaterThan(0);
815
- expect(result.metrics.compressionRatio).toBeGreaterThan(1);
816
- expect(result.metrics.compressionTimeMs).toBeGreaterThanOrEqual(0);
817
- expect(result.metrics.avgItemsPerBundle).toBeGreaterThan(0);
818
- const expectedAvg = items.length / capturedEnvelopes.length;
819
- expect(result.metrics.avgItemsPerBundle).toBeCloseTo(expectedAvg, 1);
820
- expect(result.billableRequests).toBeGreaterThanOrEqual(1);
821
- });
822
- it('handles items with special JSON edge cases', async () => {
823
- const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
824
- const edgeCaseItems = [
825
- {
826
- id: 'large-numbers',
827
- name: 'numbers',
828
- bigInt: 9007199254740991,
829
- scientific: 1.23e10,
830
- decimal: 0.1 + 0.2,
831
- negative: -999999,
832
- zero: 0,
833
- negativeZero: -0,
834
- },
835
- {
836
- id: 'special-strings',
837
- name: 'strings',
838
- data: JSON.stringify({ nested: 'json' }),
839
- withQuotes: 'He said "hello"',
840
- withBackslash: 'path\\to\\file',
841
- withSlash: 'https://example.com/path',
842
- },
843
- {
844
- id: 'boolean-variants',
845
- name: 'booleans',
846
- trueVal: true,
847
- falseVal: false,
848
- truthy: 1,
849
- falsy: 0,
850
- },
851
- {
852
- id: 'dates-as-strings',
853
- name: 'dates',
854
- isoDate: '2024-01-15T10:30:00.000Z',
855
- timestamp: 1705315800000,
856
- },
857
- ];
858
- let capturedEnvelope = null;
859
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
860
- capturedEnvelope = envelopes[0];
861
- return {
862
- successCount: envelopes.length,
863
- failedCount: 0,
864
- batchCount: 1,
865
- failedMessages: [],
866
- };
867
- });
868
- const genericClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
869
- compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
870
- });
871
- const result = await genericClient.sendBundled('test', edgeCaseItems);
872
- expect(result.totalItems).toBe(edgeCaseItems.length);
873
- expect(result.skippedItems).toBe(0);
874
- const { items: unbundledItems } = await unbundleRecords([
875
- {
876
- messageId: 'msg-1',
877
- body: JSON.stringify({ messageBody: capturedEnvelope }),
878
- },
879
- ]);
880
- expect(unbundledItems).toHaveLength(edgeCaseItems.length);
881
- const numbersItem = unbundledItems.find((item) => item.id === 'large-numbers');
882
- expect(numbersItem?.bigInt).toBe(9007199254740991);
883
- expect(numbersItem?.scientific).toBe(1.23e10);
884
- expect(numbersItem?.negative).toBe(-999999);
885
- expect(numbersItem?.zero).toBe(0);
886
- const stringsItem = unbundledItems.find((item) => item.id === 'special-strings');
887
- expect(stringsItem?.data).toBe(JSON.stringify({ nested: 'json' }));
888
- expect(stringsItem?.withQuotes).toBe('He said "hello"');
889
- expect(stringsItem?.withBackslash).toBe('path\\to\\file');
890
- const booleansItem = unbundledItems.find((item) => item.id === 'boolean-variants');
891
- expect(booleansItem?.trueVal).toBe(true);
892
- expect(booleansItem?.falseVal).toBe(false);
893
- });
894
- it('handles concurrent sends without interference', async () => {
895
- const batch1 = Array.from({ length: 100 }, (_, i) => ({
896
- id: `batch1-${i}`,
897
- name: 'batch-one',
898
- value: i,
899
- }));
900
- const batch2 = Array.from({ length: 100 }, (_, i) => ({
901
- id: `batch2-${i}`,
902
- name: 'batch-two',
903
- value: i * 2,
904
- }));
905
- const batch3 = Array.from({ length: 100 }, (_, i) => ({
906
- id: `batch3-${i}`,
907
- name: 'batch-three',
908
- value: i * 3,
909
- }));
910
- mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
911
- return {
912
- successCount: envelopes.length,
913
- failedCount: 0,
914
- batchCount: 1,
915
- failedMessages: [],
916
- };
917
- });
918
- const [result1, result2, result3] = await Promise.all([
919
- bundledClient.sendBundled('test', batch1),
920
- bundledClient.sendBundled('test', batch2),
921
- bundledClient.sendBundled('test', batch3),
922
- ]);
923
- expect(result1.totalItems).toBe(100);
924
- expect(result2.totalItems).toBe(100);
925
- expect(result3.totalItems).toBe(100);
926
- expect(result1.skippedItems).toBe(0);
927
- expect(result2.skippedItems).toBe(0);
928
- expect(result3.skippedItems).toBe(0);
929
- });
930
- });
931
- });
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ const sqs_bundled_client_1 = require("../../clients/generic/sqs-bundled-client");
37
+ const sqs_bundled_client_types_1 = require("../../clients/generic/sqs-bundled-client.types");
38
+ const sqs_1 = require("../../constants/sqs");
39
+ jest.mock('../../helpers/logging-helper', () => ({
40
+ Logger: {
41
+ debug: jest.fn(),
42
+ info: jest.fn(),
43
+ warn: jest.fn(),
44
+ error: jest.fn(),
45
+ },
46
+ }));
47
+ const actualSizeModule = jest.requireActual('../../utils/size');
48
+ const mockSizeInBytes = jest.fn(actualSizeModule.sizeInBytes);
49
+ jest.mock('../../utils/size', () => ({
50
+ ...jest.requireActual('../../utils/size'),
51
+ sizeInBytes: (obj) => mockSizeInBytes(obj),
52
+ }));
53
+ function makeTestEvent(id, name = 'test', value) {
54
+ return { id, name, value };
55
+ }
56
+ describe('BundledSQSClient', () => {
57
+ let mockSqsClient;
58
+ let bundledClient;
59
+ beforeEach(() => {
60
+ mockSqsClient = {
61
+ buildAndSendMessagesV2: jest.fn().mockResolvedValue({
62
+ successCount: 1,
63
+ failedCount: 0,
64
+ batchCount: 1,
65
+ failedMessages: [],
66
+ }),
67
+ queueUrl: 'https://sqs.us-east-1.amazonaws.com/123456789/test-queue',
68
+ limits: (0, sqs_1.createSqsLimits)(sqs_1.SQS_1MB),
69
+ };
70
+ bundledClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
71
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
72
+ compressionLevel: 3,
73
+ });
74
+ });
75
+ describe('sendBundled', () => {
76
+ it('returns empty result for empty items array', async () => {
77
+ const result = await bundledClient.sendBundled('test-message', []);
78
+ expect(result.totalItems).toBe(0);
79
+ expect(result.bundleCount).toBe(0);
80
+ expect(result.messageCount).toBe(0);
81
+ expect(mockSqsClient.buildAndSendMessagesV2).not.toHaveBeenCalled();
82
+ });
83
+ it('passes delaySeconds through to the underlying send', async () => {
84
+ const items = [makeTestEvent('1'), makeTestEvent('2')];
85
+ await bundledClient.sendBundled('test-message', items, 480);
86
+ expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledWith('test-message', expect.any(Array), 480);
87
+ });
88
+ it('defaults delaySeconds to 0 when omitted', async () => {
89
+ const items = [makeTestEvent('1')];
90
+ await bundledClient.sendBundled('test-message', items);
91
+ expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledWith('test-message', expect.any(Array), 0);
92
+ });
93
+ it('bundles and sends small items', async () => {
94
+ const items = [makeTestEvent('1'), makeTestEvent('2'), makeTestEvent('3')];
95
+ const result = await bundledClient.sendBundled('test-message', items);
96
+ expect(result.totalItems).toBe(3);
97
+ expect(result.bundleCount).toBeGreaterThanOrEqual(1);
98
+ expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledTimes(1);
99
+ const sentEnvelopes = mockSqsClient.buildAndSendMessagesV2.mock
100
+ .calls[0][1];
101
+ expect(sentEnvelopes.length).toBeGreaterThanOrEqual(1);
102
+ const envelope = sentEnvelopes[0];
103
+ expect(envelope.v).toBe(1);
104
+ expect(envelope.c).toBe(sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD);
105
+ expect(envelope.n).toBe(3);
106
+ expect(typeof envelope.p).toBe('string');
107
+ });
108
+ it('tracks compression metrics', async () => {
109
+ const items = Array.from({ length: 100 }, (_, i) => makeTestEvent(`event-${i}`, `name-${i}`, i * 100));
110
+ const result = await bundledClient.sendBundled('test-message', items);
111
+ expect(result.metrics.originalSizeBytes).toBeGreaterThan(0);
112
+ expect(result.metrics.finalSizeBytes).toBeGreaterThan(0);
113
+ expect(result.metrics.compressionRatio).toBeGreaterThan(1);
114
+ expect(result.metrics.compressionTimeMs).toBeGreaterThanOrEqual(0);
115
+ });
116
+ it('sends items without compression when NONE specified', async () => {
117
+ const noCompressionClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
118
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.NONE,
119
+ });
120
+ const items = [makeTestEvent('1')];
121
+ await noCompressionClient.sendBundled('test-message', items);
122
+ const sentEnvelopes = mockSqsClient.buildAndSendMessagesV2.mock
123
+ .calls[0][1];
124
+ const envelope = sentEnvelopes[0];
125
+ expect(envelope.c).toBe(sqs_bundled_client_types_1.CompressionAlgorithm.NONE);
126
+ expect(Array.isArray(envelope.p)).toBe(true);
127
+ });
128
+ it('respects maxItemsPerBundle config', async () => {
129
+ const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
130
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
131
+ maxItemsPerBundle: 10,
132
+ });
133
+ const items = Array.from({ length: 25 }, (_, i) => makeTestEvent(`${i}`));
134
+ mockSqsClient.buildAndSendMessagesV2.mockResolvedValue({
135
+ successCount: 3,
136
+ failedCount: 0,
137
+ batchCount: 1,
138
+ failedMessages: [],
139
+ });
140
+ const result = await client.sendBundled('test-message', items);
141
+ expect(result.totalItems).toBe(25);
142
+ expect(result.bundleCount).toBeGreaterThanOrEqual(2);
143
+ const sentEnvelopes = mockSqsClient.buildAndSendMessagesV2.mock
144
+ .calls[0][1];
145
+ for (const envelope of sentEnvelopes) {
146
+ expect(envelope.n).toBeLessThanOrEqual(10);
147
+ }
148
+ });
149
+ it('calculates billable requests based on size', async () => {
150
+ const items = Array.from({ length: 50 }, (_, i) => makeTestEvent(`${i}`, 'name', i * 10));
151
+ const result = await bundledClient.sendBundled('test-message', items);
152
+ expect(result.billableRequests).toBeGreaterThanOrEqual(1);
153
+ });
154
+ });
155
+ describe('retry behavior', () => {
156
+ it('retries failed messages', async () => {
157
+ mockSqsClient.buildAndSendMessagesV2
158
+ .mockResolvedValueOnce({
159
+ successCount: 0,
160
+ failedCount: 1,
161
+ batchCount: 1,
162
+ failedMessages: [{ v: 1, c: 'zstd', n: 1, p: 'test' }],
163
+ })
164
+ .mockResolvedValueOnce({
165
+ successCount: 1,
166
+ failedCount: 0,
167
+ batchCount: 1,
168
+ failedMessages: [],
169
+ });
170
+ const items = [makeTestEvent('1')];
171
+ const result = await bundledClient.sendBundled('test-message', items);
172
+ expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledTimes(2);
173
+ expect(result.failedBundles).toBe(0);
174
+ });
175
+ it('stops retrying after max retries', async () => {
176
+ mockSqsClient.buildAndSendMessagesV2.mockResolvedValue({
177
+ successCount: 0,
178
+ failedCount: 1,
179
+ batchCount: 1,
180
+ failedMessages: [{ v: 1, c: 'zstd', n: 1, p: 'test' }],
181
+ });
182
+ const items = [makeTestEvent('1')];
183
+ const result = await bundledClient.sendBundled('test-message', items);
184
+ expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalledTimes(3);
185
+ expect(result.failedBundles).toBeGreaterThan(0);
186
+ });
187
+ });
188
+ describe('auto-resize', () => {
189
+ it('is enabled by default', () => {
190
+ const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient);
191
+ expect(client.config.autoResize).toBe(true);
192
+ });
193
+ it('can be configured to be disabled', () => {
194
+ const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
195
+ autoResize: false,
196
+ });
197
+ expect(client.config.autoResize).toBe(false);
198
+ });
199
+ });
200
+ describe('skippedItems behavior', () => {
201
+ afterEach(() => {
202
+ mockSizeInBytes.mockImplementation(actualSizeModule.sizeInBytes);
203
+ });
204
+ it('reports skippedItems as 0 when all items sent successfully', async () => {
205
+ const items = [makeTestEvent('1'), makeTestEvent('2')];
206
+ const result = await bundledClient.sendBundled('test-message', items);
207
+ expect(result.skippedItems).toBe(0);
208
+ expect(result.totalItems).toBe(2);
209
+ expect(result.failedBundles).toBe(0);
210
+ });
211
+ it('tracks skippedItems when autoResize disabled and bundle exceeds limit', async () => {
212
+ const noResizeClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
213
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
214
+ autoResize: false,
215
+ });
216
+ const items = [makeTestEvent('1'), makeTestEvent('2'), makeTestEvent('3')];
217
+ mockSizeInBytes.mockImplementation((obj) => {
218
+ if (typeof obj === 'object' && obj !== null && 'v' in obj) {
219
+ return 2_000_000;
220
+ }
221
+ return 100;
222
+ });
223
+ const result = await noResizeClient.sendBundled('test-message', items);
224
+ expect(result.skippedItems).toBe(3);
225
+ expect(result.totalItems).toBe(3);
226
+ expect(mockSqsClient.buildAndSendMessagesV2).not.toHaveBeenCalled();
227
+ });
228
+ it('tracks skippedItems when single item cannot fit (splitAndRetry terminates)', async () => {
229
+ const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
230
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
231
+ autoResize: true,
232
+ });
233
+ const items = [makeTestEvent('oversized-item')];
234
+ mockSizeInBytes.mockImplementation((obj) => {
235
+ if (typeof obj === 'object' && obj !== null && 'v' in obj) {
236
+ return 2_000_000;
237
+ }
238
+ return 100;
239
+ });
240
+ const result = await client.sendBundled('test-message', items);
241
+ expect(result.skippedItems).toBe(1);
242
+ expect(result.totalItems).toBe(1);
243
+ });
244
+ it('reports partial skippedItems when some items are too large', async () => {
245
+ const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
246
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
247
+ autoResize: true,
248
+ maxItemsPerBundle: 1,
249
+ });
250
+ const items = [makeTestEvent('small-1'), makeTestEvent('oversized'), makeTestEvent('small-2')];
251
+ let envelopeValidationCount = 0;
252
+ mockSizeInBytes.mockImplementation((obj) => {
253
+ if (typeof obj === 'object' && obj !== null && 'v' in obj) {
254
+ envelopeValidationCount++;
255
+ if (envelopeValidationCount === 2) {
256
+ return 2_000_000;
257
+ }
258
+ return 500;
259
+ }
260
+ return 100;
261
+ });
262
+ const result = await client.sendBundled('test-message', items);
263
+ expect(result.skippedItems).toBe(1);
264
+ expect(result.totalItems).toBe(3);
265
+ expect(mockSqsClient.buildAndSendMessagesV2).toHaveBeenCalled();
266
+ });
267
+ it('emptyResult returns skippedItems as 0', async () => {
268
+ const result = await bundledClient.sendBundled('test-message', []);
269
+ expect(result.skippedItems).toBe(0);
270
+ expect(result.totalItems).toBe(0);
271
+ });
272
+ });
273
+ describe('integration: end-to-end bundle flow', () => {
274
+ it('produces envelopes that unbundleRecords can process', async () => {
275
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
276
+ const items = [
277
+ makeTestEvent('event-1', 'purchase', 99.99),
278
+ makeTestEvent('event-2', 'add_to_cart', 29.99),
279
+ makeTestEvent('event-3', 'page_view'),
280
+ ];
281
+ let capturedEnvelope = null;
282
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_type, envelopes) => {
283
+ capturedEnvelope = envelopes[0];
284
+ return {
285
+ successCount: envelopes.length,
286
+ failedCount: 0,
287
+ batchCount: 1,
288
+ failedMessages: [],
289
+ };
290
+ });
291
+ await bundledClient.sendBundled('test-message', items);
292
+ expect(capturedEnvelope).not.toBeNull();
293
+ const sqsRecord = {
294
+ messageId: 'msg-1',
295
+ body: JSON.stringify({ messageBody: capturedEnvelope }),
296
+ };
297
+ const { items: unbundledItems, stats } = await unbundleRecords([sqsRecord]);
298
+ expect(unbundledItems).toHaveLength(3);
299
+ expect(unbundledItems[0]).toEqual({ id: 'event-1', name: 'purchase', value: 99.99 });
300
+ expect(unbundledItems[1]).toEqual({ id: 'event-2', name: 'add_to_cart', value: 29.99 });
301
+ expect(unbundledItems[2]).toEqual({ id: 'event-3', name: 'page_view' });
302
+ expect(stats.bundledSqsRecords).toBe(1);
303
+ });
304
+ it('maintains compatibility with large bundles', async () => {
305
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
306
+ const items = Array.from({ length: 200 }, (_, i) => makeTestEvent(`event-${i}`, `type-${i % 5}`, i * 1.5));
307
+ let capturedEnvelopes = [];
308
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_type, envelopes) => {
309
+ capturedEnvelopes = envelopes;
310
+ return {
311
+ successCount: envelopes.length,
312
+ failedCount: 0,
313
+ batchCount: 1,
314
+ failedMessages: [],
315
+ };
316
+ });
317
+ await bundledClient.sendBundled('test-message', items);
318
+ const sqsRecords = capturedEnvelopes.map((env, i) => ({
319
+ messageId: `msg-${i}`,
320
+ body: JSON.stringify({ messageBody: env }),
321
+ }));
322
+ const { items: unbundledItems } = await unbundleRecords(sqsRecords);
323
+ expect(unbundledItems).toHaveLength(200);
324
+ expect(unbundledItems[0].id).toBe('event-0');
325
+ expect(unbundledItems[199].id).toBe('event-199');
326
+ });
327
+ });
328
+ describe('producer edge cases - real sequences', () => {
329
+ it('handles 1000 items with real bundling and verifies envelope structure', async () => {
330
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
331
+ const items = Array.from({ length: 1000 }, (_, i) => ({
332
+ id: `item-${i}`,
333
+ name: `payload-${i}`,
334
+ value: i * 10,
335
+ data: `extra-data-${i}`,
336
+ }));
337
+ const capturedEnvelopes = [];
338
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
339
+ capturedEnvelopes.push(...envelopes);
340
+ return {
341
+ successCount: envelopes.length,
342
+ failedCount: 0,
343
+ batchCount: 1,
344
+ failedMessages: [],
345
+ };
346
+ });
347
+ const result = await bundledClient.sendBundled('test', items);
348
+ expect(result.totalItems).toBe(1000);
349
+ expect(capturedEnvelopes.length).toBeGreaterThan(0);
350
+ let totalItemsInEnvelopes = 0;
351
+ for (const env of capturedEnvelopes) {
352
+ expect(env.v).toBe(1);
353
+ expect(env.c).toBe(sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD);
354
+ expect(typeof env.p).toBe('string');
355
+ expect(typeof env.n).toBe('number');
356
+ expect(env.n).toBeGreaterThan(0);
357
+ totalItemsInEnvelopes += env.n;
358
+ }
359
+ expect(totalItemsInEnvelopes).toBe(1000);
360
+ const sqsRecords = capturedEnvelopes.map((env, i) => ({
361
+ messageId: `msg-${i}`,
362
+ body: JSON.stringify({ messageBody: env }),
363
+ }));
364
+ const { items: unbundledItems } = await unbundleRecords(sqsRecords);
365
+ expect(unbundledItems).toHaveLength(1000);
366
+ expect(unbundledItems[0]).toEqual({ id: 'item-0', name: 'payload-0', value: 0, data: 'extra-data-0' });
367
+ expect(unbundledItems[999]).toEqual({ id: 'item-999', name: 'payload-999', value: 9990, data: 'extra-data-999' });
368
+ });
369
+ it('achieves compression effectiveness with repetitive data', async () => {
370
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
371
+ const repetitiveText = 'AAAAAAAAAA'.repeat(100);
372
+ const items = Array.from({ length: 100 }, (_, i) => ({
373
+ id: `item-${i}`,
374
+ name: 'repetitive-test',
375
+ value: i,
376
+ data: repetitiveText,
377
+ }));
378
+ const capturedEnvelopes = [];
379
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
380
+ capturedEnvelopes.push(envelopes[0]);
381
+ return {
382
+ successCount: envelopes.length,
383
+ failedCount: 0,
384
+ batchCount: 1,
385
+ failedMessages: [],
386
+ };
387
+ });
388
+ const result = await bundledClient.sendBundled('test', items);
389
+ expect(result.metrics.compressionRatio).toBeGreaterThan(1);
390
+ expect(result.metrics.finalSizeBytes).toBeLessThan(result.metrics.originalSizeBytes);
391
+ expect(result.metrics.compressionRatio).toBeGreaterThan(5);
392
+ expect(capturedEnvelopes).toHaveLength(1);
393
+ const envelope = capturedEnvelopes[0];
394
+ expect(typeof envelope.p).toBe('string');
395
+ const { items: unbundledItems } = await unbundleRecords([
396
+ {
397
+ messageId: 'msg-1',
398
+ body: JSON.stringify({ messageBody: envelope }),
399
+ },
400
+ ]);
401
+ expect(unbundledItems).toHaveLength(100);
402
+ expect(unbundledItems[0].data).toBe(repetitiveText);
403
+ expect(unbundledItems[99].data).toBe(repetitiveText);
404
+ });
405
+ it('handles various item sizes correctly', async () => {
406
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
407
+ const tinyItems = Array.from({ length: 10 }, (_, i) => ({
408
+ id: `tiny-${i}`,
409
+ name: 't',
410
+ }));
411
+ const smallItems = Array.from({ length: 10 }, (_, i) => ({
412
+ id: `small-${i}`,
413
+ name: 'small-item',
414
+ value: i,
415
+ data: 'x'.repeat(100),
416
+ }));
417
+ const mediumItems = Array.from({ length: 10 }, (_, i) => ({
418
+ id: `medium-${i}`,
419
+ name: 'medium-item',
420
+ value: i,
421
+ data: 'y'.repeat(10_000),
422
+ }));
423
+ const largerItems = Array.from({ length: 5 }, (_, i) => ({
424
+ id: `larger-${i}`,
425
+ name: 'larger-item',
426
+ value: i,
427
+ data: 'z'.repeat(100_000),
428
+ }));
429
+ const allItems = [...tinyItems, ...smallItems, ...mediumItems, ...largerItems];
430
+ const totalExpectedItems = allItems.length;
431
+ const capturedEnvelopes = [];
432
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
433
+ capturedEnvelopes.push(...envelopes);
434
+ return {
435
+ successCount: envelopes.length,
436
+ failedCount: 0,
437
+ batchCount: 1,
438
+ failedMessages: [],
439
+ };
440
+ });
441
+ const result = await bundledClient.sendBundled('test', allItems);
442
+ expect(result.totalItems).toBe(totalExpectedItems);
443
+ expect(result.skippedItems).toBe(0);
444
+ const totalInEnvelopes = capturedEnvelopes.reduce((sum, env) => sum + env.n, 0);
445
+ expect(totalInEnvelopes).toBe(totalExpectedItems);
446
+ const sqsRecords = capturedEnvelopes.map((env, i) => ({
447
+ messageId: `msg-${i}`,
448
+ body: JSON.stringify({ messageBody: env }),
449
+ }));
450
+ const { items: unbundledItems } = await unbundleRecords(sqsRecords);
451
+ expect(unbundledItems).toHaveLength(totalExpectedItems);
452
+ const unbundledTiny = unbundledItems.filter((item) => item.id.startsWith('tiny-'));
453
+ const unbundledSmall = unbundledItems.filter((item) => item.id.startsWith('small-'));
454
+ const unbundledMedium = unbundledItems.filter((item) => item.id.startsWith('medium-'));
455
+ const unbundledLarger = unbundledItems.filter((item) => item.id.startsWith('larger-'));
456
+ expect(unbundledTiny).toHaveLength(10);
457
+ expect(unbundledSmall).toHaveLength(10);
458
+ expect(unbundledMedium).toHaveLength(10);
459
+ expect(unbundledLarger).toHaveLength(5);
460
+ expect(unbundledSmall[0].data).toBe('x'.repeat(100));
461
+ expect(unbundledMedium[0].data).toBe('y'.repeat(10_000));
462
+ expect(unbundledLarger[0].data).toBe('z'.repeat(100_000));
463
+ });
464
+ it('preserves unicode and special characters through compression', async () => {
465
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
466
+ const unicodeItems = [
467
+ {
468
+ id: 'emoji',
469
+ name: '🎉🚀💯🔥✨',
470
+ data: 'Celebration 🎊 with many emojis 🌟⭐💫',
471
+ },
472
+ {
473
+ id: 'chinese',
474
+ name: '你好世界',
475
+ data: '这是一个测试消息,包含中文字符。北京、上海、广州。',
476
+ },
477
+ {
478
+ id: 'arabic',
479
+ name: 'مرحبا بالعالم',
480
+ data: 'هذه رسالة اختبار باللغة العربية',
481
+ },
482
+ {
483
+ id: 'japanese',
484
+ name: 'こんにちは世界',
485
+ data: 'テスト メッセージです。東京、大阪、京都。',
486
+ },
487
+ {
488
+ id: 'korean',
489
+ name: '안녕하세요 세계',
490
+ data: '테스트 메시지입니다. 서울, 부산, 인천.',
491
+ },
492
+ {
493
+ id: 'special-symbols',
494
+ name: '†‡§¶•‰™©®',
495
+ data: 'Special: «»‹› ′″ ∞∑∏√∫ ≤≥≠≈ αβγδε',
496
+ },
497
+ {
498
+ id: 'mixed-unicode',
499
+ name: 'Mixed: Ñ ü ö ä ß',
500
+ data: 'Ümlauts: äöüÄÖÜß dashes—and–more Ç ñ ¡¿',
501
+ },
502
+ {
503
+ id: 'mathematical',
504
+ name: '∀x∈ℝ: x² ≥ 0',
505
+ data: 'Math: ∫₀^∞ e^(-x²) dx = √π/2, ∑_{n=1}^{∞} 1/n² = π²/6',
506
+ },
507
+ {
508
+ id: 'currency',
509
+ name: '€£¥₹₽¢',
510
+ data: 'Prices: $100, €85, £70, ¥10000, ₹8000, ₽7500',
511
+ },
512
+ {
513
+ id: 'newlines-tabs',
514
+ name: 'control\tchars',
515
+ data: 'Line 1\nLine 2\rLine 3\r\nLine 4\tTabbed',
516
+ },
517
+ ];
518
+ let capturedEnvelope = null;
519
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
520
+ capturedEnvelope = envelopes[0];
521
+ return {
522
+ successCount: envelopes.length,
523
+ failedCount: 0,
524
+ batchCount: 1,
525
+ failedMessages: [],
526
+ };
527
+ });
528
+ const result = await bundledClient.sendBundled('test', unicodeItems);
529
+ expect(result.totalItems).toBe(unicodeItems.length);
530
+ expect(result.skippedItems).toBe(0);
531
+ expect(capturedEnvelope).not.toBeNull();
532
+ const { items: unbundledItems } = await unbundleRecords([
533
+ {
534
+ messageId: 'msg-1',
535
+ body: JSON.stringify({ messageBody: capturedEnvelope }),
536
+ },
537
+ ]);
538
+ expect(unbundledItems).toHaveLength(unicodeItems.length);
539
+ for (let i = 0; i < unicodeItems.length; i++) {
540
+ expect(unbundledItems[i]).toEqual(unicodeItems[i]);
541
+ }
542
+ const emojiItem = unbundledItems.find((item) => item.id === 'emoji');
543
+ expect(emojiItem?.name).toBe('🎉🚀💯🔥✨');
544
+ const chineseItem = unbundledItems.find((item) => item.id === 'chinese');
545
+ expect(chineseItem?.name).toBe('你好世界');
546
+ const arabicItem = unbundledItems.find((item) => item.id === 'arabic');
547
+ expect(arabicItem?.name).toBe('مرحبا بالعالم');
548
+ });
549
+ it('preserves deeply nested object structures', async () => {
550
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
551
+ const nestedItems = [
552
+ {
553
+ id: 'deep-nested',
554
+ name: 'deep',
555
+ nested: {
556
+ level1: {
557
+ level2: {
558
+ level3: {
559
+ level4: {
560
+ level5: {
561
+ level6: {
562
+ value: 'deep-value',
563
+ number: 12345,
564
+ boolean: true,
565
+ },
566
+ },
567
+ },
568
+ },
569
+ },
570
+ },
571
+ },
572
+ },
573
+ {
574
+ id: 'array-of-objects',
575
+ name: 'arrays',
576
+ items: [
577
+ { subId: 'sub-1', data: { nested: { value: 'a' } } },
578
+ { subId: 'sub-2', data: { nested: { value: 'b' } } },
579
+ { subId: 'sub-3', data: { nested: { value: 'c' } } },
580
+ ],
581
+ },
582
+ {
583
+ id: 'mixed-structures',
584
+ name: 'mixed',
585
+ config: {
586
+ settings: {
587
+ features: ['feature-1', 'feature-2', 'feature-3'],
588
+ metadata: {
589
+ tags: {
590
+ primary: ['tag-a', 'tag-b'],
591
+ secondary: {
592
+ group1: ['tag-c', 'tag-d'],
593
+ group2: ['tag-e', 'tag-f'],
594
+ },
595
+ },
596
+ },
597
+ },
598
+ },
599
+ },
600
+ {
601
+ id: 'null-undefined-handling',
602
+ name: 'nulls',
603
+ value: null,
604
+ nested: {
605
+ nullField: null,
606
+ emptyObject: {},
607
+ emptyArray: [],
608
+ zeroValue: 0,
609
+ falseValue: false,
610
+ emptyString: '',
611
+ },
612
+ },
613
+ {
614
+ id: 'large-array',
615
+ name: 'large-array',
616
+ items: Array.from({ length: 100 }, (_, i) => ({
617
+ index: i,
618
+ data: `item-${i}`,
619
+ nested: { level: 1, value: i * 2 },
620
+ })),
621
+ },
622
+ ];
623
+ let capturedEnvelope = null;
624
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
625
+ capturedEnvelope = envelopes[0];
626
+ return {
627
+ successCount: envelopes.length,
628
+ failedCount: 0,
629
+ batchCount: 1,
630
+ failedMessages: [],
631
+ };
632
+ });
633
+ const genericClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
634
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
635
+ });
636
+ const result = await genericClient.sendBundled('test', nestedItems);
637
+ expect(result.totalItems).toBe(nestedItems.length);
638
+ expect(result.skippedItems).toBe(0);
639
+ const { items: unbundledItems } = await unbundleRecords([
640
+ {
641
+ messageId: 'msg-1',
642
+ body: JSON.stringify({ messageBody: capturedEnvelope }),
643
+ },
644
+ ]);
645
+ expect(unbundledItems).toHaveLength(nestedItems.length);
646
+ const deepItem = unbundledItems.find((item) => item.id === 'deep-nested');
647
+ expect(deepItem?.nested?.level1?.level2?.level3?.level4?.level5?.level6?.value).toBe('deep-value');
648
+ expect(deepItem?.nested?.level1?.level2?.level3?.level4?.level5?.level6?.number).toBe(12345);
649
+ expect(deepItem?.nested?.level1?.level2?.level3?.level4?.level5?.level6?.boolean).toBe(true);
650
+ const arrayItem = unbundledItems.find((item) => item.id === 'array-of-objects');
651
+ expect(arrayItem?.items?.length).toBe(3);
652
+ expect(arrayItem?.items?.[0]?.data?.nested?.value).toBe('a');
653
+ expect(arrayItem?.items?.[2]?.data?.nested?.value).toBe('c');
654
+ const mixedItem = unbundledItems.find((item) => item.id === 'mixed-structures');
655
+ expect(mixedItem?.config?.settings?.features).toEqual(['feature-1', 'feature-2', 'feature-3']);
656
+ expect(mixedItem?.config?.settings?.metadata?.tags?.secondary?.group2).toEqual(['tag-e', 'tag-f']);
657
+ const nullItem = unbundledItems.find((item) => item.id === 'null-undefined-handling');
658
+ expect(nullItem?.value).toBeNull();
659
+ expect(nullItem?.nested?.nullField).toBeNull();
660
+ expect(nullItem?.nested?.emptyObject).toEqual({});
661
+ expect(nullItem?.nested?.emptyArray).toEqual([]);
662
+ expect(nullItem?.nested?.zeroValue).toBe(0);
663
+ expect(nullItem?.nested?.falseValue).toBe(false);
664
+ expect(nullItem?.nested?.emptyString).toBe('');
665
+ const largeArrayItem = unbundledItems.find((item) => item.id === 'large-array');
666
+ expect(largeArrayItem?.items).toHaveLength(100);
667
+ expect(largeArrayItem?.items?.[0]).toEqual({ index: 0, data: 'item-0', nested: { level: 1, value: 0 } });
668
+ expect(largeArrayItem?.items?.[99]).toEqual({ index: 99, data: 'item-99', nested: { level: 1, value: 198 } });
669
+ });
670
+ it('handles exactly 1 item', async () => {
671
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
672
+ const items = [{ id: 'single', name: 'only-one', value: 42 }];
673
+ const capturedEnvelopes = [];
674
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
675
+ capturedEnvelopes.push(envelopes[0]);
676
+ return {
677
+ successCount: envelopes.length,
678
+ failedCount: 0,
679
+ batchCount: 1,
680
+ failedMessages: [],
681
+ };
682
+ });
683
+ const result = await bundledClient.sendBundled('test', items);
684
+ expect(result.totalItems).toBe(1);
685
+ expect(result.bundleCount).toBe(1);
686
+ expect(result.messageCount).toBe(1);
687
+ expect(capturedEnvelopes).toHaveLength(1);
688
+ expect(capturedEnvelopes[0].n).toBe(1);
689
+ const { items: unbundledItems } = await unbundleRecords([
690
+ {
691
+ messageId: 'msg-1',
692
+ body: JSON.stringify({ messageBody: capturedEnvelopes[0] }),
693
+ },
694
+ ]);
695
+ expect(unbundledItems).toHaveLength(1);
696
+ expect(unbundledItems[0]).toEqual(items[0]);
697
+ });
698
+ it('handles exactly maxItemsPerBundle items', async () => {
699
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
700
+ const maxItems = 50;
701
+ const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
702
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
703
+ maxItemsPerBundle: maxItems,
704
+ });
705
+ const items = Array.from({ length: maxItems }, (_, i) => ({
706
+ id: `item-${i}`,
707
+ name: `name-${i}`,
708
+ value: i,
709
+ }));
710
+ const capturedEnvelopes = [];
711
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
712
+ capturedEnvelopes.push(...envelopes);
713
+ return {
714
+ successCount: envelopes.length,
715
+ failedCount: 0,
716
+ batchCount: 1,
717
+ failedMessages: [],
718
+ };
719
+ });
720
+ const result = await client.sendBundled('test', items);
721
+ expect(result.totalItems).toBe(maxItems);
722
+ expect(capturedEnvelopes).toHaveLength(1);
723
+ expect(capturedEnvelopes[0].n).toBe(maxItems);
724
+ const sqsRecords = capturedEnvelopes.map((env, i) => ({
725
+ messageId: `msg-${i}`,
726
+ body: JSON.stringify({ messageBody: env }),
727
+ }));
728
+ const { items: unbundledItems } = await unbundleRecords(sqsRecords);
729
+ expect(unbundledItems).toHaveLength(maxItems);
730
+ });
731
+ it('handles maxItemsPerBundle + 1 items (splits correctly)', async () => {
732
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
733
+ const maxItems = 50;
734
+ const client = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
735
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
736
+ maxItemsPerBundle: maxItems,
737
+ });
738
+ const items = Array.from({ length: maxItems + 1 }, (_, i) => ({
739
+ id: `item-${i}`,
740
+ name: `name-${i}`,
741
+ value: i,
742
+ }));
743
+ const capturedEnvelopes = [];
744
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
745
+ capturedEnvelopes.push(...envelopes);
746
+ return {
747
+ successCount: envelopes.length,
748
+ failedCount: 0,
749
+ batchCount: 1,
750
+ failedMessages: [],
751
+ };
752
+ });
753
+ const result = await client.sendBundled('test', items);
754
+ expect(result.totalItems).toBe(maxItems + 1);
755
+ expect(capturedEnvelopes).toHaveLength(2);
756
+ expect(capturedEnvelopes[0].n).toBe(maxItems);
757
+ expect(capturedEnvelopes[1].n).toBe(1);
758
+ const sqsRecords = capturedEnvelopes.map((env, i) => ({
759
+ messageId: `msg-${i}`,
760
+ body: JSON.stringify({ messageBody: env }),
761
+ }));
762
+ const { items: unbundledItems } = await unbundleRecords(sqsRecords);
763
+ expect(unbundledItems).toHaveLength(maxItems + 1);
764
+ });
765
+ it('handles uncompressed mode (NONE) with various data', async () => {
766
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
767
+ const noCompressionClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
768
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.NONE,
769
+ });
770
+ const items = Array.from({ length: 50 }, (_, i) => ({
771
+ id: `uncompressed-${i}`,
772
+ name: `test-${i}`,
773
+ value: i * 100,
774
+ data: `Some data for item ${i}`,
775
+ }));
776
+ const capturedEnvelopes = [];
777
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
778
+ capturedEnvelopes.push(envelopes[0]);
779
+ return {
780
+ successCount: envelopes.length,
781
+ failedCount: 0,
782
+ batchCount: 1,
783
+ failedMessages: [],
784
+ };
785
+ });
786
+ const result = await noCompressionClient.sendBundled('test', items);
787
+ expect(result.totalItems).toBe(50);
788
+ expect(capturedEnvelopes).toHaveLength(1);
789
+ const envelope = capturedEnvelopes[0];
790
+ expect(envelope.c).toBe(sqs_bundled_client_types_1.CompressionAlgorithm.NONE);
791
+ expect(Array.isArray(envelope.p)).toBe(true);
792
+ expect(envelope.p.length).toBe(50);
793
+ expect(result.metrics.compressionRatio).toBeCloseTo(1, 0);
794
+ const { items: unbundledItems } = await unbundleRecords([
795
+ {
796
+ messageId: 'msg-1',
797
+ body: JSON.stringify({ messageBody: envelope }),
798
+ },
799
+ ]);
800
+ expect(unbundledItems).toHaveLength(50);
801
+ expect(unbundledItems[0]).toEqual(items[0]);
802
+ expect(unbundledItems[49]).toEqual(items[49]);
803
+ });
804
+ it('produces correct metrics for a large mixed batch', async () => {
805
+ const items = Array.from({ length: 500 }, (_, i) => ({
806
+ id: `metric-test-${i}`,
807
+ name: `item-${i % 10}`,
808
+ value: i,
809
+ data: i % 5 === 0 ? 'repeated-data'.repeat(100) : `unique-${i}`,
810
+ }));
811
+ const capturedEnvelopes = [];
812
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
813
+ capturedEnvelopes.push(...envelopes);
814
+ return {
815
+ successCount: envelopes.length,
816
+ failedCount: 0,
817
+ batchCount: 1,
818
+ failedMessages: [],
819
+ };
820
+ });
821
+ const result = await bundledClient.sendBundled('test', items);
822
+ expect(result.totalItems).toBe(500);
823
+ expect(result.metrics.originalSizeBytes).toBeGreaterThan(0);
824
+ expect(result.metrics.finalSizeBytes).toBeGreaterThan(0);
825
+ expect(result.metrics.compressionRatio).toBeGreaterThan(1);
826
+ expect(result.metrics.compressionTimeMs).toBeGreaterThanOrEqual(0);
827
+ expect(result.metrics.avgItemsPerBundle).toBeGreaterThan(0);
828
+ const expectedAvg = items.length / capturedEnvelopes.length;
829
+ expect(result.metrics.avgItemsPerBundle).toBeCloseTo(expectedAvg, 1);
830
+ expect(result.billableRequests).toBeGreaterThanOrEqual(1);
831
+ });
832
+ it('handles items with special JSON edge cases', async () => {
833
+ const { unbundleRecords } = await Promise.resolve().then(() => __importStar(require('../../clients/generic/sqs-unbundle')));
834
+ const edgeCaseItems = [
835
+ {
836
+ id: 'large-numbers',
837
+ name: 'numbers',
838
+ bigInt: 9007199254740991,
839
+ scientific: 1.23e10,
840
+ decimal: 0.1 + 0.2,
841
+ negative: -999999,
842
+ zero: 0,
843
+ negativeZero: -0,
844
+ },
845
+ {
846
+ id: 'special-strings',
847
+ name: 'strings',
848
+ data: JSON.stringify({ nested: 'json' }),
849
+ withQuotes: 'He said "hello"',
850
+ withBackslash: 'path\\to\\file',
851
+ withSlash: 'https://example.com/path',
852
+ },
853
+ {
854
+ id: 'boolean-variants',
855
+ name: 'booleans',
856
+ trueVal: true,
857
+ falseVal: false,
858
+ truthy: 1,
859
+ falsy: 0,
860
+ },
861
+ {
862
+ id: 'dates-as-strings',
863
+ name: 'dates',
864
+ isoDate: '2024-01-15T10:30:00.000Z',
865
+ timestamp: 1705315800000,
866
+ },
867
+ ];
868
+ let capturedEnvelope = null;
869
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
870
+ capturedEnvelope = envelopes[0];
871
+ return {
872
+ successCount: envelopes.length,
873
+ failedCount: 0,
874
+ batchCount: 1,
875
+ failedMessages: [],
876
+ };
877
+ });
878
+ const genericClient = new sqs_bundled_client_1.BundledSQSClient(mockSqsClient, {
879
+ compression: sqs_bundled_client_types_1.CompressionAlgorithm.ZSTD,
880
+ });
881
+ const result = await genericClient.sendBundled('test', edgeCaseItems);
882
+ expect(result.totalItems).toBe(edgeCaseItems.length);
883
+ expect(result.skippedItems).toBe(0);
884
+ const { items: unbundledItems } = await unbundleRecords([
885
+ {
886
+ messageId: 'msg-1',
887
+ body: JSON.stringify({ messageBody: capturedEnvelope }),
888
+ },
889
+ ]);
890
+ expect(unbundledItems).toHaveLength(edgeCaseItems.length);
891
+ const numbersItem = unbundledItems.find((item) => item.id === 'large-numbers');
892
+ expect(numbersItem?.bigInt).toBe(9007199254740991);
893
+ expect(numbersItem?.scientific).toBe(1.23e10);
894
+ expect(numbersItem?.negative).toBe(-999999);
895
+ expect(numbersItem?.zero).toBe(0);
896
+ const stringsItem = unbundledItems.find((item) => item.id === 'special-strings');
897
+ expect(stringsItem?.data).toBe(JSON.stringify({ nested: 'json' }));
898
+ expect(stringsItem?.withQuotes).toBe('He said "hello"');
899
+ expect(stringsItem?.withBackslash).toBe('path\\to\\file');
900
+ const booleansItem = unbundledItems.find((item) => item.id === 'boolean-variants');
901
+ expect(booleansItem?.trueVal).toBe(true);
902
+ expect(booleansItem?.falseVal).toBe(false);
903
+ });
904
+ it('handles concurrent sends without interference', async () => {
905
+ const batch1 = Array.from({ length: 100 }, (_, i) => ({
906
+ id: `batch1-${i}`,
907
+ name: 'batch-one',
908
+ value: i,
909
+ }));
910
+ const batch2 = Array.from({ length: 100 }, (_, i) => ({
911
+ id: `batch2-${i}`,
912
+ name: 'batch-two',
913
+ value: i * 2,
914
+ }));
915
+ const batch3 = Array.from({ length: 100 }, (_, i) => ({
916
+ id: `batch3-${i}`,
917
+ name: 'batch-three',
918
+ value: i * 3,
919
+ }));
920
+ mockSqsClient.buildAndSendMessagesV2.mockImplementation(async (_, envelopes) => {
921
+ return {
922
+ successCount: envelopes.length,
923
+ failedCount: 0,
924
+ batchCount: 1,
925
+ failedMessages: [],
926
+ };
927
+ });
928
+ const [result1, result2, result3] = await Promise.all([
929
+ bundledClient.sendBundled('test', batch1),
930
+ bundledClient.sendBundled('test', batch2),
931
+ bundledClient.sendBundled('test', batch3),
932
+ ]);
933
+ expect(result1.totalItems).toBe(100);
934
+ expect(result2.totalItems).toBe(100);
935
+ expect(result3.totalItems).toBe(100);
936
+ expect(result1.skippedItems).toBe(0);
937
+ expect(result2.skippedItems).toBe(0);
938
+ expect(result3.skippedItems).toBe(0);
939
+ });
940
+ });
941
+ });
932
942
  //# sourceMappingURL=sqs-bundled-client.spec.js.map