bupkis 0.18.1 → 0.18.2

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 (376) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/package.json +1 -4
  3. package/src/assertion/assertion-types.ts +4 -4
  4. package/src/assertion/impl/sync-parametric.ts +1 -1
  5. package/src/expect.ts +0 -4
  6. package/src/guards.ts +24 -24
  7. package/src/internal-schema.ts +16 -32
  8. package/src/value-to-schema.ts +1 -1
  9. package/dist/assertion/assertion-async.cjs +0 -268
  10. package/dist/assertion/assertion-async.cjs.map +0 -1
  11. package/dist/assertion/assertion-async.d.cts +0 -40
  12. package/dist/assertion/assertion-async.d.cts.map +0 -1
  13. package/dist/assertion/assertion-async.d.ts +0 -40
  14. package/dist/assertion/assertion-async.d.ts.map +0 -1
  15. package/dist/assertion/assertion-async.js +0 -259
  16. package/dist/assertion/assertion-async.js.map +0 -1
  17. package/dist/assertion/assertion-standard-schema-async.cjs +0 -132
  18. package/dist/assertion/assertion-standard-schema-async.cjs.map +0 -1
  19. package/dist/assertion/assertion-standard-schema-async.d.cts +0 -52
  20. package/dist/assertion/assertion-standard-schema-async.d.cts.map +0 -1
  21. package/dist/assertion/assertion-standard-schema-async.d.ts +0 -52
  22. package/dist/assertion/assertion-standard-schema-async.d.ts.map +0 -1
  23. package/dist/assertion/assertion-standard-schema-async.js +0 -128
  24. package/dist/assertion/assertion-standard-schema-async.js.map +0 -1
  25. package/dist/assertion/assertion-standard-schema-sync.cjs +0 -141
  26. package/dist/assertion/assertion-standard-schema-sync.cjs.map +0 -1
  27. package/dist/assertion/assertion-standard-schema-sync.d.cts +0 -52
  28. package/dist/assertion/assertion-standard-schema-sync.d.cts.map +0 -1
  29. package/dist/assertion/assertion-standard-schema-sync.d.ts +0 -52
  30. package/dist/assertion/assertion-standard-schema-sync.d.ts.map +0 -1
  31. package/dist/assertion/assertion-standard-schema-sync.js +0 -137
  32. package/dist/assertion/assertion-standard-schema-sync.js.map +0 -1
  33. package/dist/assertion/assertion-sync.cjs +0 -284
  34. package/dist/assertion/assertion-sync.cjs.map +0 -1
  35. package/dist/assertion/assertion-sync.d.cts +0 -60
  36. package/dist/assertion/assertion-sync.d.cts.map +0 -1
  37. package/dist/assertion/assertion-sync.d.ts +0 -60
  38. package/dist/assertion/assertion-sync.d.ts.map +0 -1
  39. package/dist/assertion/assertion-sync.js +0 -275
  40. package/dist/assertion/assertion-sync.js.map +0 -1
  41. package/dist/assertion/assertion-types.cjs +0 -20
  42. package/dist/assertion/assertion-types.cjs.map +0 -1
  43. package/dist/assertion/assertion-types.d.cts +0 -1086
  44. package/dist/assertion/assertion-types.d.cts.map +0 -1
  45. package/dist/assertion/assertion-types.d.ts +0 -1086
  46. package/dist/assertion/assertion-types.d.ts.map +0 -1
  47. package/dist/assertion/assertion-types.js +0 -19
  48. package/dist/assertion/assertion-types.js.map +0 -1
  49. package/dist/assertion/assertion.cjs +0 -382
  50. package/dist/assertion/assertion.cjs.map +0 -1
  51. package/dist/assertion/assertion.d.cts +0 -109
  52. package/dist/assertion/assertion.d.cts.map +0 -1
  53. package/dist/assertion/assertion.d.ts +0 -109
  54. package/dist/assertion/assertion.d.ts.map +0 -1
  55. package/dist/assertion/assertion.js +0 -375
  56. package/dist/assertion/assertion.js.map +0 -1
  57. package/dist/assertion/create.cjs +0 -148
  58. package/dist/assertion/create.cjs.map +0 -1
  59. package/dist/assertion/create.d.cts +0 -85
  60. package/dist/assertion/create.d.cts.map +0 -1
  61. package/dist/assertion/create.d.ts +0 -85
  62. package/dist/assertion/create.d.ts.map +0 -1
  63. package/dist/assertion/create.js +0 -143
  64. package/dist/assertion/create.js.map +0 -1
  65. package/dist/assertion/format-assertion-failure.cjs +0 -63
  66. package/dist/assertion/format-assertion-failure.cjs.map +0 -1
  67. package/dist/assertion/format-assertion-failure.d.cts +0 -21
  68. package/dist/assertion/format-assertion-failure.d.cts.map +0 -1
  69. package/dist/assertion/format-assertion-failure.d.ts +0 -21
  70. package/dist/assertion/format-assertion-failure.d.ts.map +0 -1
  71. package/dist/assertion/format-assertion-failure.js +0 -59
  72. package/dist/assertion/format-assertion-failure.js.map +0 -1
  73. package/dist/assertion/impl/assertion-util.cjs +0 -68
  74. package/dist/assertion/impl/assertion-util.cjs.map +0 -1
  75. package/dist/assertion/impl/assertion-util.d.cts +0 -36
  76. package/dist/assertion/impl/assertion-util.d.cts.map +0 -1
  77. package/dist/assertion/impl/assertion-util.d.ts +0 -36
  78. package/dist/assertion/impl/assertion-util.d.ts.map +0 -1
  79. package/dist/assertion/impl/assertion-util.js +0 -62
  80. package/dist/assertion/impl/assertion-util.js.map +0 -1
  81. package/dist/assertion/impl/async-iterable.cjs +0 -627
  82. package/dist/assertion/impl/async-iterable.cjs.map +0 -1
  83. package/dist/assertion/impl/async-iterable.d.cts +0 -406
  84. package/dist/assertion/impl/async-iterable.d.cts.map +0 -1
  85. package/dist/assertion/impl/async-iterable.d.ts +0 -406
  86. package/dist/assertion/impl/async-iterable.d.ts.map +0 -1
  87. package/dist/assertion/impl/async-iterable.js +0 -624
  88. package/dist/assertion/impl/async-iterable.js.map +0 -1
  89. package/dist/assertion/impl/async-parametric.cjs +0 -412
  90. package/dist/assertion/impl/async-parametric.cjs.map +0 -1
  91. package/dist/assertion/impl/async-parametric.d.cts +0 -278
  92. package/dist/assertion/impl/async-parametric.d.cts.map +0 -1
  93. package/dist/assertion/impl/async-parametric.d.ts +0 -278
  94. package/dist/assertion/impl/async-parametric.d.ts.map +0 -1
  95. package/dist/assertion/impl/async-parametric.js +0 -409
  96. package/dist/assertion/impl/async-parametric.js.map +0 -1
  97. package/dist/assertion/impl/async.cjs +0 -56
  98. package/dist/assertion/impl/async.cjs.map +0 -1
  99. package/dist/assertion/impl/async.d.cts +0 -179
  100. package/dist/assertion/impl/async.d.cts.map +0 -1
  101. package/dist/assertion/impl/async.d.ts +0 -179
  102. package/dist/assertion/impl/async.d.ts.map +0 -1
  103. package/dist/assertion/impl/async.js +0 -39
  104. package/dist/assertion/impl/async.js.map +0 -1
  105. package/dist/assertion/impl/index.cjs +0 -37
  106. package/dist/assertion/impl/index.cjs.map +0 -1
  107. package/dist/assertion/impl/index.d.cts +0 -21
  108. package/dist/assertion/impl/index.d.cts.map +0 -1
  109. package/dist/assertion/impl/index.d.ts +0 -21
  110. package/dist/assertion/impl/index.d.ts.map +0 -1
  111. package/dist/assertion/impl/index.js +0 -21
  112. package/dist/assertion/impl/index.js.map +0 -1
  113. package/dist/assertion/impl/iteration-util.cjs +0 -297
  114. package/dist/assertion/impl/iteration-util.cjs.map +0 -1
  115. package/dist/assertion/impl/iteration-util.d.cts +0 -12
  116. package/dist/assertion/impl/iteration-util.d.cts.map +0 -1
  117. package/dist/assertion/impl/iteration-util.d.ts +0 -12
  118. package/dist/assertion/impl/iteration-util.d.ts.map +0 -1
  119. package/dist/assertion/impl/iteration-util.js +0 -282
  120. package/dist/assertion/impl/iteration-util.js.map +0 -1
  121. package/dist/assertion/impl/snapshot.cjs +0 -276
  122. package/dist/assertion/impl/snapshot.cjs.map +0 -1
  123. package/dist/assertion/impl/snapshot.d.cts +0 -278
  124. package/dist/assertion/impl/snapshot.d.cts.map +0 -1
  125. package/dist/assertion/impl/snapshot.d.ts +0 -278
  126. package/dist/assertion/impl/snapshot.d.ts.map +0 -1
  127. package/dist/assertion/impl/snapshot.js +0 -273
  128. package/dist/assertion/impl/snapshot.js.map +0 -1
  129. package/dist/assertion/impl/sync-basic.cjs +0 -553
  130. package/dist/assertion/impl/sync-basic.cjs.map +0 -1
  131. package/dist/assertion/impl/sync-basic.d.cts +0 -528
  132. package/dist/assertion/impl/sync-basic.d.cts.map +0 -1
  133. package/dist/assertion/impl/sync-basic.d.ts +0 -528
  134. package/dist/assertion/impl/sync-basic.d.ts.map +0 -1
  135. package/dist/assertion/impl/sync-basic.js +0 -550
  136. package/dist/assertion/impl/sync-basic.js.map +0 -1
  137. package/dist/assertion/impl/sync-collection.cjs +0 -856
  138. package/dist/assertion/impl/sync-collection.cjs.map +0 -1
  139. package/dist/assertion/impl/sync-collection.d.cts +0 -607
  140. package/dist/assertion/impl/sync-collection.d.cts.map +0 -1
  141. package/dist/assertion/impl/sync-collection.d.ts +0 -607
  142. package/dist/assertion/impl/sync-collection.d.ts.map +0 -1
  143. package/dist/assertion/impl/sync-collection.js +0 -850
  144. package/dist/assertion/impl/sync-collection.js.map +0 -1
  145. package/dist/assertion/impl/sync-date.cjs +0 -341
  146. package/dist/assertion/impl/sync-date.cjs.map +0 -1
  147. package/dist/assertion/impl/sync-date.d.cts +0 -209
  148. package/dist/assertion/impl/sync-date.d.cts.map +0 -1
  149. package/dist/assertion/impl/sync-date.d.ts +0 -209
  150. package/dist/assertion/impl/sync-date.d.ts.map +0 -1
  151. package/dist/assertion/impl/sync-date.js +0 -338
  152. package/dist/assertion/impl/sync-date.js.map +0 -1
  153. package/dist/assertion/impl/sync-esoteric.cjs +0 -214
  154. package/dist/assertion/impl/sync-esoteric.cjs.map +0 -1
  155. package/dist/assertion/impl/sync-esoteric.d.cts +0 -191
  156. package/dist/assertion/impl/sync-esoteric.d.cts.map +0 -1
  157. package/dist/assertion/impl/sync-esoteric.d.ts +0 -191
  158. package/dist/assertion/impl/sync-esoteric.d.ts.map +0 -1
  159. package/dist/assertion/impl/sync-esoteric.js +0 -211
  160. package/dist/assertion/impl/sync-esoteric.js.map +0 -1
  161. package/dist/assertion/impl/sync-iterable.cjs +0 -512
  162. package/dist/assertion/impl/sync-iterable.cjs.map +0 -1
  163. package/dist/assertion/impl/sync-iterable.d.cts +0 -334
  164. package/dist/assertion/impl/sync-iterable.d.cts.map +0 -1
  165. package/dist/assertion/impl/sync-iterable.d.ts +0 -334
  166. package/dist/assertion/impl/sync-iterable.d.ts.map +0 -1
  167. package/dist/assertion/impl/sync-iterable.js +0 -509
  168. package/dist/assertion/impl/sync-iterable.js.map +0 -1
  169. package/dist/assertion/impl/sync-parametric.cjs +0 -805
  170. package/dist/assertion/impl/sync-parametric.cjs.map +0 -1
  171. package/dist/assertion/impl/sync-parametric.d.cts +0 -560
  172. package/dist/assertion/impl/sync-parametric.d.cts.map +0 -1
  173. package/dist/assertion/impl/sync-parametric.d.ts +0 -560
  174. package/dist/assertion/impl/sync-parametric.d.ts.map +0 -1
  175. package/dist/assertion/impl/sync-parametric.js +0 -802
  176. package/dist/assertion/impl/sync-parametric.js.map +0 -1
  177. package/dist/assertion/impl/sync.cjs +0 -214
  178. package/dist/assertion/impl/sync.cjs.map +0 -1
  179. package/dist/assertion/impl/sync.d.cts +0 -512
  180. package/dist/assertion/impl/sync.d.cts.map +0 -1
  181. package/dist/assertion/impl/sync.d.ts +0 -512
  182. package/dist/assertion/impl/sync.d.ts.map +0 -1
  183. package/dist/assertion/impl/sync.js +0 -197
  184. package/dist/assertion/impl/sync.js.map +0 -1
  185. package/dist/assertion/index.cjs +0 -38
  186. package/dist/assertion/index.cjs.map +0 -1
  187. package/dist/assertion/index.d.cts +0 -18
  188. package/dist/assertion/index.d.cts.map +0 -1
  189. package/dist/assertion/index.d.ts +0 -18
  190. package/dist/assertion/index.d.ts.map +0 -1
  191. package/dist/assertion/index.js +0 -17
  192. package/dist/assertion/index.js.map +0 -1
  193. package/dist/assertion/slotify.cjs +0 -165
  194. package/dist/assertion/slotify.cjs.map +0 -1
  195. package/dist/assertion/slotify.d.cts +0 -11
  196. package/dist/assertion/slotify.d.cts.map +0 -1
  197. package/dist/assertion/slotify.d.ts +0 -11
  198. package/dist/assertion/slotify.d.ts.map +0 -1
  199. package/dist/assertion/slotify.js +0 -161
  200. package/dist/assertion/slotify.js.map +0 -1
  201. package/dist/bootstrap.cjs +0 -43
  202. package/dist/bootstrap.cjs.map +0 -1
  203. package/dist/bootstrap.d.cts +0 -27
  204. package/dist/bootstrap.d.cts.map +0 -1
  205. package/dist/bootstrap.d.ts +0 -27
  206. package/dist/bootstrap.d.ts.map +0 -1
  207. package/dist/bootstrap.js +0 -40
  208. package/dist/bootstrap.js.map +0 -1
  209. package/dist/constant.cjs +0 -82
  210. package/dist/constant.cjs.map +0 -1
  211. package/dist/constant.d.cts +0 -69
  212. package/dist/constant.d.cts.map +0 -1
  213. package/dist/constant.d.ts +0 -69
  214. package/dist/constant.d.ts.map +0 -1
  215. package/dist/constant.js +0 -79
  216. package/dist/constant.js.map +0 -1
  217. package/dist/diff.cjs +0 -340
  218. package/dist/diff.cjs.map +0 -1
  219. package/dist/diff.d.cts +0 -51
  220. package/dist/diff.d.cts.map +0 -1
  221. package/dist/diff.d.ts +0 -51
  222. package/dist/diff.d.ts.map +0 -1
  223. package/dist/diff.js +0 -334
  224. package/dist/diff.js.map +0 -1
  225. package/dist/error.cjs +0 -204
  226. package/dist/error.cjs.map +0 -1
  227. package/dist/error.d.cts +0 -212
  228. package/dist/error.d.cts.map +0 -1
  229. package/dist/error.d.ts +0 -212
  230. package/dist/error.d.ts.map +0 -1
  231. package/dist/error.js +0 -191
  232. package/dist/error.js.map +0 -1
  233. package/dist/expect.cjs +0 -590
  234. package/dist/expect.cjs.map +0 -1
  235. package/dist/expect.d.cts +0 -138
  236. package/dist/expect.d.cts.map +0 -1
  237. package/dist/expect.d.ts +0 -138
  238. package/dist/expect.d.ts.map +0 -1
  239. package/dist/expect.js +0 -582
  240. package/dist/expect.js.map +0 -1
  241. package/dist/guards.cjs +0 -297
  242. package/dist/guards.cjs.map +0 -1
  243. package/dist/guards.d.cts +0 -231
  244. package/dist/guards.d.cts.map +0 -1
  245. package/dist/guards.d.ts +0 -231
  246. package/dist/guards.d.ts.map +0 -1
  247. package/dist/guards.js +0 -277
  248. package/dist/guards.js.map +0 -1
  249. package/dist/index.cjs +0 -111
  250. package/dist/index.cjs.map +0 -1
  251. package/dist/index.d.cts +0 -448
  252. package/dist/index.d.cts.map +0 -1
  253. package/dist/index.d.ts +0 -448
  254. package/dist/index.d.ts.map +0 -1
  255. package/dist/index.js +0 -71
  256. package/dist/index.js.map +0 -1
  257. package/dist/internal-schema.cjs +0 -253
  258. package/dist/internal-schema.cjs.map +0 -1
  259. package/dist/internal-schema.d.cts +0 -8
  260. package/dist/internal-schema.d.cts.map +0 -1
  261. package/dist/internal-schema.d.ts +0 -8
  262. package/dist/internal-schema.d.ts.map +0 -1
  263. package/dist/internal-schema.js +0 -248
  264. package/dist/internal-schema.js.map +0 -1
  265. package/dist/metadata.cjs +0 -57
  266. package/dist/metadata.cjs.map +0 -1
  267. package/dist/metadata.d.cts +0 -27
  268. package/dist/metadata.d.cts.map +0 -1
  269. package/dist/metadata.d.ts +0 -27
  270. package/dist/metadata.d.ts.map +0 -1
  271. package/dist/metadata.js +0 -54
  272. package/dist/metadata.js.map +0 -1
  273. package/dist/schema.cjs +0 -1522
  274. package/dist/schema.cjs.map +0 -1
  275. package/dist/schema.d.cts +0 -1196
  276. package/dist/schema.d.cts.map +0 -1
  277. package/dist/schema.d.ts +0 -1196
  278. package/dist/schema.d.ts.map +0 -1
  279. package/dist/schema.js +0 -1516
  280. package/dist/schema.js.map +0 -1
  281. package/dist/snapshot/adapter.cjs +0 -31
  282. package/dist/snapshot/adapter.cjs.map +0 -1
  283. package/dist/snapshot/adapter.d.cts +0 -258
  284. package/dist/snapshot/adapter.d.cts.map +0 -1
  285. package/dist/snapshot/adapter.d.ts +0 -258
  286. package/dist/snapshot/adapter.d.ts.map +0 -1
  287. package/dist/snapshot/adapter.js +0 -27
  288. package/dist/snapshot/adapter.js.map +0 -1
  289. package/dist/snapshot/adapters/fallback.cjs +0 -453
  290. package/dist/snapshot/adapters/fallback.cjs.map +0 -1
  291. package/dist/snapshot/adapters/fallback.d.cts +0 -185
  292. package/dist/snapshot/adapters/fallback.d.cts.map +0 -1
  293. package/dist/snapshot/adapters/fallback.d.ts +0 -185
  294. package/dist/snapshot/adapters/fallback.d.ts.map +0 -1
  295. package/dist/snapshot/adapters/fallback.js +0 -446
  296. package/dist/snapshot/adapters/fallback.js.map +0 -1
  297. package/dist/snapshot/adapters/node-test.cjs +0 -301
  298. package/dist/snapshot/adapters/node-test.cjs.map +0 -1
  299. package/dist/snapshot/adapters/node-test.d.cts +0 -131
  300. package/dist/snapshot/adapters/node-test.d.cts.map +0 -1
  301. package/dist/snapshot/adapters/node-test.d.ts +0 -131
  302. package/dist/snapshot/adapters/node-test.d.ts.map +0 -1
  303. package/dist/snapshot/adapters/node-test.js +0 -297
  304. package/dist/snapshot/adapters/node-test.js.map +0 -1
  305. package/dist/snapshot/index.cjs +0 -61
  306. package/dist/snapshot/index.cjs.map +0 -1
  307. package/dist/snapshot/index.d.cts +0 -40
  308. package/dist/snapshot/index.d.cts.map +0 -1
  309. package/dist/snapshot/index.d.ts +0 -40
  310. package/dist/snapshot/index.d.ts.map +0 -1
  311. package/dist/snapshot/index.js +0 -44
  312. package/dist/snapshot/index.js.map +0 -1
  313. package/dist/snapshot/node-version.cjs +0 -49
  314. package/dist/snapshot/node-version.cjs.map +0 -1
  315. package/dist/snapshot/node-version.d.cts +0 -34
  316. package/dist/snapshot/node-version.d.cts.map +0 -1
  317. package/dist/snapshot/node-version.d.ts +0 -34
  318. package/dist/snapshot/node-version.d.ts.map +0 -1
  319. package/dist/snapshot/node-version.js +0 -44
  320. package/dist/snapshot/node-version.js.map +0 -1
  321. package/dist/snapshot/select-adapter.cjs +0 -170
  322. package/dist/snapshot/select-adapter.cjs.map +0 -1
  323. package/dist/snapshot/select-adapter.d.cts +0 -128
  324. package/dist/snapshot/select-adapter.d.cts.map +0 -1
  325. package/dist/snapshot/select-adapter.d.ts +0 -128
  326. package/dist/snapshot/select-adapter.d.ts.map +0 -1
  327. package/dist/snapshot/select-adapter.js +0 -164
  328. package/dist/snapshot/select-adapter.js.map +0 -1
  329. package/dist/snapshot/serializer.cjs +0 -246
  330. package/dist/snapshot/serializer.cjs.map +0 -1
  331. package/dist/snapshot/serializer.d.cts +0 -126
  332. package/dist/snapshot/serializer.d.cts.map +0 -1
  333. package/dist/snapshot/serializer.d.ts +0 -126
  334. package/dist/snapshot/serializer.d.ts.map +0 -1
  335. package/dist/snapshot/serializer.js +0 -238
  336. package/dist/snapshot/serializer.js.map +0 -1
  337. package/dist/standard-schema.cjs +0 -13
  338. package/dist/standard-schema.cjs.map +0 -1
  339. package/dist/standard-schema.d.cts +0 -192
  340. package/dist/standard-schema.d.cts.map +0 -1
  341. package/dist/standard-schema.d.ts +0 -192
  342. package/dist/standard-schema.d.ts.map +0 -1
  343. package/dist/standard-schema.js +0 -12
  344. package/dist/standard-schema.js.map +0 -1
  345. package/dist/types.cjs +0 -22
  346. package/dist/types.cjs.map +0 -1
  347. package/dist/types.d.cts +0 -905
  348. package/dist/types.d.cts.map +0 -1
  349. package/dist/types.d.ts +0 -905
  350. package/dist/types.d.ts.map +0 -1
  351. package/dist/types.js +0 -21
  352. package/dist/types.js.map +0 -1
  353. package/dist/use.cjs +0 -240
  354. package/dist/use.cjs.map +0 -1
  355. package/dist/use.d.cts +0 -8
  356. package/dist/use.d.cts.map +0 -1
  357. package/dist/use.d.ts +0 -8
  358. package/dist/use.d.ts.map +0 -1
  359. package/dist/use.js +0 -236
  360. package/dist/use.js.map +0 -1
  361. package/dist/util.cjs +0 -255
  362. package/dist/util.cjs.map +0 -1
  363. package/dist/util.d.cts +0 -141
  364. package/dist/util.d.cts.map +0 -1
  365. package/dist/util.d.ts +0 -141
  366. package/dist/util.d.ts.map +0 -1
  367. package/dist/util.js +0 -234
  368. package/dist/util.js.map +0 -1
  369. package/dist/value-to-schema.cjs +0 -537
  370. package/dist/value-to-schema.cjs.map +0 -1
  371. package/dist/value-to-schema.d.cts +0 -144
  372. package/dist/value-to-schema.d.cts.map +0 -1
  373. package/dist/value-to-schema.d.ts +0 -144
  374. package/dist/value-to-schema.d.ts.map +0 -1
  375. package/dist/value-to-schema.js +0 -533
  376. package/dist/value-to-schema.js.map +0 -1
@@ -1,453 +0,0 @@
1
- "use strict";
2
- /**
3
- * Fallback adapter for frameworks without native snapshot support.
4
- *
5
- * This adapter provides custom snapshot storage for test frameworks that don't
6
- * have built-in snapshot functionality (e.g., Mocha, Tap, custom test
7
- * runners).
8
- *
9
- * **Storage Format:** Snapshots are stored as CommonJS modules in
10
- * `__snapshots__/` directories:
11
- *
12
- * ```javascript
13
- * // __snapshots__/my-test.test.js.snap.cjs
14
- * module.exports = {
15
- * 'test name': '{\n "value": 42\n}',
16
- * 'test name 2': '"another snapshot"',
17
- * };
18
- * ```
19
- *
20
- * @packageDocumentation
21
- */
22
- var __importDefault = (this && this.__importDefault) || function (mod) {
23
- return (mod && mod.__esModule) ? mod : { "default": mod };
24
- };
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.fallbackAdapter = exports.FallbackAdapter = void 0;
27
- const json_stable_stringify_1 = __importDefault(require("json-stable-stringify"));
28
- const node_fs_1 = require("node:fs");
29
- const node_path_1 = require("node:path");
30
- const serializer_js_1 = require("../serializer.cjs");
31
- const { entries } = Object;
32
- /**
33
- * Extract snapshot context from Mocha's `this` context.
34
- *
35
- * Mocha provides test information through `this.test` in test callbacks. This
36
- * function attempts to extract the test name and file path from that
37
- * structure.
38
- *
39
- * @example
40
- *
41
- * ```typescript
42
- * describe('suite', function () {
43
- * it('test', function () {
44
- * const ctx = extractMochaContext(this);
45
- * // ctx = {
46
- * // testPath: 'suite test',
47
- * // filePath: '/path/to/test.js',
48
- * // isUpdateMode: false
49
- * // }
50
- * });
51
- * });
52
- * ```
53
- *
54
- * @function
55
- * @param context - Potential Mocha context object
56
- * @returns Snapshot context if Mocha context detected, null otherwise
57
- */
58
- const extractMochaContext = (context) => {
59
- const mochaCtx = context;
60
- if (mochaCtx?.test?.fullTitle) {
61
- return {
62
- filePath: mochaCtx.test.file || getTestFilePathFromStack(),
63
- isUpdateMode: process.env.BUPKIS_UPDATE_SNAPSHOTS === '1',
64
- testPath: mochaCtx.test.fullTitle(),
65
- };
66
- }
67
- return null;
68
- };
69
- /**
70
- * Get snapshot file path for a test file.
71
- *
72
- * Snapshots are stored in a `__snapshots__/` directory next to the test file.
73
- * The snapshot filename is based on the test file path, with slashes replaced
74
- * by dashes to create a flat structure.
75
- *
76
- * Uses `.cjs` extension for CommonJS compatibility in both CJS and ESM
77
- * projects.
78
- *
79
- * @example
80
- *
81
- * ```typescript
82
- * getSnapshotFilePath('/project/test/unit/foo.test.ts');
83
- * // Returns: '/project/test/unit/__snapshots__/test-unit-foo.test.ts.snap.cjs'
84
- * ```
85
- *
86
- * @function
87
- * @param testFilePath - Absolute path to the test file
88
- * @returns Absolute path to the snapshot file
89
- */
90
- const getSnapshotFilePath = (testFilePath) => {
91
- const dir = (0, node_path_1.dirname)(testFilePath);
92
- const snapshotDir = (0, node_path_1.join)(dir, '__snapshots__');
93
- const filename = (0, node_path_1.relative)(process.cwd(), testFilePath).replace(/\//g, '-');
94
- return (0, node_path_1.join)(snapshotDir, `${filename}.snap.cjs`);
95
- };
96
- /**
97
- * Get test file path from stack trace.
98
- *
99
- * Searches the stack trace for lines containing test file paths. Looks for
100
- * files matching patterns like `*.test.js`, `*.spec.ts`, etc.
101
- *
102
- * @function
103
- * @returns Absolute path to test file, or 'unknown.test.js' if not found
104
- */
105
- const getTestFilePathFromStack = () => {
106
- const stack = new Error().stack || '';
107
- const lines = stack.split('\n');
108
- for (const line of lines) {
109
- // Match file paths in stack traces
110
- const match = line.match(/\((.+\.(?:test|spec)\.[jt]s):\d+:\d+\)/);
111
- if (match && match[1]) {
112
- return (0, node_path_1.resolve)(match[1]);
113
- }
114
- }
115
- return (0, node_path_1.resolve)('unknown.test.js');
116
- };
117
- /**
118
- * Load snapshots from a snapshot file.
119
- *
120
- * Reads and parses the CommonJS format snapshot file. If the file doesn't exist
121
- * or can't be parsed, returns an empty store.
122
- *
123
- * **Expected format:**
124
- *
125
- * ```javascript
126
- * module.exports = {
127
- * 'test name': '{"value": 42}',
128
- * 'another test': '"string"',
129
- * };
130
- * ```
131
- *
132
- * @example
133
- *
134
- * ```typescript
135
- * const store = loadSnapshots('/path/to/__snapshots__/test.snap.cjs');
136
- * console.log(store['my test']); // '{"foo": "bar"}'
137
- * ```
138
- *
139
- * @function
140
- * @param snapshotPath - Path to the snapshot file
141
- * @returns Snapshot store (test name → serialized value)
142
- */
143
- const loadSnapshots = (snapshotPath) => {
144
- if (!(0, node_fs_1.existsSync)(snapshotPath)) {
145
- return {};
146
- }
147
- try {
148
- // Read as CommonJS module
149
- const content = (0, node_fs_1.readFileSync)(snapshotPath, 'utf-8');
150
- // Parse the module.exports = { ... } format
151
- const match = content.match(/module\.exports\s*=\s*(\{[\s\S]*\});?\s*$/);
152
- if (match) {
153
- // Use Function constructor to safely eval the object literal
154
- // This is safe because we're only parsing the object structure,
155
- // not executing arbitrary code
156
- // eslint-disable-next-line @typescript-eslint/no-implied-eval, @typescript-eslint/no-unsafe-call
157
- const store = new Function(`return ${match[1]}`)();
158
- return store;
159
- }
160
- }
161
- catch {
162
- // If parsing fails, return empty store
163
- // This allows for snapshot regeneration
164
- }
165
- return {};
166
- };
167
- /**
168
- * Save snapshots to a snapshot file.
169
- *
170
- * Writes the snapshot store to disk in CommonJS format. Creates the
171
- * `__snapshots__/` directory if it doesn't exist. Entries are sorted
172
- * alphabetically by test name for consistency.
173
- *
174
- * **Output format:**
175
- *
176
- * ```javascript
177
- * module.exports = {
178
- * 'test 1': '{"value": 1}',
179
- * 'test 2': '{"value": 2}',
180
- * };
181
- * ```
182
- *
183
- * @example
184
- *
185
- * ```typescript
186
- * const store = {
187
- * 'my test': '{"foo": "bar"}',
188
- * 'another test': '"string"',
189
- * };
190
- * saveSnapshots('/path/to/__snapshots__/test.snap.cjs', store);
191
- * ```
192
- *
193
- * @function
194
- * @param snapshotPath - Path to the snapshot file
195
- * @param store - Snapshot store to save
196
- */
197
- const saveSnapshots = (snapshotPath, store) => {
198
- const dir = (0, node_path_1.dirname)(snapshotPath);
199
- // Ensure directory exists
200
- if (!(0, node_fs_1.existsSync)(dir)) {
201
- (0, node_fs_1.mkdirSync)(dir, { recursive: true });
202
- }
203
- // Generate CommonJS module format with sorted entries
204
- const snapshotEntries = entries(store)
205
- .sort(([a], [b]) => a.localeCompare(b))
206
- .map(([key, value]) => ` ${(0, json_stable_stringify_1.default)(key)}: ${(0, json_stable_stringify_1.default)(value)}`)
207
- .join(',\n');
208
- const content = `module.exports = {\n${snapshotEntries}\n};\n`;
209
- (0, node_fs_1.writeFileSync)(snapshotPath, content, 'utf-8');
210
- };
211
- /**
212
- * Snapshot counters for multiple snapshots per test.
213
- *
214
- * Tracks how many snapshots have been taken for each test path to generate
215
- * unique snapshot names when a test has multiple snapshots.
216
- */
217
- const snapshotCounters = new Map();
218
- /**
219
- * Fallback adapter for frameworks without native snapshot support.
220
- *
221
- * This adapter provides custom snapshot storage and management for test
222
- * frameworks that don't have built-in snapshot functionality.
223
- *
224
- * **Supported Contexts:**
225
- *
226
- * - **Mocha**: Pass `this` from test callback
227
- * - **Explicit names**: Pass a string snapshot name
228
- *
229
- * **Storage:**
230
- *
231
- * - Snapshots stored in `__snapshots__/*.snap.cjs` files
232
- * - CommonJS format for compatibility with both CJS and ESM projects
233
- * - Sorted entries for consistent diffs
234
- *
235
- * **Update Mode:**
236
- *
237
- * - Controlled by `BUPKIS_UPDATE_SNAPSHOTS=1` environment variable
238
- *
239
- * **Features:**
240
- *
241
- * - Multiple snapshots per test (automatic counters)
242
- * - Named snapshots via `hint` option
243
- * - Circular reference detection
244
- * - Non-JSON type handling
245
- *
246
- * @example
247
- *
248
- * ```typescript
249
- * // Mocha usage
250
- * describe('MyComponent', function() {
251
- * it('renders', function() {
252
- * const output = render(<MyComponent />);
253
- * expect(output, 'to match snapshot', this);
254
- * });
255
- * });
256
- * ```
257
- *
258
- * @example
259
- *
260
- * ```typescript
261
- * // Explicit name (any framework)
262
- * test('renders component', () => {
263
- * const output = render(<MyComponent />);
264
- * expect(output, 'to match snapshot', 'component-default-state');
265
- * });
266
- * ```
267
- *
268
- * @example
269
- *
270
- * ```typescript
271
- * // Multiple snapshots with hints
272
- * test('multi-step process', () => {
273
- * expect(step1(), 'to match snapshot', 'step-1', { hint: 'initial' });
274
- * expect(step2(), 'to match snapshot', 'step-2', { hint: 'processing' });
275
- * expect(step3(), 'to match snapshot', 'step-3', { hint: 'complete' });
276
- * });
277
- * ```
278
- *
279
- * @example
280
- *
281
- * ```sh
282
- * # Update snapshots
283
- * BUPKIS_UPDATE_SNAPSHOTS=1 npm test
284
- * ```
285
- */
286
- class FallbackAdapter {
287
- /**
288
- * Adapter name for identification and debugging.
289
- */
290
- name = 'fallback';
291
- /**
292
- * Check if this adapter can handle the given context.
293
- *
294
- * The fallback adapter accepts both strings (explicit snapshot names) and
295
- * objects (potential Mocha contexts). It's designed to be the last adapter in
296
- * the selection chain and will accept most inputs.
297
- *
298
- * @param context - Test context or snapshot name
299
- * @returns `true` for strings or objects
300
- */
301
- canHandle(context) {
302
- // Fallback handles strings (explicit names) and objects (Mocha)
303
- return typeof context === 'string' || typeof context === 'object';
304
- }
305
- /**
306
- * Extract snapshot context from Mocha context or string name.
307
- *
308
- * **For Mocha contexts:**
309
- *
310
- * - Extracts test name from `this.test.fullTitle()`
311
- * - Gets file path from `this.test.file` or stack trace
312
- *
313
- * **For string contexts:**
314
- *
315
- * - Uses the string as the test name
316
- * - Extracts file path from stack trace
317
- *
318
- * **Update mode:**
319
- *
320
- * - Checks `process.env.BUPKIS_UPDATE_SNAPSHOTS === '1'`
321
- *
322
- * @param context - Mocha context or string snapshot name
323
- * @returns Normalized snapshot context
324
- * @throws {TypeError} If context is neither a valid Mocha context nor a
325
- * string
326
- */
327
- getContext(context) {
328
- // Try Mocha first
329
- const mochaContext = extractMochaContext(context);
330
- if (mochaContext) {
331
- return mochaContext;
332
- }
333
- // String context (explicit snapshot name)
334
- if (typeof context === 'string') {
335
- return {
336
- filePath: getTestFilePathFromStack(),
337
- isUpdateMode: process.env.BUPKIS_UPDATE_SNAPSHOTS === '1',
338
- testPath: context,
339
- };
340
- }
341
- throw new TypeError('Fallback adapter requires either a string snapshot name or Mocha context. ' +
342
- 'Pass test name as string: expect(value, "to match snapshot", "my-test-name")');
343
- }
344
- /**
345
- * Perform snapshot assertion using custom storage.
346
- *
347
- * **Behavior:**
348
- *
349
- * - **Update mode**: Creates or updates the snapshot
350
- * - **Comparison mode**: Loads existing snapshot and compares
351
- *
352
- * **Process:**
353
- *
354
- * 1. Serialize the value using provided serializer or default
355
- * 2. Generate unique snapshot name (with counter if needed)
356
- * 3. Load existing snapshot store from disk
357
- * 4. Either update snapshot or compare and throw on mismatch
358
- *
359
- * @example
360
- *
361
- * ```typescript
362
- * const adapter = new FallbackAdapter();
363
- *
364
- * // With Mocha context
365
- * adapter.assertSnapshot({ foo: 'bar' }, mochaThis);
366
- *
367
- * // With explicit name
368
- * adapter.assertSnapshot({ foo: 'bar' }, 'my-snapshot');
369
- *
370
- * // With custom serializer
371
- * adapter.assertSnapshot(data, 'test', {
372
- * serializer: (v) => JSON.stringify(v, null, 2),
373
- * });
374
- * ```
375
- *
376
- * @param value - Value to snapshot
377
- * @param context - Mocha context or string name
378
- * @param options - Optional serializer and hint
379
- * @throws {TypeError} If context is invalid
380
- * @throws {AssertionError} If snapshot doesn't match (in comparison mode)
381
- */
382
- validateSnapshot(value, context, options) {
383
- const ctx = this.getContext(context);
384
- const serializer = options?.serializer || serializer_js_1.defaultSerializer;
385
- const snapshotName = getSnapshotName(ctx.testPath, options?.hint);
386
- const snapshotPath = getSnapshotFilePath(ctx.filePath);
387
- const store = loadSnapshots(snapshotPath);
388
- const actual = serializer(value);
389
- const expected = store[snapshotName];
390
- if (ctx.isUpdateMode || expected === undefined) {
391
- // Update/create snapshot
392
- store[snapshotName] = actual;
393
- saveSnapshots(snapshotPath, store);
394
- return;
395
- }
396
- // Compare snapshots
397
- if (actual !== expected) {
398
- return {
399
- actual,
400
- expected,
401
- message: `Snapshot mismatch for "${snapshotName}"\n\nExpected:\n${expected}\n\nActual:\n${actual}`,
402
- };
403
- }
404
- }
405
- }
406
- exports.FallbackAdapter = FallbackAdapter;
407
- /**
408
- * Get the next snapshot name for a test.
409
- *
410
- * For the first snapshot in a test, uses the test path as-is. For subsequent
411
- * snapshots, appends a counter: `"test name 2"`, `"test name 3"`, etc.
412
- *
413
- * If a hint is provided, it's appended in brackets: `"test name [hint]"`.
414
- *
415
- * @example
416
- *
417
- * ```typescript
418
- * getSnapshotName('MyComponent renders'); // 'MyComponent renders'
419
- * getSnapshotName('MyComponent renders'); // 'MyComponent renders 2'
420
- * getSnapshotName('MyComponent renders'); // 'MyComponent renders 3'
421
- *
422
- * getSnapshotName('test', 'initial state'); // 'test [initial state]'
423
- * ```
424
- *
425
- * @function
426
- * @param testPath - Full test path/name
427
- * @param hint - Optional descriptive hint
428
- * @returns Unique snapshot name
429
- */
430
- const getSnapshotName = (testPath, hint) => {
431
- if (hint) {
432
- return `${testPath} [${hint}]`;
433
- }
434
- const counter = snapshotCounters.get(testPath) || 0;
435
- snapshotCounters.set(testPath, counter + 1);
436
- return counter === 0 ? testPath : `${testPath} ${counter + 1}`;
437
- };
438
- /**
439
- * Singleton instance of the fallback adapter.
440
- *
441
- * This is the primary export and should be used for adapter registration.
442
- *
443
- * @example
444
- *
445
- * ```typescript
446
- * import { fallbackAdapter } from 'bupkis/snapshot';
447
- * import { registerAdapter } from 'bupkis/snapshot';
448
- *
449
- * registerAdapter(fallbackAdapter);
450
- * ```
451
- */
452
- exports.fallbackAdapter = new FallbackAdapter();
453
- //# sourceMappingURL=fallback.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fallback.js","sourceRoot":"","sources":["../../../src/snapshot/adapters/fallback.ts"],"names":[],"mappings":"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"}
@@ -1,185 +0,0 @@
1
- /**
2
- * Fallback adapter for frameworks without native snapshot support.
3
- *
4
- * This adapter provides custom snapshot storage for test frameworks that don't
5
- * have built-in snapshot functionality (e.g., Mocha, Tap, custom test
6
- * runners).
7
- *
8
- * **Storage Format:** Snapshots are stored as CommonJS modules in
9
- * `__snapshots__/` directories:
10
- *
11
- * ```javascript
12
- * // __snapshots__/my-test.test.js.snap.cjs
13
- * module.exports = {
14
- * 'test name': '{\n "value": 42\n}',
15
- * 'test name 2': '"another snapshot"',
16
- * };
17
- * ```
18
- *
19
- * @packageDocumentation
20
- */
21
- import type { AssertionFailure } from "../../types.cjs";
22
- import type { SnapshotAdapter, SnapshotContext, SnapshotOptions } from "../adapter.cjs";
23
- /**
24
- * Fallback adapter for frameworks without native snapshot support.
25
- *
26
- * This adapter provides custom snapshot storage and management for test
27
- * frameworks that don't have built-in snapshot functionality.
28
- *
29
- * **Supported Contexts:**
30
- *
31
- * - **Mocha**: Pass `this` from test callback
32
- * - **Explicit names**: Pass a string snapshot name
33
- *
34
- * **Storage:**
35
- *
36
- * - Snapshots stored in `__snapshots__/*.snap.cjs` files
37
- * - CommonJS format for compatibility with both CJS and ESM projects
38
- * - Sorted entries for consistent diffs
39
- *
40
- * **Update Mode:**
41
- *
42
- * - Controlled by `BUPKIS_UPDATE_SNAPSHOTS=1` environment variable
43
- *
44
- * **Features:**
45
- *
46
- * - Multiple snapshots per test (automatic counters)
47
- * - Named snapshots via `hint` option
48
- * - Circular reference detection
49
- * - Non-JSON type handling
50
- *
51
- * @example
52
- *
53
- * ```typescript
54
- * // Mocha usage
55
- * describe('MyComponent', function() {
56
- * it('renders', function() {
57
- * const output = render(<MyComponent />);
58
- * expect(output, 'to match snapshot', this);
59
- * });
60
- * });
61
- * ```
62
- *
63
- * @example
64
- *
65
- * ```typescript
66
- * // Explicit name (any framework)
67
- * test('renders component', () => {
68
- * const output = render(<MyComponent />);
69
- * expect(output, 'to match snapshot', 'component-default-state');
70
- * });
71
- * ```
72
- *
73
- * @example
74
- *
75
- * ```typescript
76
- * // Multiple snapshots with hints
77
- * test('multi-step process', () => {
78
- * expect(step1(), 'to match snapshot', 'step-1', { hint: 'initial' });
79
- * expect(step2(), 'to match snapshot', 'step-2', { hint: 'processing' });
80
- * expect(step3(), 'to match snapshot', 'step-3', { hint: 'complete' });
81
- * });
82
- * ```
83
- *
84
- * @example
85
- *
86
- * ```sh
87
- * # Update snapshots
88
- * BUPKIS_UPDATE_SNAPSHOTS=1 npm test
89
- * ```
90
- */
91
- export declare class FallbackAdapter implements SnapshotAdapter {
92
- /**
93
- * Adapter name for identification and debugging.
94
- */
95
- readonly name = "fallback";
96
- /**
97
- * Check if this adapter can handle the given context.
98
- *
99
- * The fallback adapter accepts both strings (explicit snapshot names) and
100
- * objects (potential Mocha contexts). It's designed to be the last adapter in
101
- * the selection chain and will accept most inputs.
102
- *
103
- * @param context - Test context or snapshot name
104
- * @returns `true` for strings or objects
105
- */
106
- canHandle(context: unknown): boolean;
107
- /**
108
- * Extract snapshot context from Mocha context or string name.
109
- *
110
- * **For Mocha contexts:**
111
- *
112
- * - Extracts test name from `this.test.fullTitle()`
113
- * - Gets file path from `this.test.file` or stack trace
114
- *
115
- * **For string contexts:**
116
- *
117
- * - Uses the string as the test name
118
- * - Extracts file path from stack trace
119
- *
120
- * **Update mode:**
121
- *
122
- * - Checks `process.env.BUPKIS_UPDATE_SNAPSHOTS === '1'`
123
- *
124
- * @param context - Mocha context or string snapshot name
125
- * @returns Normalized snapshot context
126
- * @throws {TypeError} If context is neither a valid Mocha context nor a
127
- * string
128
- */
129
- getContext(context: unknown): SnapshotContext;
130
- /**
131
- * Perform snapshot assertion using custom storage.
132
- *
133
- * **Behavior:**
134
- *
135
- * - **Update mode**: Creates or updates the snapshot
136
- * - **Comparison mode**: Loads existing snapshot and compares
137
- *
138
- * **Process:**
139
- *
140
- * 1. Serialize the value using provided serializer or default
141
- * 2. Generate unique snapshot name (with counter if needed)
142
- * 3. Load existing snapshot store from disk
143
- * 4. Either update snapshot or compare and throw on mismatch
144
- *
145
- * @example
146
- *
147
- * ```typescript
148
- * const adapter = new FallbackAdapter();
149
- *
150
- * // With Mocha context
151
- * adapter.assertSnapshot({ foo: 'bar' }, mochaThis);
152
- *
153
- * // With explicit name
154
- * adapter.assertSnapshot({ foo: 'bar' }, 'my-snapshot');
155
- *
156
- * // With custom serializer
157
- * adapter.assertSnapshot(data, 'test', {
158
- * serializer: (v) => JSON.stringify(v, null, 2),
159
- * });
160
- * ```
161
- *
162
- * @param value - Value to snapshot
163
- * @param context - Mocha context or string name
164
- * @param options - Optional serializer and hint
165
- * @throws {TypeError} If context is invalid
166
- * @throws {AssertionError} If snapshot doesn't match (in comparison mode)
167
- */
168
- validateSnapshot(value: unknown, context: unknown, options?: SnapshotOptions): AssertionFailure | void;
169
- }
170
- /**
171
- * Singleton instance of the fallback adapter.
172
- *
173
- * This is the primary export and should be used for adapter registration.
174
- *
175
- * @example
176
- *
177
- * ```typescript
178
- * import { fallbackAdapter } from 'bupkis/snapshot';
179
- * import { registerAdapter } from 'bupkis/snapshot';
180
- *
181
- * registerAdapter(fallbackAdapter);
182
- * ```
183
- */
184
- export declare const fallbackAdapter: FallbackAdapter;
185
- //# sourceMappingURL=fallback.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fallback.d.ts","sourceRoot":"","sources":["../../../src/snapshot/adapters/fallback.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAMH,OAAO,KAAK,EAAE,gBAAgB,EAAE,wBAAuB;AACvD,OAAO,KAAK,EACV,eAAe,EACf,eAAe,EACf,eAAe,EAChB,uBAAsB;AAwPvB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmEG;AACH,qBAAa,eAAgB,YAAW,eAAe;IACrD;;OAEG;IACH,QAAQ,CAAC,IAAI,cAAc;IAE3B;;;;;;;;;OASG;IACH,SAAS,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO;IAKpC;;;;;;;;;;;;;;;;;;;;;OAqBG;IACH,UAAU,CAAC,OAAO,EAAE,OAAO,GAAG,eAAe;IAsB7C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAqCG;IACH,gBAAgB,CACd,KAAK,EAAE,OAAO,EACd,OAAO,EAAE,OAAO,EAChB,OAAO,CAAC,EAAE,eAAe,GACxB,gBAAgB,GAAG,IAAI;CA2B3B;AAoCD;;;;;;;;;;;;;GAaG;AACH,eAAO,MAAM,eAAe,iBAAwB,CAAC"}