@adtrackify/at-service-common 3.17.8 → 3.18.1

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