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