@adtrackify/at-service-common 3.19.10 → 3.19.11

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 (407) hide show
  1. package/dist/cjs/__tests__/clients/acuity-client.spec.d.ts +1 -0
  2. package/dist/cjs/__tests__/clients/acuity-client.spec.js +44 -0
  3. package/dist/cjs/__tests__/clients/acuity-client.spec.js.map +1 -0
  4. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.d.ts +1 -0
  5. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.js +355 -0
  6. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.js.map +1 -0
  7. package/dist/cjs/__tests__/clients/dynamodb-client.spec.js +2 -7
  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 -0
  10. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.js +932 -0
  11. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.js.map +1 -0
  12. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -0
  13. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.js +564 -0
  14. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.js.map +1 -0
  15. package/dist/cjs/__tests__/clients/sqs-client.spec.js +72 -0
  16. package/dist/cjs/__tests__/clients/sqs-client.spec.js.map +1 -1
  17. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.d.ts +1 -0
  18. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.js +1358 -0
  19. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.js.map +1 -0
  20. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -0
  21. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.js +69 -0
  22. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.js.map +1 -0
  23. package/dist/cjs/__tests__/db/shared-read-db-services.spec.d.ts +1 -0
  24. package/dist/cjs/__tests__/db/shared-read-db-services.spec.js +90 -0
  25. package/dist/cjs/__tests__/db/shared-read-db-services.spec.js.map +1 -0
  26. package/dist/cjs/__tests__/helpers/acuity-helper.spec.d.ts +1 -0
  27. package/dist/cjs/__tests__/helpers/acuity-helper.spec.js +70 -0
  28. package/dist/cjs/__tests__/helpers/acuity-helper.spec.js.map +1 -0
  29. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -0
  30. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.js +83 -0
  31. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.js.map +1 -0
  32. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +6 -2
  33. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js.map +1 -1
  34. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -0
  35. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.js +585 -0
  36. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.js.map +1 -0
  37. package/dist/cjs/__tests__/libs/contacts.spec.d.ts +1 -0
  38. package/dist/cjs/__tests__/libs/contacts.spec.js +295 -0
  39. package/dist/cjs/__tests__/libs/contacts.spec.js.map +1 -0
  40. package/dist/cjs/__tests__/services/acuity-api-service.spec.d.ts +1 -0
  41. package/dist/cjs/__tests__/services/acuity-api-service.spec.js +72 -0
  42. package/dist/cjs/__tests__/services/acuity-api-service.spec.js.map +1 -0
  43. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -0
  44. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.js +94 -0
  45. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.js.map +1 -0
  46. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -0
  47. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.js +58 -0
  48. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.js.map +1 -0
  49. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -0
  50. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.js +182 -0
  51. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.js.map +1 -0
  52. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -0
  53. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.js +70 -0
  54. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.js.map +1 -0
  55. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -0
  56. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.js +140 -0
  57. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.js.map +1 -0
  58. package/dist/cjs/clients/generic/dynamodb-client.js +13 -12
  59. package/dist/cjs/clients/generic/dynamodb-client.js.map +1 -1
  60. package/dist/cjs/clients/generic/index.d.ts +3 -0
  61. package/dist/cjs/clients/generic/index.js +3 -0
  62. package/dist/cjs/clients/generic/index.js.map +1 -1
  63. package/dist/cjs/clients/generic/sqs-bundled-client.d.ts +15 -0
  64. package/dist/cjs/clients/generic/sqs-bundled-client.js +312 -0
  65. package/dist/cjs/clients/generic/sqs-bundled-client.js.map +1 -0
  66. package/dist/cjs/clients/generic/sqs-bundled-client.types.d.ts +53 -0
  67. package/dist/cjs/clients/generic/sqs-bundled-client.types.js +18 -0
  68. package/dist/cjs/clients/generic/sqs-bundled-client.types.js.map +1 -0
  69. package/dist/cjs/clients/generic/sqs-client.d.ts +21 -1
  70. package/dist/cjs/clients/generic/sqs-client.js +193 -19
  71. package/dist/cjs/clients/generic/sqs-client.js.map +1 -1
  72. package/dist/cjs/clients/generic/sqs-unbundle.d.ts +32 -0
  73. package/dist/cjs/clients/generic/sqs-unbundle.js +145 -0
  74. package/dist/cjs/clients/generic/sqs-unbundle.js.map +1 -0
  75. package/dist/cjs/clients/internal-api/shopify-app-install-client.d.ts +2 -2
  76. package/dist/cjs/clients/internal-api/shopify-app-install-client.js.map +1 -1
  77. package/dist/cjs/clients/third-party/acuity-client.d.ts +10 -0
  78. package/dist/cjs/clients/third-party/acuity-client.js +41 -0
  79. package/dist/cjs/clients/third-party/acuity-client.js.map +1 -0
  80. package/dist/cjs/clients/third-party/index.d.ts +1 -0
  81. package/dist/cjs/clients/third-party/index.js +1 -0
  82. package/dist/cjs/clients/third-party/index.js.map +1 -1
  83. package/dist/cjs/clients/third-party/shopify-client.d.ts +5 -5
  84. package/dist/cjs/clients/third-party/shopify-client.js.map +1 -1
  85. package/dist/cjs/constants/index.d.ts +1 -0
  86. package/dist/cjs/constants/index.js +18 -0
  87. package/dist/cjs/constants/index.js.map +1 -0
  88. package/dist/cjs/constants/sqs.d.ts +20 -0
  89. package/dist/cjs/constants/sqs.js +27 -0
  90. package/dist/cjs/constants/sqs.js.map +1 -0
  91. package/dist/cjs/helpers/acuity-helper.d.ts +4 -0
  92. package/dist/cjs/helpers/acuity-helper.js +57 -0
  93. package/dist/cjs/helpers/acuity-helper.js.map +1 -0
  94. package/dist/cjs/helpers/api-key-auth-helper.d.ts +9 -0
  95. package/dist/cjs/helpers/api-key-auth-helper.js +41 -0
  96. package/dist/cjs/helpers/api-key-auth-helper.js.map +1 -0
  97. package/dist/cjs/helpers/api-key-authorizer-helper.d.ts +36 -0
  98. package/dist/cjs/helpers/api-key-authorizer-helper.js +88 -0
  99. package/dist/cjs/helpers/api-key-authorizer-helper.js.map +1 -0
  100. package/dist/cjs/helpers/index.d.ts +3 -0
  101. package/dist/cjs/helpers/index.js +3 -0
  102. package/dist/cjs/helpers/index.js.map +1 -1
  103. package/dist/cjs/index.d.ts +2 -0
  104. package/dist/cjs/index.js +2 -0
  105. package/dist/cjs/index.js.map +1 -1
  106. package/dist/cjs/libs/api-router/index.d.ts +2 -0
  107. package/dist/cjs/libs/api-router/index.js +19 -0
  108. package/dist/cjs/libs/api-router/index.js.map +1 -0
  109. package/dist/cjs/libs/api-router/public-api-router.d.ts +3 -0
  110. package/dist/cjs/libs/api-router/public-api-router.js +37 -0
  111. package/dist/cjs/libs/api-router/public-api-router.js.map +1 -0
  112. package/dist/cjs/libs/api-router/route-matcher.d.ts +21 -0
  113. package/dist/cjs/libs/api-router/route-matcher.js +37 -0
  114. package/dist/cjs/libs/api-router/route-matcher.js.map +1 -0
  115. package/dist/cjs/libs/contacts.d.ts +7 -0
  116. package/dist/cjs/libs/contacts.js +153 -0
  117. package/dist/cjs/libs/contacts.js.map +1 -0
  118. package/dist/cjs/libs/emails.d.ts +2 -0
  119. package/dist/cjs/libs/emails.js +33 -1
  120. package/dist/cjs/libs/emails.js.map +1 -1
  121. package/dist/cjs/libs/index.d.ts +2 -0
  122. package/dist/cjs/libs/index.js +2 -0
  123. package/dist/cjs/libs/index.js.map +1 -1
  124. package/dist/cjs/services/acuity-api-service.d.ts +9 -0
  125. package/dist/cjs/services/acuity-api-service.js +74 -0
  126. package/dist/cjs/services/acuity-api-service.js.map +1 -0
  127. package/dist/cjs/services/db/accounts-db-service.d.ts +9 -0
  128. package/dist/cjs/services/db/accounts-db-service.js +34 -0
  129. package/dist/cjs/services/db/accounts-db-service.js.map +1 -0
  130. package/dist/cjs/services/db/api-keys-db-service.d.ts +10 -0
  131. package/dist/cjs/services/db/api-keys-db-service.js +37 -0
  132. package/dist/cjs/services/db/api-keys-db-service.js.map +1 -0
  133. package/dist/cjs/services/db/contact-enrichments-db-service.d.ts +15 -0
  134. package/dist/cjs/services/db/contact-enrichments-db-service.js +95 -0
  135. package/dist/cjs/services/db/contact-enrichments-db-service.js.map +1 -0
  136. package/dist/cjs/services/db/custom-measures-db-service.d.ts +14 -0
  137. package/dist/cjs/services/db/custom-measures-db-service.js +49 -0
  138. package/dist/cjs/services/db/custom-measures-db-service.js.map +1 -0
  139. package/dist/cjs/services/db/identity-cache-dynamodb-service.d.ts +2 -26
  140. package/dist/cjs/services/db/identity-cache-dynamodb-service.js +17 -39
  141. package/dist/cjs/services/db/identity-cache-dynamodb-service.js.map +1 -1
  142. package/dist/cjs/services/db/index.d.ts +6 -1
  143. package/dist/cjs/services/db/index.js +6 -1
  144. package/dist/cjs/services/db/index.js.map +1 -1
  145. package/dist/cjs/services/db/pixels-db-service.js +3 -3
  146. package/dist/cjs/services/db/pixels-db-service.js.map +1 -1
  147. package/dist/cjs/services/db/purchased-contacts/index.d.ts +2 -0
  148. package/dist/cjs/services/db/purchased-contacts/index.js +19 -0
  149. package/dist/cjs/services/db/purchased-contacts/index.js.map +1 -0
  150. package/dist/cjs/services/db/{purchased-contacts-db-service.d.ts → purchased-contacts/purchased-contacts-db-service.d.ts} +2 -1
  151. package/dist/cjs/services/db/{purchased-contacts-db-service.js → purchased-contacts/purchased-contacts-db-service.js} +13 -4
  152. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.js.map +1 -0
  153. package/dist/cjs/services/db/purchased-contacts/types.d.ts +11 -0
  154. package/dist/cjs/services/db/purchased-contacts/types.js +3 -0
  155. package/dist/cjs/services/db/purchased-contacts/types.js.map +1 -0
  156. package/dist/cjs/services/db/shopify-app-installs-db-service.d.ts +2 -1
  157. package/dist/cjs/services/db/shopify-app-installs-db-service.js +10 -6
  158. package/dist/cjs/services/db/shopify-app-installs-db-service.js.map +1 -1
  159. package/dist/cjs/services/db/subscriptions-db-service.d.ts +10 -0
  160. package/dist/cjs/services/db/subscriptions-db-service.js +35 -0
  161. package/dist/cjs/services/db/subscriptions-db-service.js.map +1 -0
  162. package/dist/cjs/services/email-verification/contact-email-verification-service.d.ts +7 -0
  163. package/dist/cjs/services/email-verification/contact-email-verification-service.js +102 -0
  164. package/dist/cjs/services/email-verification/contact-email-verification-service.js.map +1 -0
  165. package/dist/cjs/services/email-verification/email-verification-service.d.ts +19 -0
  166. package/dist/cjs/services/email-verification/email-verification-service.js +132 -0
  167. package/dist/cjs/services/email-verification/email-verification-service.js.map +1 -0
  168. package/dist/cjs/services/email-verification/index.d.ts +2 -0
  169. package/dist/cjs/services/email-verification/index.js +19 -0
  170. package/dist/cjs/services/email-verification/index.js.map +1 -0
  171. package/dist/cjs/services/events/log-event-service.d.ts +11 -1
  172. package/dist/cjs/services/events/log-event-service.js +27 -6
  173. package/dist/cjs/services/events/log-event-service.js.map +1 -1
  174. package/dist/cjs/services/index.d.ts +2 -0
  175. package/dist/cjs/services/index.js +2 -0
  176. package/dist/cjs/services/index.js.map +1 -1
  177. package/dist/cjs/types/acuity-types.d.ts +74 -0
  178. package/dist/cjs/types/acuity-types.js +3 -0
  179. package/dist/cjs/types/acuity-types.js.map +1 -0
  180. package/dist/cjs/types/index.d.ts +3 -0
  181. package/dist/cjs/types/index.js +16 -0
  182. package/dist/cjs/types/index.js.map +1 -1
  183. package/dist/cjs/types/shopify-graphql-types/admin.generated.d.ts +38 -38
  184. package/dist/cjs/types/shopify-graphql-types/admin.types.js.map +1 -1
  185. package/dist/cjs/types/shopify-rest-types.d.ts +767 -0
  186. package/dist/cjs/types/shopify-rest-types.js +3 -0
  187. package/dist/cjs/types/shopify-rest-types.js.map +1 -0
  188. package/dist/cjs/utils/compression.d.ts +36 -0
  189. package/dist/cjs/utils/compression.js +199 -0
  190. package/dist/cjs/utils/compression.js.map +1 -0
  191. package/dist/cjs/utils/custom-measure-formula-utils.d.ts +6 -0
  192. package/dist/cjs/utils/custom-measure-formula-utils.js +210 -0
  193. package/dist/cjs/utils/custom-measure-formula-utils.js.map +1 -0
  194. package/dist/cjs/utils/index.d.ts +4 -0
  195. package/dist/cjs/utils/index.js +21 -0
  196. package/dist/cjs/utils/index.js.map +1 -0
  197. package/dist/cjs/utils/retry-envelope.d.ts +12 -0
  198. package/dist/cjs/utils/retry-envelope.js +29 -0
  199. package/dist/cjs/utils/retry-envelope.js.map +1 -0
  200. package/dist/cjs/utils/size.d.ts +2 -0
  201. package/dist/cjs/utils/size.js +50 -0
  202. package/dist/cjs/utils/size.js.map +1 -0
  203. package/dist/esm/__tests__/clients/acuity-client.spec.d.ts +1 -0
  204. package/dist/esm/__tests__/clients/acuity-client.spec.js +42 -0
  205. package/dist/esm/__tests__/clients/acuity-client.spec.js.map +1 -0
  206. package/dist/esm/__tests__/clients/cross-platform-compression.spec.d.ts +1 -0
  207. package/dist/esm/__tests__/clients/cross-platform-compression.spec.js +330 -0
  208. package/dist/esm/__tests__/clients/cross-platform-compression.spec.js.map +1 -0
  209. package/dist/esm/__tests__/clients/dynamodb-client.spec.js +2 -7
  210. package/dist/esm/__tests__/clients/dynamodb-client.spec.js.map +1 -1
  211. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -0
  212. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.js +907 -0
  213. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.js.map +1 -0
  214. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -0
  215. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.js +539 -0
  216. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.js.map +1 -0
  217. package/dist/esm/__tests__/clients/sqs-client.spec.js +72 -0
  218. package/dist/esm/__tests__/clients/sqs-client.spec.js.map +1 -1
  219. package/dist/esm/__tests__/clients/sqs-unbundle.spec.d.ts +1 -0
  220. package/dist/esm/__tests__/clients/sqs-unbundle.spec.js +1356 -0
  221. package/dist/esm/__tests__/clients/sqs-unbundle.spec.js.map +1 -0
  222. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -0
  223. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.js +67 -0
  224. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.js.map +1 -0
  225. package/dist/esm/__tests__/db/shared-read-db-services.spec.d.ts +1 -0
  226. package/dist/esm/__tests__/db/shared-read-db-services.spec.js +88 -0
  227. package/dist/esm/__tests__/db/shared-read-db-services.spec.js.map +1 -0
  228. package/dist/esm/__tests__/helpers/acuity-helper.spec.d.ts +1 -0
  229. package/dist/esm/__tests__/helpers/acuity-helper.spec.js +68 -0
  230. package/dist/esm/__tests__/helpers/acuity-helper.spec.js.map +1 -0
  231. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -0
  232. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.js +81 -0
  233. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.js.map +1 -0
  234. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +7 -3
  235. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js.map +1 -1
  236. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -0
  237. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.js +583 -0
  238. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.js.map +1 -0
  239. package/dist/esm/__tests__/libs/contacts.spec.d.ts +1 -0
  240. package/dist/esm/__tests__/libs/contacts.spec.js +293 -0
  241. package/dist/esm/__tests__/libs/contacts.spec.js.map +1 -0
  242. package/dist/esm/__tests__/services/acuity-api-service.spec.d.ts +1 -0
  243. package/dist/esm/__tests__/services/acuity-api-service.spec.js +70 -0
  244. package/dist/esm/__tests__/services/acuity-api-service.spec.js.map +1 -0
  245. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -0
  246. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.js +92 -0
  247. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.js.map +1 -0
  248. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -0
  249. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.js +56 -0
  250. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.js.map +1 -0
  251. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -0
  252. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.js +157 -0
  253. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.js.map +1 -0
  254. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -0
  255. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.js +68 -0
  256. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.js.map +1 -0
  257. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -0
  258. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.js +138 -0
  259. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.js.map +1 -0
  260. package/dist/esm/clients/generic/dynamodb-client.js +2 -1
  261. package/dist/esm/clients/generic/dynamodb-client.js.map +1 -1
  262. package/dist/esm/clients/generic/index.d.ts +3 -0
  263. package/dist/esm/clients/generic/index.js +3 -0
  264. package/dist/esm/clients/generic/index.js.map +1 -1
  265. package/dist/esm/clients/generic/sqs-bundled-client.d.ts +15 -0
  266. package/dist/esm/clients/generic/sqs-bundled-client.js +308 -0
  267. package/dist/esm/clients/generic/sqs-bundled-client.js.map +1 -0
  268. package/dist/esm/clients/generic/sqs-bundled-client.types.d.ts +53 -0
  269. package/dist/esm/clients/generic/sqs-bundled-client.types.js +15 -0
  270. package/dist/esm/clients/generic/sqs-bundled-client.types.js.map +1 -0
  271. package/dist/esm/clients/generic/sqs-client.d.ts +21 -1
  272. package/dist/esm/clients/generic/sqs-client.js +193 -19
  273. package/dist/esm/clients/generic/sqs-client.js.map +1 -1
  274. package/dist/esm/clients/generic/sqs-unbundle.d.ts +32 -0
  275. package/dist/esm/clients/generic/sqs-unbundle.js +138 -0
  276. package/dist/esm/clients/generic/sqs-unbundle.js.map +1 -0
  277. package/dist/esm/clients/internal-api/shopify-app-install-client.d.ts +2 -2
  278. package/dist/esm/clients/internal-api/shopify-app-install-client.js.map +1 -1
  279. package/dist/esm/clients/third-party/acuity-client.d.ts +10 -0
  280. package/dist/esm/clients/third-party/acuity-client.js +37 -0
  281. package/dist/esm/clients/third-party/acuity-client.js.map +1 -0
  282. package/dist/esm/clients/third-party/index.d.ts +1 -0
  283. package/dist/esm/clients/third-party/index.js +1 -0
  284. package/dist/esm/clients/third-party/index.js.map +1 -1
  285. package/dist/esm/clients/third-party/shopify-client.d.ts +5 -5
  286. package/dist/esm/clients/third-party/shopify-client.js.map +1 -1
  287. package/dist/esm/constants/index.d.ts +1 -0
  288. package/dist/esm/constants/index.js +2 -0
  289. package/dist/esm/constants/index.js.map +1 -0
  290. package/dist/esm/constants/sqs.d.ts +20 -0
  291. package/dist/esm/constants/sqs.js +23 -0
  292. package/dist/esm/constants/sqs.js.map +1 -0
  293. package/dist/esm/helpers/acuity-helper.d.ts +4 -0
  294. package/dist/esm/helpers/acuity-helper.js +52 -0
  295. package/dist/esm/helpers/acuity-helper.js.map +1 -0
  296. package/dist/esm/helpers/api-key-auth-helper.d.ts +9 -0
  297. package/dist/esm/helpers/api-key-auth-helper.js +36 -0
  298. package/dist/esm/helpers/api-key-auth-helper.js.map +1 -0
  299. package/dist/esm/helpers/api-key-authorizer-helper.d.ts +36 -0
  300. package/dist/esm/helpers/api-key-authorizer-helper.js +84 -0
  301. package/dist/esm/helpers/api-key-authorizer-helper.js.map +1 -0
  302. package/dist/esm/helpers/index.d.ts +3 -0
  303. package/dist/esm/helpers/index.js +3 -0
  304. package/dist/esm/helpers/index.js.map +1 -1
  305. package/dist/esm/index.d.ts +2 -0
  306. package/dist/esm/index.js +2 -0
  307. package/dist/esm/index.js.map +1 -1
  308. package/dist/esm/libs/api-router/index.d.ts +2 -0
  309. package/dist/esm/libs/api-router/index.js +3 -0
  310. package/dist/esm/libs/api-router/index.js.map +1 -0
  311. package/dist/esm/libs/api-router/public-api-router.d.ts +3 -0
  312. package/dist/esm/libs/api-router/public-api-router.js +33 -0
  313. package/dist/esm/libs/api-router/public-api-router.js.map +1 -0
  314. package/dist/esm/libs/api-router/route-matcher.d.ts +21 -0
  315. package/dist/esm/libs/api-router/route-matcher.js +31 -0
  316. package/dist/esm/libs/api-router/route-matcher.js.map +1 -0
  317. package/dist/esm/libs/contacts.d.ts +7 -0
  318. package/dist/esm/libs/contacts.js +144 -0
  319. package/dist/esm/libs/contacts.js.map +1 -0
  320. package/dist/esm/libs/emails.d.ts +2 -0
  321. package/dist/esm/libs/emails.js +31 -0
  322. package/dist/esm/libs/emails.js.map +1 -1
  323. package/dist/esm/libs/index.d.ts +2 -0
  324. package/dist/esm/libs/index.js +2 -0
  325. package/dist/esm/libs/index.js.map +1 -1
  326. package/dist/esm/services/acuity-api-service.d.ts +9 -0
  327. package/dist/esm/services/acuity-api-service.js +70 -0
  328. package/dist/esm/services/acuity-api-service.js.map +1 -0
  329. package/dist/esm/services/db/accounts-db-service.d.ts +9 -0
  330. package/dist/esm/services/db/accounts-db-service.js +30 -0
  331. package/dist/esm/services/db/accounts-db-service.js.map +1 -0
  332. package/dist/esm/services/db/api-keys-db-service.d.ts +10 -0
  333. package/dist/esm/services/db/api-keys-db-service.js +33 -0
  334. package/dist/esm/services/db/api-keys-db-service.js.map +1 -0
  335. package/dist/esm/services/db/contact-enrichments-db-service.d.ts +15 -0
  336. package/dist/esm/services/db/contact-enrichments-db-service.js +91 -0
  337. package/dist/esm/services/db/contact-enrichments-db-service.js.map +1 -0
  338. package/dist/esm/services/db/custom-measures-db-service.d.ts +14 -0
  339. package/dist/esm/services/db/custom-measures-db-service.js +45 -0
  340. package/dist/esm/services/db/custom-measures-db-service.js.map +1 -0
  341. package/dist/esm/services/db/identity-cache-dynamodb-service.d.ts +2 -26
  342. package/dist/esm/services/db/identity-cache-dynamodb-service.js +1 -23
  343. package/dist/esm/services/db/identity-cache-dynamodb-service.js.map +1 -1
  344. package/dist/esm/services/db/index.d.ts +6 -1
  345. package/dist/esm/services/db/index.js +6 -1
  346. package/dist/esm/services/db/index.js.map +1 -1
  347. package/dist/esm/services/db/pixels-db-service.js +1 -1
  348. package/dist/esm/services/db/pixels-db-service.js.map +1 -1
  349. package/dist/esm/services/db/purchased-contacts/index.d.ts +2 -0
  350. package/dist/esm/services/db/purchased-contacts/index.js +3 -0
  351. package/dist/esm/services/db/purchased-contacts/index.js.map +1 -0
  352. package/dist/esm/services/db/{purchased-contacts-db-service.d.ts → purchased-contacts/purchased-contacts-db-service.d.ts} +2 -1
  353. package/dist/esm/services/db/{purchased-contacts-db-service.js → purchased-contacts/purchased-contacts-db-service.js} +13 -4
  354. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.js.map +1 -0
  355. package/dist/esm/services/db/purchased-contacts/types.d.ts +11 -0
  356. package/dist/esm/services/db/purchased-contacts/types.js +2 -0
  357. package/dist/esm/services/db/purchased-contacts/types.js.map +1 -0
  358. package/dist/esm/services/db/shopify-app-installs-db-service.d.ts +2 -1
  359. package/dist/esm/services/db/shopify-app-installs-db-service.js +6 -2
  360. package/dist/esm/services/db/shopify-app-installs-db-service.js.map +1 -1
  361. package/dist/esm/services/db/subscriptions-db-service.d.ts +10 -0
  362. package/dist/esm/services/db/subscriptions-db-service.js +31 -0
  363. package/dist/esm/services/db/subscriptions-db-service.js.map +1 -0
  364. package/dist/esm/services/email-verification/contact-email-verification-service.d.ts +7 -0
  365. package/dist/esm/services/email-verification/contact-email-verification-service.js +98 -0
  366. package/dist/esm/services/email-verification/contact-email-verification-service.js.map +1 -0
  367. package/dist/esm/services/email-verification/email-verification-service.d.ts +19 -0
  368. package/dist/esm/services/email-verification/email-verification-service.js +128 -0
  369. package/dist/esm/services/email-verification/email-verification-service.js.map +1 -0
  370. package/dist/esm/services/email-verification/index.d.ts +2 -0
  371. package/dist/esm/services/email-verification/index.js +3 -0
  372. package/dist/esm/services/email-verification/index.js.map +1 -0
  373. package/dist/esm/services/events/log-event-service.d.ts +11 -1
  374. package/dist/esm/services/events/log-event-service.js +25 -4
  375. package/dist/esm/services/events/log-event-service.js.map +1 -1
  376. package/dist/esm/services/index.d.ts +2 -0
  377. package/dist/esm/services/index.js +2 -0
  378. package/dist/esm/services/index.js.map +1 -1
  379. package/dist/esm/types/acuity-types.d.ts +74 -0
  380. package/dist/esm/types/acuity-types.js +2 -0
  381. package/dist/esm/types/acuity-types.js.map +1 -0
  382. package/dist/esm/types/index.d.ts +3 -0
  383. package/dist/esm/types/index.js +3 -0
  384. package/dist/esm/types/index.js.map +1 -1
  385. package/dist/esm/types/shopify-graphql-types/admin.generated.d.ts +38 -38
  386. package/dist/esm/types/shopify-graphql-types/admin.types.js.map +1 -1
  387. package/dist/esm/types/shopify-rest-types.d.ts +767 -0
  388. package/dist/esm/types/shopify-rest-types.js +2 -0
  389. package/dist/esm/types/shopify-rest-types.js.map +1 -0
  390. package/dist/esm/utils/compression.d.ts +36 -0
  391. package/dist/esm/utils/compression.js +188 -0
  392. package/dist/esm/utils/compression.js.map +1 -0
  393. package/dist/esm/utils/custom-measure-formula-utils.d.ts +6 -0
  394. package/dist/esm/utils/custom-measure-formula-utils.js +202 -0
  395. package/dist/esm/utils/custom-measure-formula-utils.js.map +1 -0
  396. package/dist/esm/utils/index.d.ts +4 -0
  397. package/dist/esm/utils/index.js +5 -0
  398. package/dist/esm/utils/index.js.map +1 -0
  399. package/dist/esm/utils/retry-envelope.d.ts +12 -0
  400. package/dist/esm/utils/retry-envelope.js +23 -0
  401. package/dist/esm/utils/retry-envelope.js.map +1 -0
  402. package/dist/esm/utils/size.d.ts +2 -0
  403. package/dist/esm/utils/size.js +45 -0
  404. package/dist/esm/utils/size.js.map +1 -0
  405. package/package.json +2 -4
  406. package/dist/cjs/services/db/purchased-contacts-db-service.js.map +0 -1
  407. package/dist/esm/services/db/purchased-contacts-db-service.js.map +0 -1
@@ -0,0 +1,932 @@
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
+ });
932
+ //# sourceMappingURL=sqs-bundled-client.spec.js.map