veryfront 0.1.324 → 0.1.326

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 (271) hide show
  1. package/esm/cli/commands/extension/init-command.js +2 -2
  2. package/esm/cli/commands/extension/validate-command.js +1 -1
  3. package/esm/deno.d.ts +7 -0
  4. package/esm/deno.js +8 -1
  5. package/esm/deps/esm.sh/react-dom@19.2.4/client.d.ts +2 -0
  6. package/esm/deps/esm.sh/react-dom@19.2.4/client.d.ts.map +1 -0
  7. package/esm/deps/esm.sh/react-dom@19.2.4/client.js +5 -0
  8. package/esm/deps/esm.sh/scheduler@^0.27.0.d.ts +2 -0
  9. package/esm/deps/esm.sh/scheduler@^0.27.0.d.ts.map +1 -0
  10. package/esm/deps/esm.sh/scheduler@^0.27.0.js +3 -0
  11. package/esm/deps/jsr.io/@std/assert/1.0.19/almost_equals.d.ts +30 -0
  12. package/esm/deps/jsr.io/@std/assert/1.0.19/almost_equals.d.ts.map +1 -0
  13. package/esm/deps/jsr.io/@std/assert/1.0.19/almost_equals.js +47 -0
  14. package/esm/deps/jsr.io/@std/assert/1.0.19/array_includes.d.ts +29 -0
  15. package/esm/deps/jsr.io/@std/assert/1.0.19/array_includes.d.ts.map +1 -0
  16. package/esm/deps/jsr.io/@std/assert/1.0.19/array_includes.js +65 -0
  17. package/esm/deps/jsr.io/@std/assert/1.0.19/assert.d.ts +17 -0
  18. package/esm/deps/jsr.io/@std/assert/1.0.19/assert.d.ts.map +1 -0
  19. package/esm/deps/jsr.io/@std/assert/1.0.19/assert.js +23 -0
  20. package/esm/deps/jsr.io/@std/assert/1.0.19/assertion_error.d.ts +26 -0
  21. package/esm/deps/jsr.io/@std/assert/1.0.19/assertion_error.d.ts.map +1 -0
  22. package/esm/deps/jsr.io/@std/assert/1.0.19/assertion_error.js +30 -0
  23. package/esm/deps/jsr.io/@std/assert/1.0.19/equal.d.ts +25 -0
  24. package/esm/deps/jsr.io/@std/assert/1.0.19/equal.d.ts.map +1 -0
  25. package/esm/deps/jsr.io/@std/assert/1.0.19/equal.js +194 -0
  26. package/esm/deps/jsr.io/@std/assert/1.0.19/equals.d.ts +37 -0
  27. package/esm/deps/jsr.io/@std/assert/1.0.19/equals.d.ts.map +1 -0
  28. package/esm/deps/jsr.io/@std/assert/1.0.19/equals.js +61 -0
  29. package/esm/deps/jsr.io/@std/assert/1.0.19/exists.d.ts +18 -0
  30. package/esm/deps/jsr.io/@std/assert/1.0.19/exists.d.ts.map +1 -0
  31. package/esm/deps/jsr.io/@std/assert/1.0.19/exists.js +27 -0
  32. package/esm/deps/jsr.io/@std/assert/1.0.19/fail.d.ts +15 -0
  33. package/esm/deps/jsr.io/@std/assert/1.0.19/fail.d.ts.map +1 -0
  34. package/esm/deps/jsr.io/@std/assert/1.0.19/fail.js +20 -0
  35. package/esm/deps/jsr.io/@std/assert/1.0.19/false.d.ts +19 -0
  36. package/esm/deps/jsr.io/@std/assert/1.0.19/false.d.ts.map +1 -0
  37. package/esm/deps/jsr.io/@std/assert/1.0.19/false.js +23 -0
  38. package/esm/deps/jsr.io/@std/assert/1.0.19/greater.d.ts +20 -0
  39. package/esm/deps/jsr.io/@std/assert/1.0.19/greater.d.ts.map +1 -0
  40. package/esm/deps/jsr.io/@std/assert/1.0.19/greater.js +29 -0
  41. package/esm/deps/jsr.io/@std/assert/1.0.19/greater_or_equal.d.ts +20 -0
  42. package/esm/deps/jsr.io/@std/assert/1.0.19/greater_or_equal.d.ts.map +1 -0
  43. package/esm/deps/jsr.io/@std/assert/1.0.19/greater_or_equal.js +29 -0
  44. package/esm/deps/jsr.io/@std/assert/1.0.19/instance_of.d.ts +23 -0
  45. package/esm/deps/jsr.io/@std/assert/1.0.19/instance_of.d.ts.map +1 -0
  46. package/esm/deps/jsr.io/@std/assert/1.0.19/instance_of.js +52 -0
  47. package/esm/deps/jsr.io/@std/assert/1.0.19/is_error.d.ts +25 -0
  48. package/esm/deps/jsr.io/@std/assert/1.0.19/is_error.d.ts.map +1 -0
  49. package/esm/deps/jsr.io/@std/assert/1.0.19/is_error.js +53 -0
  50. package/esm/deps/jsr.io/@std/assert/1.0.19/less.d.ts +19 -0
  51. package/esm/deps/jsr.io/@std/assert/1.0.19/less.d.ts.map +1 -0
  52. package/esm/deps/jsr.io/@std/assert/1.0.19/less.js +28 -0
  53. package/esm/deps/jsr.io/@std/assert/1.0.19/less_or_equal.d.ts +20 -0
  54. package/esm/deps/jsr.io/@std/assert/1.0.19/less_or_equal.d.ts.map +1 -0
  55. package/esm/deps/jsr.io/@std/assert/1.0.19/less_or_equal.js +29 -0
  56. package/esm/deps/jsr.io/@std/assert/1.0.19/match.d.ts +18 -0
  57. package/esm/deps/jsr.io/@std/assert/1.0.19/match.d.ts.map +1 -0
  58. package/esm/deps/jsr.io/@std/assert/1.0.19/match.js +26 -0
  59. package/esm/deps/jsr.io/@std/assert/1.0.19/mod.d.ts +44 -0
  60. package/esm/deps/jsr.io/@std/assert/1.0.19/mod.d.ts.map +1 -0
  61. package/esm/deps/jsr.io/@std/assert/1.0.19/mod.js +45 -0
  62. package/esm/deps/jsr.io/@std/assert/1.0.19/not_equals.d.ts +27 -0
  63. package/esm/deps/jsr.io/@std/assert/1.0.19/not_equals.d.ts.map +1 -0
  64. package/esm/deps/jsr.io/@std/assert/1.0.19/not_equals.js +39 -0
  65. package/esm/deps/jsr.io/@std/assert/1.0.19/not_instance_of.d.ts +20 -0
  66. package/esm/deps/jsr.io/@std/assert/1.0.19/not_instance_of.d.ts.map +1 -0
  67. package/esm/deps/jsr.io/@std/assert/1.0.19/not_instance_of.js +29 -0
  68. package/esm/deps/jsr.io/@std/assert/1.0.19/not_match.d.ts +18 -0
  69. package/esm/deps/jsr.io/@std/assert/1.0.19/not_match.d.ts.map +1 -0
  70. package/esm/deps/jsr.io/@std/assert/1.0.19/not_match.js +26 -0
  71. package/esm/deps/jsr.io/@std/assert/1.0.19/not_strict_equals.d.ts +23 -0
  72. package/esm/deps/jsr.io/@std/assert/1.0.19/not_strict_equals.d.ts.map +1 -0
  73. package/esm/deps/jsr.io/@std/assert/1.0.19/not_strict_equals.js +32 -0
  74. package/esm/deps/jsr.io/@std/assert/1.0.19/object_match.d.ts +29 -0
  75. package/esm/deps/jsr.io/@std/assert/1.0.19/object_match.d.ts.map +1 -0
  76. package/esm/deps/jsr.io/@std/assert/1.0.19/object_match.js +177 -0
  77. package/esm/deps/jsr.io/@std/assert/1.0.19/rejects.d.ts +42 -0
  78. package/esm/deps/jsr.io/@std/assert/1.0.19/rejects.d.ts.map +1 -0
  79. package/esm/deps/jsr.io/@std/assert/1.0.19/rejects.js +53 -0
  80. package/esm/deps/jsr.io/@std/assert/1.0.19/strict_equals.d.ts +24 -0
  81. package/esm/deps/jsr.io/@std/assert/1.0.19/strict_equals.d.ts.map +1 -0
  82. package/esm/deps/jsr.io/@std/assert/1.0.19/strict_equals.js +58 -0
  83. package/esm/deps/jsr.io/@std/assert/1.0.19/string_includes.d.ts +18 -0
  84. package/esm/deps/jsr.io/@std/assert/1.0.19/string_includes.d.ts.map +1 -0
  85. package/esm/deps/jsr.io/@std/assert/1.0.19/string_includes.js +26 -0
  86. package/esm/deps/jsr.io/@std/assert/1.0.19/throws.d.ts +45 -0
  87. package/esm/deps/jsr.io/@std/assert/1.0.19/throws.d.ts.map +1 -0
  88. package/esm/deps/jsr.io/@std/assert/1.0.19/throws.js +44 -0
  89. package/esm/deps/jsr.io/@std/assert/1.0.19/unimplemented.d.ts +15 -0
  90. package/esm/deps/jsr.io/@std/assert/1.0.19/unimplemented.d.ts.map +1 -0
  91. package/esm/deps/jsr.io/@std/assert/1.0.19/unimplemented.js +20 -0
  92. package/esm/deps/jsr.io/@std/assert/1.0.19/unreachable.d.ts +15 -0
  93. package/esm/deps/jsr.io/@std/assert/1.0.19/unreachable.d.ts.map +1 -0
  94. package/esm/deps/jsr.io/@std/assert/1.0.19/unreachable.js +20 -0
  95. package/esm/deps/jsr.io/@std/internal/1.0.13/assertion_state.d.ts +150 -0
  96. package/esm/deps/jsr.io/@std/internal/1.0.13/assertion_state.d.ts.map +1 -0
  97. package/esm/deps/jsr.io/@std/internal/1.0.13/assertion_state.js +224 -0
  98. package/esm/deps/jsr.io/@std/internal/1.0.13/build_message.d.ts +80 -0
  99. package/esm/deps/jsr.io/@std/internal/1.0.13/build_message.d.ts.map +1 -0
  100. package/esm/deps/jsr.io/@std/internal/1.0.13/build_message.js +116 -0
  101. package/esm/deps/jsr.io/@std/internal/1.0.13/diff.d.ts +140 -0
  102. package/esm/deps/jsr.io/@std/internal/1.0.13/diff.d.ts.map +1 -0
  103. package/esm/deps/jsr.io/@std/internal/1.0.13/diff.js +276 -0
  104. package/esm/deps/jsr.io/@std/internal/1.0.13/diff_str.d.ts +99 -0
  105. package/esm/deps/jsr.io/@std/internal/1.0.13/diff_str.d.ts.map +1 -0
  106. package/esm/deps/jsr.io/@std/internal/1.0.13/diff_str.js +182 -0
  107. package/esm/deps/jsr.io/@std/internal/1.0.13/format.d.ts +29 -0
  108. package/esm/deps/jsr.io/@std/internal/1.0.13/format.d.ts.map +1 -0
  109. package/esm/deps/jsr.io/@std/internal/1.0.13/format.js +70 -0
  110. package/esm/deps/jsr.io/@std/internal/1.0.13/styles.d.ts +159 -0
  111. package/esm/deps/jsr.io/@std/internal/1.0.13/styles.d.ts.map +1 -0
  112. package/esm/deps/jsr.io/@std/internal/1.0.13/styles.js +207 -0
  113. package/esm/deps/jsr.io/@std/internal/1.0.13/types.d.ts +25 -0
  114. package/esm/deps/jsr.io/@std/internal/1.0.13/types.d.ts.map +1 -0
  115. package/esm/deps/jsr.io/@std/internal/1.0.13/types.js +3 -0
  116. package/esm/deps/jsr.io/@std/testing/1.0.18/_test_suite.d.ts +80 -0
  117. package/esm/deps/jsr.io/@std/testing/1.0.18/_test_suite.d.ts.map +1 -0
  118. package/esm/deps/jsr.io/@std/testing/1.0.18/_test_suite.js +348 -0
  119. package/esm/deps/jsr.io/@std/testing/1.0.18/bdd.d.ts +738 -0
  120. package/esm/deps/jsr.io/@std/testing/1.0.18/bdd.d.ts.map +1 -0
  121. package/esm/deps/jsr.io/@std/testing/1.0.18/bdd.js +656 -0
  122. package/esm/src/agent/fork-runtime-stream.d.ts +143 -0
  123. package/esm/src/agent/fork-runtime-stream.d.ts.map +1 -0
  124. package/esm/src/agent/fork-runtime-stream.js +505 -0
  125. package/esm/src/agent/index.d.ts +1 -0
  126. package/esm/src/agent/index.d.ts.map +1 -1
  127. package/esm/src/agent/index.js +1 -0
  128. package/esm/src/chat/conversation.d.ts +5 -5
  129. package/esm/src/modules/index.d.ts +12 -0
  130. package/esm/src/modules/index.d.ts.map +1 -0
  131. package/esm/src/modules/index.js +10 -0
  132. package/esm/src/modules/module-resolver.d.ts +28 -0
  133. package/esm/src/modules/module-resolver.d.ts.map +1 -0
  134. package/esm/src/modules/module-resolver.js +106 -0
  135. package/esm/src/rendering/cleanup.d.ts +7 -0
  136. package/esm/src/rendering/cleanup.d.ts.map +1 -0
  137. package/esm/src/rendering/cleanup.js +22 -0
  138. package/esm/src/rendering/ssr/index.d.ts +10 -0
  139. package/esm/src/rendering/ssr/index.d.ts.map +1 -0
  140. package/esm/src/rendering/ssr/index.js +8 -0
  141. package/esm/src/rendering/ssr/mdx-module-loader.d.ts +5 -0
  142. package/esm/src/rendering/ssr/mdx-module-loader.d.ts.map +1 -0
  143. package/esm/src/rendering/ssr/mdx-module-loader.js +150 -0
  144. package/esm/src/rendering/ssr/mdx-renderer.d.ts +4 -0
  145. package/esm/src/rendering/ssr/mdx-renderer.d.ts.map +1 -0
  146. package/esm/src/rendering/ssr/mdx-renderer.js +44 -0
  147. package/esm/src/rendering/ssr/types.d.ts +13 -0
  148. package/esm/src/rendering/ssr/types.d.ts.map +1 -0
  149. package/esm/src/rendering/ssr/types.js +1 -0
  150. package/esm/src/sandbox/index.d.ts +1 -0
  151. package/esm/src/sandbox/index.d.ts.map +1 -1
  152. package/esm/src/sandbox/index.js +1 -0
  153. package/esm/src/sandbox/shell-tools.d.ts +39 -0
  154. package/esm/src/sandbox/shell-tools.d.ts.map +1 -0
  155. package/esm/src/sandbox/shell-tools.js +177 -0
  156. package/esm/src/server/shared/index.d.ts +7 -0
  157. package/esm/src/server/shared/index.d.ts.map +1 -0
  158. package/esm/src/server/shared/index.js +6 -0
  159. package/esm/src/testing/assert.d.ts +22 -0
  160. package/esm/src/testing/assert.d.ts.map +1 -0
  161. package/esm/src/testing/assert.js +217 -0
  162. package/esm/src/testing/bdd.d.ts +67 -0
  163. package/esm/src/testing/bdd.d.ts.map +1 -0
  164. package/esm/src/testing/bdd.js +401 -0
  165. package/esm/src/testing/deno-compat.d.ts +26 -0
  166. package/esm/src/testing/deno-compat.d.ts.map +1 -0
  167. package/esm/src/testing/deno-compat.js +146 -0
  168. package/esm/src/testing/index.d.ts +28 -0
  169. package/esm/src/testing/index.d.ts.map +1 -0
  170. package/esm/src/testing/index.js +27 -0
  171. package/esm/src/testing/init.d.ts +2 -0
  172. package/esm/src/testing/init.d.ts.map +1 -0
  173. package/esm/src/testing/init.js +18 -0
  174. package/esm/src/testing/isolation.d.ts +30 -0
  175. package/esm/src/testing/isolation.d.ts.map +1 -0
  176. package/esm/src/testing/isolation.js +151 -0
  177. package/esm/src/testing/timing.d.ts +4 -0
  178. package/esm/src/testing/timing.d.ts.map +1 -0
  179. package/esm/src/testing/timing.js +22 -0
  180. package/esm/src/testing/utils.d.ts +6 -0
  181. package/esm/src/testing/utils.d.ts.map +1 -0
  182. package/esm/src/testing/utils.js +49 -0
  183. package/esm/src/types/global-guards.d.ts +11 -0
  184. package/esm/src/types/global-guards.d.ts.map +1 -0
  185. package/esm/src/types/global-guards.js +12 -0
  186. package/esm/src/utils/cache/keys/namespace.d.ts +3 -0
  187. package/esm/src/utils/cache/keys/namespace.d.ts.map +1 -0
  188. package/esm/src/utils/cache/keys/namespace.js +19 -0
  189. package/esm/src/utils/clsx.d.ts +3 -3
  190. package/esm/src/utils/clsx.d.ts.map +1 -1
  191. package/esm/src/utils/clsx.js +2 -3
  192. package/esm/src/utils/mime-types.d.ts +0 -6
  193. package/esm/src/utils/mime-types.d.ts.map +1 -1
  194. package/esm/src/utils/mime-types.js +0 -1
  195. package/esm/src/utils/version-constant.d.ts +1 -1
  196. package/esm/src/utils/version-constant.js +1 -1
  197. package/package.json +14 -1
  198. package/src/cli/commands/extension/init-command.ts +2 -2
  199. package/src/cli/commands/extension/validate-command.ts +1 -1
  200. package/src/deno.js +8 -1
  201. package/src/deps/esm.sh/@types/react-dom@19.2.3/client.d.ts +105 -0
  202. package/src/deps/esm.sh/@types/react@19.2.3/global.d.ts +165 -0
  203. package/src/deps/esm.sh/@types/react@19.2.3/index.d.ts +4301 -0
  204. package/src/deps/esm.sh/@types/scheduler@0.26.0/index.d.ts +30 -0
  205. package/src/deps/esm.sh/csstype@3.2.3/index.d.ts +22569 -0
  206. package/src/deps/esm.sh/react-dom@19.2.4/client.d.ts +105 -0
  207. package/src/deps/esm.sh/react-dom@19.2.4/client.js +5 -0
  208. package/src/deps/esm.sh/scheduler@^0.27.0.d.ts +30 -0
  209. package/src/deps/esm.sh/scheduler@^0.27.0.js +3 -0
  210. package/src/deps/jsr.io/@std/assert/1.0.19/almost_equals.ts +56 -0
  211. package/src/deps/jsr.io/@std/assert/1.0.19/array_includes.ts +76 -0
  212. package/src/deps/jsr.io/@std/assert/1.0.19/assert.ts +24 -0
  213. package/src/deps/jsr.io/@std/assert/1.0.19/assertion_error.ts +31 -0
  214. package/src/deps/jsr.io/@std/assert/1.0.19/equal.ts +226 -0
  215. package/src/deps/jsr.io/@std/assert/1.0.19/equals.ts +68 -0
  216. package/src/deps/jsr.io/@std/assert/1.0.19/exists.ts +31 -0
  217. package/src/deps/jsr.io/@std/assert/1.0.19/fail.ts +21 -0
  218. package/src/deps/jsr.io/@std/assert/1.0.19/false.ts +27 -0
  219. package/src/deps/jsr.io/@std/assert/1.0.19/greater.ts +30 -0
  220. package/src/deps/jsr.io/@std/assert/1.0.19/greater_or_equal.ts +36 -0
  221. package/src/deps/jsr.io/@std/assert/1.0.19/instance_of.ts +64 -0
  222. package/src/deps/jsr.io/@std/assert/1.0.19/is_error.ts +65 -0
  223. package/src/deps/jsr.io/@std/assert/1.0.19/less.ts +29 -0
  224. package/src/deps/jsr.io/@std/assert/1.0.19/less_or_equal.ts +36 -0
  225. package/src/deps/jsr.io/@std/assert/1.0.19/match.ts +30 -0
  226. package/src/deps/jsr.io/@std/assert/1.0.19/mod.ts +47 -0
  227. package/src/deps/jsr.io/@std/assert/1.0.19/not_equals.ts +43 -0
  228. package/src/deps/jsr.io/@std/assert/1.0.19/not_instance_of.ts +33 -0
  229. package/src/deps/jsr.io/@std/assert/1.0.19/not_match.ts +30 -0
  230. package/src/deps/jsr.io/@std/assert/1.0.19/not_strict_equals.ts +42 -0
  231. package/src/deps/jsr.io/@std/assert/1.0.19/object_match.ts +224 -0
  232. package/src/deps/jsr.io/@std/assert/1.0.19/rejects.ts +123 -0
  233. package/src/deps/jsr.io/@std/assert/1.0.19/strict_equals.ts +68 -0
  234. package/src/deps/jsr.io/@std/assert/1.0.19/string_includes.ts +30 -0
  235. package/src/deps/jsr.io/@std/assert/1.0.19/throws.ts +111 -0
  236. package/src/deps/jsr.io/@std/assert/1.0.19/unimplemented.ts +21 -0
  237. package/src/deps/jsr.io/@std/assert/1.0.19/unreachable.ts +21 -0
  238. package/src/deps/jsr.io/@std/internal/1.0.13/assertion_state.ts +248 -0
  239. package/src/deps/jsr.io/@std/internal/1.0.13/build_message.ts +147 -0
  240. package/src/deps/jsr.io/@std/internal/1.0.13/diff.ts +317 -0
  241. package/src/deps/jsr.io/@std/internal/1.0.13/diff_str.ts +208 -0
  242. package/src/deps/jsr.io/@std/internal/1.0.13/format.ts +89 -0
  243. package/src/deps/jsr.io/@std/internal/1.0.13/styles.ts +233 -0
  244. package/src/deps/jsr.io/@std/internal/1.0.13/types.ts +30 -0
  245. package/src/deps/jsr.io/@std/testing/1.0.18/_test_suite.ts +461 -0
  246. package/src/deps/jsr.io/@std/testing/1.0.18/bdd.ts +1294 -0
  247. package/src/src/agent/fork-runtime-stream.ts +780 -0
  248. package/src/src/agent/index.ts +16 -0
  249. package/src/src/modules/index.ts +43 -0
  250. package/src/src/modules/module-resolver.ts +145 -0
  251. package/src/src/rendering/cleanup.ts +27 -0
  252. package/src/src/rendering/ssr/index.ts +10 -0
  253. package/src/src/rendering/ssr/mdx-module-loader.ts +185 -0
  254. package/src/src/rendering/ssr/mdx-renderer.ts +66 -0
  255. package/src/src/rendering/ssr/types.ts +14 -0
  256. package/src/src/sandbox/index.ts +9 -0
  257. package/src/src/sandbox/shell-tools.ts +242 -0
  258. package/src/src/server/shared/index.ts +12 -0
  259. package/src/src/testing/assert.ts +352 -0
  260. package/src/src/testing/bdd.ts +618 -0
  261. package/src/src/testing/deno-compat.ts +206 -0
  262. package/src/src/testing/index.ts +92 -0
  263. package/src/src/testing/init.ts +21 -0
  264. package/src/src/testing/isolation.ts +177 -0
  265. package/src/src/testing/timing.ts +27 -0
  266. package/src/src/testing/utils.ts +44 -0
  267. package/src/src/types/global-guards.ts +21 -0
  268. package/src/src/utils/cache/keys/namespace.ts +25 -0
  269. package/src/src/utils/clsx.ts +2 -4
  270. package/src/src/utils/mime-types.ts +0 -2
  271. package/src/src/utils/version-constant.ts +1 -1
@@ -0,0 +1,224 @@
1
+ // Copyright 2018-2026 the Deno authors. MIT license.
2
+ // This module is browser compatible.
3
+ /**
4
+ * Check the test suite internal state
5
+ *
6
+ * @example Usage
7
+ * ```ts ignore
8
+ * import { AssertionState } from "@std/internal";
9
+ *
10
+ * const assertionState = new AssertionState();
11
+ * ```
12
+ */
13
+ import * as dntShim from "../../../../../_dnt.shims.js";
14
+ export class AssertionState {
15
+ #state;
16
+ constructor() {
17
+ this.#state = {
18
+ assertionCount: undefined,
19
+ assertionCheck: false,
20
+ assertionTriggered: false,
21
+ assertionTriggeredCount: 0,
22
+ };
23
+ if (typeof globalThis?.addEventListener === "function") {
24
+ globalThis.addEventListener("unload", () => {
25
+ this.#ensureCleanedUp();
26
+ });
27
+ }
28
+ else if (
29
+ // deno-lint-ignore no-explicit-any
30
+ typeof dntShim.dntGlobalThis?.process?.on === "function") {
31
+ // deno-lint-ignore no-explicit-any
32
+ dntShim.dntGlobalThis.process.on("exit", () => {
33
+ this.#ensureCleanedUp();
34
+ });
35
+ }
36
+ else {
37
+ // deno-lint-ignore no-console
38
+ console.warn("AssertionCounter cleanup step was not registered");
39
+ }
40
+ }
41
+ #ensureCleanedUp() {
42
+ // If any checks were registered, after the test suite runs the checks,
43
+ // `resetAssertionState` should also have been called. If it was not,
44
+ // then the test suite did not run the checks.
45
+ if (this.#state.assertionCheck ||
46
+ this.#state.assertionCount !== undefined) {
47
+ throw new Error("AssertionCounter was not cleaned up: If tests are not otherwise failing, ensure `expect.hasAssertion` and `expect.assertions` are only run in bdd tests");
48
+ }
49
+ }
50
+ /**
51
+ * Get the number that through `expect.assertions` api set.
52
+ *
53
+ * @returns the number that through `expect.assertions` api set.
54
+ *
55
+ * @example Usage
56
+ * ```ts ignore
57
+ * import { AssertionState } from "@std/internal";
58
+ *
59
+ * const assertionState = new AssertionState();
60
+ * assertionState.assertionCount;
61
+ * ```
62
+ */
63
+ get assertionCount() {
64
+ return this.#state.assertionCount;
65
+ }
66
+ /**
67
+ * Get a certain number that assertions were called before.
68
+ *
69
+ * @returns return a certain number that assertions were called before.
70
+ *
71
+ * @example Usage
72
+ * ```ts ignore
73
+ * import { AssertionState } from "@std/internal";
74
+ *
75
+ * const assertionState = new AssertionState();
76
+ * assertionState.assertionTriggeredCount;
77
+ * ```
78
+ */
79
+ get assertionTriggeredCount() {
80
+ return this.#state.assertionTriggeredCount;
81
+ }
82
+ /**
83
+ * If `expect.hasAssertions` called, then through this method to update #state.assertionCheck value.
84
+ *
85
+ * @param val Set #state.assertionCheck's value
86
+ *
87
+ * @example Usage
88
+ * ```ts ignore
89
+ * import { AssertionState } from "@std/internal";
90
+ *
91
+ * const assertionState = new AssertionState();
92
+ * assertionState.setAssertionCheck(true);
93
+ * ```
94
+ */
95
+ setAssertionCheck(val) {
96
+ this.#state.assertionCheck = val;
97
+ }
98
+ /**
99
+ * If any matchers was called, `#state.assertionTriggered` will be set through this method.
100
+ *
101
+ * @param val Set #state.assertionTriggered's value
102
+ *
103
+ * @example Usage
104
+ * ```ts ignore
105
+ * import { AssertionState } from "@std/internal";
106
+ *
107
+ * const assertionState = new AssertionState();
108
+ * assertionState.setAssertionTriggered(true);
109
+ * ```
110
+ */
111
+ setAssertionTriggered(val) {
112
+ this.#state.assertionTriggered = val;
113
+ }
114
+ /**
115
+ * If `expect.assertions` called, then through this method to update #state.assertionCheck value.
116
+ *
117
+ * @param num Set #state.assertionCount's value, for example if the value is set 2, that means
118
+ * you must have two assertion matchers call in your test suite.
119
+ *
120
+ * @example Usage
121
+ * ```ts ignore
122
+ * import { AssertionState } from "@std/internal";
123
+ *
124
+ * const assertionState = new AssertionState();
125
+ * assertionState.setAssertionCount(2);
126
+ * ```
127
+ */
128
+ setAssertionCount(num) {
129
+ this.#state.assertionCount = num;
130
+ }
131
+ /**
132
+ * If any matchers was called, `#state.assertionTriggeredCount` value will plus one internally.
133
+ *
134
+ * @example Usage
135
+ * ```ts ignore
136
+ * import { AssertionState } from "@std/internal";
137
+ *
138
+ * const assertionState = new AssertionState();
139
+ * assertionState.updateAssertionTriggerCount();
140
+ * ```
141
+ */
142
+ updateAssertionTriggerCount() {
143
+ if (this.#state.assertionCount !== undefined) {
144
+ this.#state.assertionTriggeredCount += 1;
145
+ }
146
+ }
147
+ /**
148
+ * Check Assertion internal state, if `#state.assertionCheck` is set true, but
149
+ * `#state.assertionTriggered` is still false, then should throw an Assertion Error.
150
+ *
151
+ * @returns a boolean value, that the test suite is satisfied with the check. If not,
152
+ * it should throw an AssertionError.
153
+ *
154
+ * @example Usage
155
+ * ```ts ignore
156
+ * import { AssertionState } from "@std/internal";
157
+ *
158
+ * const assertionState = new AssertionState();
159
+ * if (assertionState.checkAssertionErrorState()) {
160
+ * // throw AssertionError("");
161
+ * }
162
+ * ```
163
+ */
164
+ checkAssertionErrorState() {
165
+ return this.#state.assertionCheck && !this.#state.assertionTriggered;
166
+ }
167
+ /**
168
+ * Reset all assertion state when every test suite function ran completely.
169
+ *
170
+ * @example Usage
171
+ * ```ts ignore
172
+ * import { AssertionState } from "@std/internal";
173
+ *
174
+ * const assertionState = new AssertionState();
175
+ * assertionState.resetAssertionState();
176
+ * ```
177
+ */
178
+ resetAssertionState() {
179
+ this.#state = {
180
+ assertionCount: undefined,
181
+ assertionCheck: false,
182
+ assertionTriggered: false,
183
+ assertionTriggeredCount: 0,
184
+ };
185
+ }
186
+ /**
187
+ * Check Assertion called state, if `#state.assertionCount` is set to a number value, but
188
+ * `#state.assertionTriggeredCount` is less then it, then should throw an assertion error.
189
+ *
190
+ * @returns a boolean value, that the test suite is satisfied with the check. If not,
191
+ * it should throw an AssertionError.
192
+ *
193
+ * @example Usage
194
+ * ```ts ignore
195
+ * import { AssertionState } from "@std/internal";
196
+ *
197
+ * const assertionState = new AssertionState();
198
+ * if (assertionState.checkAssertionCountSatisfied()) {
199
+ * // throw AssertionError("");
200
+ * }
201
+ * ```
202
+ */
203
+ checkAssertionCountSatisfied() {
204
+ return this.#state.assertionCount !== undefined &&
205
+ this.#state.assertionCount !== this.#state.assertionTriggeredCount;
206
+ }
207
+ }
208
+ const assertionState = new AssertionState();
209
+ /**
210
+ * return an instance of AssertionState
211
+ *
212
+ * @returns AssertionState
213
+ *
214
+ * @example Usage
215
+ * ```ts ignore
216
+ * import { getAssertionState } from "@std/internal";
217
+ *
218
+ * const assertionState = getAssertionState();
219
+ * assertionState.setAssertionTriggered(true);
220
+ * ```
221
+ */
222
+ export function getAssertionState() {
223
+ return assertionState;
224
+ }
@@ -0,0 +1,80 @@
1
+ import type { DiffResult, DiffType } from "./types.js";
2
+ /**
3
+ * Colors the output of assertion diffs.
4
+ *
5
+ * @param diffType Difference type, either added or removed.
6
+ * @param background If true, colors the background instead of the text.
7
+ *
8
+ * @returns A function that colors the input string.
9
+ *
10
+ * @example Usage
11
+ * ```ts
12
+ * import { createColor } from "@std/internal";
13
+ * import { assertEquals } from "@std/assert";
14
+ * import { bold, green, red, white } from "@std/fmt/colors";
15
+ *
16
+ * assertEquals(createColor("added")("foo"), green(bold("foo")));
17
+ * assertEquals(createColor("removed")("foo"), red(bold("foo")));
18
+ * assertEquals(createColor("common")("foo"), white("foo"));
19
+ * ```
20
+ */
21
+ export declare function createColor(diffType: DiffType,
22
+ /**
23
+ * TODO(@littledivy): Remove this when we can detect true color terminals. See
24
+ * https://github.com/denoland/std/issues/2575.
25
+ */
26
+ background?: boolean): (s: string) => string;
27
+ /**
28
+ * Prefixes `+` or `-` in diff output.
29
+ *
30
+ * @param diffType Difference type, either added or removed
31
+ *
32
+ * @returns A string representing the sign.
33
+ *
34
+ * @example Usage
35
+ * ```ts
36
+ * import { createSign } from "@std/internal";
37
+ * import { assertEquals } from "@std/assert";
38
+ *
39
+ * assertEquals(createSign("added"), "+ ");
40
+ * assertEquals(createSign("removed"), "- ");
41
+ * assertEquals(createSign("common"), " ");
42
+ * ```
43
+ */
44
+ export declare function createSign(diffType: DiffType): string;
45
+ /** Options for {@linkcode buildMessage}. */
46
+ export interface BuildMessageOptions {
47
+ /**
48
+ * Whether to output the diff as a single string.
49
+ * @default {false}
50
+ */
51
+ stringDiff?: boolean;
52
+ }
53
+ /**
54
+ * Builds a message based on the provided diff result.
55
+ *
56
+ * @param diffResult The diff result array.
57
+ * @param options Optional parameters for customizing the message.
58
+ * @param truncateDiff Function to truncate the diff (default is no truncation).
59
+ *
60
+ * @returns An array of strings representing the built message.
61
+ *
62
+ * @example Usage
63
+ * ```ts no-assert
64
+ * import { diffStr, buildMessage } from "@std/internal";
65
+ *
66
+ * diffStr("Hello, world!", "Hello, world");
67
+ * // [
68
+ * // "",
69
+ * // "",
70
+ * // " [Diff] Actual / Expected",
71
+ * // "",
72
+ * // "",
73
+ * // "- Hello, world!",
74
+ * // "+ Hello, world",
75
+ * // "",
76
+ * // ]
77
+ * ```
78
+ */
79
+ export declare function buildMessage(diffResult: ReadonlyArray<DiffResult<string>>, options?: BuildMessageOptions, truncateDiff?: (diffResult: ReadonlyArray<DiffResult<string>>, stringDiff: boolean, contextLength?: number | null) => ReadonlyArray<DiffResult<string>>): string[];
80
+ //# sourceMappingURL=build_message.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build_message.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/internal/1.0.13/build_message.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEvD;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,WAAW,CACzB,QAAQ,EAAE,QAAQ;AAClB;;;GAGG;AACH,UAAU,UAAQ,GACjB,CAAC,CAAC,EAAE,MAAM,KAAK,MAAM,CAWvB;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,UAAU,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM,CASrD;AAED,4CAA4C;AAC5C,MAAM,WAAW,mBAAmB;IAClC;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,wBAAgB,YAAY,CAC1B,UAAU,EAAE,aAAa,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAC7C,OAAO,GAAE,mBAAwB,EACjC,YAAY,CAAC,EAAE,CACb,UAAU,EAAE,aAAa,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAC7C,UAAU,EAAE,OAAO,EACnB,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,KAC1B,aAAa,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,GACrC,MAAM,EAAE,CA8BV"}
@@ -0,0 +1,116 @@
1
+ // Copyright 2018-2026 the Deno authors. MIT license.
2
+ // This module is browser compatible.
3
+ import { bgGreen, bgRed, bold, gray, green, red, white } from "./styles.js";
4
+ /**
5
+ * Colors the output of assertion diffs.
6
+ *
7
+ * @param diffType Difference type, either added or removed.
8
+ * @param background If true, colors the background instead of the text.
9
+ *
10
+ * @returns A function that colors the input string.
11
+ *
12
+ * @example Usage
13
+ * ```ts
14
+ * import { createColor } from "@std/internal";
15
+ * import { assertEquals } from "@std/assert";
16
+ * import { bold, green, red, white } from "@std/fmt/colors";
17
+ *
18
+ * assertEquals(createColor("added")("foo"), green(bold("foo")));
19
+ * assertEquals(createColor("removed")("foo"), red(bold("foo")));
20
+ * assertEquals(createColor("common")("foo"), white("foo"));
21
+ * ```
22
+ */
23
+ export function createColor(diffType,
24
+ /**
25
+ * TODO(@littledivy): Remove this when we can detect true color terminals. See
26
+ * https://github.com/denoland/std/issues/2575.
27
+ */
28
+ background = false) {
29
+ switch (diffType) {
30
+ case "added":
31
+ return (s) => background ? bgGreen(white(s)) : green(bold(s));
32
+ case "removed":
33
+ return (s) => background ? bgRed(white(s)) : red(bold(s));
34
+ case "truncation":
35
+ return gray;
36
+ default:
37
+ return white;
38
+ }
39
+ }
40
+ /**
41
+ * Prefixes `+` or `-` in diff output.
42
+ *
43
+ * @param diffType Difference type, either added or removed
44
+ *
45
+ * @returns A string representing the sign.
46
+ *
47
+ * @example Usage
48
+ * ```ts
49
+ * import { createSign } from "@std/internal";
50
+ * import { assertEquals } from "@std/assert";
51
+ *
52
+ * assertEquals(createSign("added"), "+ ");
53
+ * assertEquals(createSign("removed"), "- ");
54
+ * assertEquals(createSign("common"), " ");
55
+ * ```
56
+ */
57
+ export function createSign(diffType) {
58
+ switch (diffType) {
59
+ case "added":
60
+ return "+ ";
61
+ case "removed":
62
+ return "- ";
63
+ default:
64
+ return " ";
65
+ }
66
+ }
67
+ /**
68
+ * Builds a message based on the provided diff result.
69
+ *
70
+ * @param diffResult The diff result array.
71
+ * @param options Optional parameters for customizing the message.
72
+ * @param truncateDiff Function to truncate the diff (default is no truncation).
73
+ *
74
+ * @returns An array of strings representing the built message.
75
+ *
76
+ * @example Usage
77
+ * ```ts no-assert
78
+ * import { diffStr, buildMessage } from "@std/internal";
79
+ *
80
+ * diffStr("Hello, world!", "Hello, world");
81
+ * // [
82
+ * // "",
83
+ * // "",
84
+ * // " [Diff] Actual / Expected",
85
+ * // "",
86
+ * // "",
87
+ * // "- Hello, world!",
88
+ * // "+ Hello, world",
89
+ * // "",
90
+ * // ]
91
+ * ```
92
+ */
93
+ export function buildMessage(diffResult, options = {}, truncateDiff) {
94
+ if (truncateDiff != null) {
95
+ diffResult = truncateDiff(diffResult, options.stringDiff ?? false);
96
+ }
97
+ const { stringDiff = false } = options;
98
+ const messages = [
99
+ "",
100
+ "",
101
+ ` ${gray(bold("[Diff]"))} ${red(bold("Actual"))} / ${green(bold("Expected"))}`,
102
+ "",
103
+ "",
104
+ ];
105
+ const diffMessages = diffResult.map((result) => {
106
+ const color = createColor(result.type);
107
+ const line = result.type === "added" || result.type === "removed"
108
+ ? result.details?.map((detail) => detail.type !== "common"
109
+ ? createColor(detail.type, true)(detail.value)
110
+ : detail.value).join("") ?? result.value
111
+ : result.value;
112
+ return color(`${createSign(result.type)}${line}`);
113
+ });
114
+ messages.push(...(stringDiff ? [diffMessages.join("")] : diffMessages), "");
115
+ return messages;
116
+ }
@@ -0,0 +1,140 @@
1
+ import type { DiffResult, DiffType } from "./types.js";
2
+ /** Represents the farthest point in the diff algorithm. */
3
+ export interface FarthestPoint {
4
+ /** The y-coordinate of the point. */
5
+ y: number;
6
+ /** The id of the point. */
7
+ id: number;
8
+ }
9
+ /**
10
+ * Creates an array of common elements between two arrays.
11
+ *
12
+ * @typeParam T The type of elements in the arrays.
13
+ *
14
+ * @param A The first array.
15
+ * @param B The second array.
16
+ *
17
+ * @returns An array containing the common elements between the two arrays.
18
+ *
19
+ * @example Usage
20
+ * ```ts
21
+ * import { createCommon } from "@std/internal/diff";
22
+ * import { assertEquals } from "@std/assert";
23
+ *
24
+ * const a = [1, 2, 3];
25
+ * const b = [1, 2, 4];
26
+ *
27
+ * assertEquals(createCommon(a, b), [1, 2]);
28
+ * ```
29
+ */
30
+ export declare function createCommon<T>(A: T[], B: T[]): T[];
31
+ /**
32
+ * Asserts that the value is a {@linkcode FarthestPoint}.
33
+ * If not, an error is thrown.
34
+ *
35
+ * @param value The value to check.
36
+ *
37
+ * @returns A void value that returns once the assertion completes.
38
+ *
39
+ * @example Usage
40
+ * ```ts
41
+ * import { assertFp } from "@std/internal/diff";
42
+ * import { assertThrows } from "@std/assert";
43
+ *
44
+ * assertFp({ y: 0, id: 0 });
45
+ * assertThrows(() => assertFp({ id: 0 }));
46
+ * assertThrows(() => assertFp({ y: 0 }));
47
+ * assertThrows(() => assertFp(undefined));
48
+ * ```
49
+ */
50
+ export declare function assertFp(value: unknown): asserts value is FarthestPoint;
51
+ /**
52
+ * Creates an array of backtraced differences.
53
+ *
54
+ * @typeParam T The type of elements in the arrays.
55
+ *
56
+ * @param A The first array.
57
+ * @param B The second array.
58
+ * @param current The current {@linkcode FarthestPoint}.
59
+ * @param swapped Boolean indicating if the arrays are swapped.
60
+ * @param routes The routes array.
61
+ * @param diffTypesPtrOffset The offset of the diff types in the routes array.
62
+ *
63
+ * @returns An array of backtraced differences.
64
+ *
65
+ * @example Usage
66
+ * ```ts
67
+ * import { backTrace } from "@std/internal/diff";
68
+ * import { assertEquals } from "@std/assert";
69
+ *
70
+ * assertEquals(
71
+ * backTrace([], [], { y: 0, id: 0 }, false, new Uint32Array(0), 0),
72
+ * [],
73
+ * );
74
+ * ```
75
+ */
76
+ export declare function backTrace<T>(A: T[], B: T[], current: FarthestPoint, swapped: boolean, routes: Uint32Array, diffTypesPtrOffset: number): Array<{
77
+ type: DiffType;
78
+ value: T;
79
+ }>;
80
+ /**
81
+ * Creates a {@linkcode FarthestPoint}.
82
+ *
83
+ * @param k The current index.
84
+ * @param M The length of the first array.
85
+ * @param routes The routes array.
86
+ * @param diffTypesPtrOffset The offset of the diff types in the routes array.
87
+ * @param ptr The current pointer.
88
+ * @param slide The slide {@linkcode FarthestPoint}.
89
+ * @param down The down {@linkcode FarthestPoint}.
90
+ *
91
+ * @returns A {@linkcode FarthestPoint}.
92
+ *
93
+ * @example Usage
94
+ * ```ts
95
+ * import { createFp } from "@std/internal/diff";
96
+ * import { assertEquals } from "@std/assert";
97
+ *
98
+ * assertEquals(
99
+ * createFp(
100
+ * 0,
101
+ * 0,
102
+ * new Uint32Array(0),
103
+ * 0,
104
+ * 0,
105
+ * { y: -1, id: 0 },
106
+ * { y: 0, id: 0 },
107
+ * ),
108
+ * { y: -1, id: 1 },
109
+ * );
110
+ * ```
111
+ */
112
+ export declare function createFp(k: number, M: number, routes: Uint32Array, diffTypesPtrOffset: number, ptr: number, slide?: FarthestPoint, down?: FarthestPoint): FarthestPoint;
113
+ /**
114
+ * Renders the differences between the actual and expected values.
115
+ *
116
+ * @typeParam T The type of elements in the arrays.
117
+ *
118
+ * @param A Actual value
119
+ * @param B Expected value
120
+ *
121
+ * @returns An array of differences between the actual and expected values.
122
+ *
123
+ * @example Usage
124
+ * ```ts
125
+ * import { diff } from "@std/internal/diff";
126
+ * import { assertEquals } from "@std/assert";
127
+ *
128
+ * const a = [1, 2, 3];
129
+ * const b = [1, 2, 4];
130
+ *
131
+ * assertEquals(diff(a, b), [
132
+ * { type: "common", value: 1 },
133
+ * { type: "common", value: 2 },
134
+ * { type: "removed", value: 3 },
135
+ * { type: "added", value: 4 },
136
+ * ]);
137
+ * ```
138
+ */
139
+ export declare function diff<T>(A: T[], B: T[]): DiffResult<T>[];
140
+ //# sourceMappingURL=diff.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"diff.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/internal/1.0.13/diff.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEvD,2DAA2D;AAC3D,MAAM,WAAW,aAAa;IAC5B,qCAAqC;IACrC,CAAC,EAAE,MAAM,CAAC;IACV,2BAA2B;IAC3B,EAAE,EAAE,MAAM,CAAC;CACZ;AAMD;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,YAAY,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,CAanD;AAED;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,KAAK,IAAI,aAAa,CAWvE;AAED;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,wBAAgB,SAAS,CAAC,CAAC,EACzB,CAAC,EAAE,CAAC,EAAE,EACN,CAAC,EAAE,CAAC,EAAE,EACN,OAAO,EAAE,aAAa,EACtB,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,WAAW,EACnB,kBAAkB,EAAE,MAAM,GACzB,KAAK,CAAC;IACP,IAAI,EAAE,QAAQ,CAAC;IACf,KAAK,EAAE,CAAC,CAAC;CACV,CAAC,CAgCD;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AACH,wBAAgB,QAAQ,CACtB,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,MAAM,EAAE,WAAW,EACnB,kBAAkB,EAAE,MAAM,EAC1B,GAAG,EAAE,MAAM,EACX,KAAK,CAAC,EAAE,aAAa,EACrB,IAAI,CAAC,EAAE,aAAa,GACnB,aAAa,CAsBf;AAED;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,wBAAgB,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC,EAAE,CAwEvD"}