veryfront 0.1.324 → 0.1.327

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 (277) 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/hosted-child-fork-stream-execution.d.ts +130 -0
  126. package/esm/src/agent/hosted-child-fork-stream-execution.d.ts.map +1 -0
  127. package/esm/src/agent/hosted-child-fork-stream-execution.js +391 -0
  128. package/esm/src/agent/index.d.ts +2 -0
  129. package/esm/src/agent/index.d.ts.map +1 -1
  130. package/esm/src/agent/index.js +2 -0
  131. package/esm/src/chat/conversation.d.ts +5 -5
  132. package/esm/src/chat/final-step-fallback.js +2 -2
  133. package/esm/src/modules/index.d.ts +12 -0
  134. package/esm/src/modules/index.d.ts.map +1 -0
  135. package/esm/src/modules/index.js +10 -0
  136. package/esm/src/modules/module-resolver.d.ts +28 -0
  137. package/esm/src/modules/module-resolver.d.ts.map +1 -0
  138. package/esm/src/modules/module-resolver.js +106 -0
  139. package/esm/src/rendering/cleanup.d.ts +7 -0
  140. package/esm/src/rendering/cleanup.d.ts.map +1 -0
  141. package/esm/src/rendering/cleanup.js +22 -0
  142. package/esm/src/rendering/ssr/index.d.ts +10 -0
  143. package/esm/src/rendering/ssr/index.d.ts.map +1 -0
  144. package/esm/src/rendering/ssr/index.js +8 -0
  145. package/esm/src/rendering/ssr/mdx-module-loader.d.ts +5 -0
  146. package/esm/src/rendering/ssr/mdx-module-loader.d.ts.map +1 -0
  147. package/esm/src/rendering/ssr/mdx-module-loader.js +150 -0
  148. package/esm/src/rendering/ssr/mdx-renderer.d.ts +4 -0
  149. package/esm/src/rendering/ssr/mdx-renderer.d.ts.map +1 -0
  150. package/esm/src/rendering/ssr/mdx-renderer.js +44 -0
  151. package/esm/src/rendering/ssr/types.d.ts +13 -0
  152. package/esm/src/rendering/ssr/types.d.ts.map +1 -0
  153. package/esm/src/rendering/ssr/types.js +1 -0
  154. package/esm/src/sandbox/index.d.ts +1 -0
  155. package/esm/src/sandbox/index.d.ts.map +1 -1
  156. package/esm/src/sandbox/index.js +1 -0
  157. package/esm/src/sandbox/shell-tools.d.ts +39 -0
  158. package/esm/src/sandbox/shell-tools.d.ts.map +1 -0
  159. package/esm/src/sandbox/shell-tools.js +177 -0
  160. package/esm/src/server/shared/index.d.ts +7 -0
  161. package/esm/src/server/shared/index.d.ts.map +1 -0
  162. package/esm/src/server/shared/index.js +6 -0
  163. package/esm/src/testing/assert.d.ts +22 -0
  164. package/esm/src/testing/assert.d.ts.map +1 -0
  165. package/esm/src/testing/assert.js +217 -0
  166. package/esm/src/testing/bdd.d.ts +67 -0
  167. package/esm/src/testing/bdd.d.ts.map +1 -0
  168. package/esm/src/testing/bdd.js +401 -0
  169. package/esm/src/testing/deno-compat.d.ts +26 -0
  170. package/esm/src/testing/deno-compat.d.ts.map +1 -0
  171. package/esm/src/testing/deno-compat.js +146 -0
  172. package/esm/src/testing/index.d.ts +28 -0
  173. package/esm/src/testing/index.d.ts.map +1 -0
  174. package/esm/src/testing/index.js +27 -0
  175. package/esm/src/testing/init.d.ts +2 -0
  176. package/esm/src/testing/init.d.ts.map +1 -0
  177. package/esm/src/testing/init.js +18 -0
  178. package/esm/src/testing/isolation.d.ts +30 -0
  179. package/esm/src/testing/isolation.d.ts.map +1 -0
  180. package/esm/src/testing/isolation.js +151 -0
  181. package/esm/src/testing/timing.d.ts +4 -0
  182. package/esm/src/testing/timing.d.ts.map +1 -0
  183. package/esm/src/testing/timing.js +22 -0
  184. package/esm/src/testing/utils.d.ts +6 -0
  185. package/esm/src/testing/utils.d.ts.map +1 -0
  186. package/esm/src/testing/utils.js +49 -0
  187. package/esm/src/types/global-guards.d.ts +11 -0
  188. package/esm/src/types/global-guards.d.ts.map +1 -0
  189. package/esm/src/types/global-guards.js +12 -0
  190. package/esm/src/utils/cache/keys/namespace.d.ts +3 -0
  191. package/esm/src/utils/cache/keys/namespace.d.ts.map +1 -0
  192. package/esm/src/utils/cache/keys/namespace.js +19 -0
  193. package/esm/src/utils/clsx.d.ts +3 -3
  194. package/esm/src/utils/clsx.d.ts.map +1 -1
  195. package/esm/src/utils/clsx.js +2 -3
  196. package/esm/src/utils/mime-types.d.ts +0 -6
  197. package/esm/src/utils/mime-types.d.ts.map +1 -1
  198. package/esm/src/utils/mime-types.js +0 -1
  199. package/esm/src/utils/version-constant.d.ts +1 -1
  200. package/esm/src/utils/version-constant.js +1 -1
  201. package/package.json +14 -1
  202. package/src/cli/commands/extension/init-command.ts +2 -2
  203. package/src/cli/commands/extension/validate-command.ts +1 -1
  204. package/src/deno.js +8 -1
  205. package/src/deps/esm.sh/@types/react-dom@19.2.3/client.d.ts +105 -0
  206. package/src/deps/esm.sh/@types/react@19.2.14/global.d.ts +166 -0
  207. package/src/deps/esm.sh/@types/react@19.2.14/index.d.ts +4370 -0
  208. package/src/deps/esm.sh/@types/scheduler@0.26.0/index.d.ts +30 -0
  209. package/src/deps/esm.sh/csstype@3.2.3/index.d.ts +22569 -0
  210. package/src/deps/esm.sh/react-dom@19.2.4/client.d.ts +105 -0
  211. package/src/deps/esm.sh/react-dom@19.2.4/client.js +5 -0
  212. package/src/deps/esm.sh/scheduler@^0.27.0.d.ts +30 -0
  213. package/src/deps/esm.sh/scheduler@^0.27.0.js +3 -0
  214. package/src/deps/jsr.io/@std/assert/1.0.19/almost_equals.ts +56 -0
  215. package/src/deps/jsr.io/@std/assert/1.0.19/array_includes.ts +76 -0
  216. package/src/deps/jsr.io/@std/assert/1.0.19/assert.ts +24 -0
  217. package/src/deps/jsr.io/@std/assert/1.0.19/assertion_error.ts +31 -0
  218. package/src/deps/jsr.io/@std/assert/1.0.19/equal.ts +226 -0
  219. package/src/deps/jsr.io/@std/assert/1.0.19/equals.ts +68 -0
  220. package/src/deps/jsr.io/@std/assert/1.0.19/exists.ts +31 -0
  221. package/src/deps/jsr.io/@std/assert/1.0.19/fail.ts +21 -0
  222. package/src/deps/jsr.io/@std/assert/1.0.19/false.ts +27 -0
  223. package/src/deps/jsr.io/@std/assert/1.0.19/greater.ts +30 -0
  224. package/src/deps/jsr.io/@std/assert/1.0.19/greater_or_equal.ts +36 -0
  225. package/src/deps/jsr.io/@std/assert/1.0.19/instance_of.ts +64 -0
  226. package/src/deps/jsr.io/@std/assert/1.0.19/is_error.ts +65 -0
  227. package/src/deps/jsr.io/@std/assert/1.0.19/less.ts +29 -0
  228. package/src/deps/jsr.io/@std/assert/1.0.19/less_or_equal.ts +36 -0
  229. package/src/deps/jsr.io/@std/assert/1.0.19/match.ts +30 -0
  230. package/src/deps/jsr.io/@std/assert/1.0.19/mod.ts +47 -0
  231. package/src/deps/jsr.io/@std/assert/1.0.19/not_equals.ts +43 -0
  232. package/src/deps/jsr.io/@std/assert/1.0.19/not_instance_of.ts +33 -0
  233. package/src/deps/jsr.io/@std/assert/1.0.19/not_match.ts +30 -0
  234. package/src/deps/jsr.io/@std/assert/1.0.19/not_strict_equals.ts +42 -0
  235. package/src/deps/jsr.io/@std/assert/1.0.19/object_match.ts +224 -0
  236. package/src/deps/jsr.io/@std/assert/1.0.19/rejects.ts +123 -0
  237. package/src/deps/jsr.io/@std/assert/1.0.19/strict_equals.ts +68 -0
  238. package/src/deps/jsr.io/@std/assert/1.0.19/string_includes.ts +30 -0
  239. package/src/deps/jsr.io/@std/assert/1.0.19/throws.ts +111 -0
  240. package/src/deps/jsr.io/@std/assert/1.0.19/unimplemented.ts +21 -0
  241. package/src/deps/jsr.io/@std/assert/1.0.19/unreachable.ts +21 -0
  242. package/src/deps/jsr.io/@std/internal/1.0.13/assertion_state.ts +248 -0
  243. package/src/deps/jsr.io/@std/internal/1.0.13/build_message.ts +147 -0
  244. package/src/deps/jsr.io/@std/internal/1.0.13/diff.ts +317 -0
  245. package/src/deps/jsr.io/@std/internal/1.0.13/diff_str.ts +208 -0
  246. package/src/deps/jsr.io/@std/internal/1.0.13/format.ts +89 -0
  247. package/src/deps/jsr.io/@std/internal/1.0.13/styles.ts +233 -0
  248. package/src/deps/jsr.io/@std/internal/1.0.13/types.ts +30 -0
  249. package/src/deps/jsr.io/@std/testing/1.0.18/_test_suite.ts +461 -0
  250. package/src/deps/jsr.io/@std/testing/1.0.18/bdd.ts +1294 -0
  251. package/src/src/agent/fork-runtime-stream.ts +780 -0
  252. package/src/src/agent/hosted-child-fork-stream-execution.ts +579 -0
  253. package/src/src/agent/index.ts +26 -0
  254. package/src/src/chat/final-step-fallback.ts +2 -2
  255. package/src/src/modules/index.ts +43 -0
  256. package/src/src/modules/module-resolver.ts +145 -0
  257. package/src/src/rendering/cleanup.ts +27 -0
  258. package/src/src/rendering/ssr/index.ts +10 -0
  259. package/src/src/rendering/ssr/mdx-module-loader.ts +185 -0
  260. package/src/src/rendering/ssr/mdx-renderer.ts +66 -0
  261. package/src/src/rendering/ssr/types.ts +14 -0
  262. package/src/src/sandbox/index.ts +9 -0
  263. package/src/src/sandbox/shell-tools.ts +242 -0
  264. package/src/src/server/shared/index.ts +12 -0
  265. package/src/src/testing/assert.ts +352 -0
  266. package/src/src/testing/bdd.ts +618 -0
  267. package/src/src/testing/deno-compat.ts +206 -0
  268. package/src/src/testing/index.ts +92 -0
  269. package/src/src/testing/init.ts +21 -0
  270. package/src/src/testing/isolation.ts +177 -0
  271. package/src/src/testing/timing.ts +27 -0
  272. package/src/src/testing/utils.ts +44 -0
  273. package/src/src/types/global-guards.ts +21 -0
  274. package/src/src/utils/cache/keys/namespace.ts +25 -0
  275. package/src/src/utils/clsx.ts +2 -4
  276. package/src/src/utils/mime-types.ts +0 -2
  277. package/src/src/utils/version-constant.ts +1 -1
@@ -0,0 +1,248 @@
1
+ // Copyright 2018-2026 the Deno authors. MIT license.
2
+ // This module is browser compatible.
3
+
4
+ /**
5
+ * Check the test suite internal state
6
+ *
7
+ * @example Usage
8
+ * ```ts ignore
9
+ * import { AssertionState } from "@std/internal";
10
+ *
11
+ * const assertionState = new AssertionState();
12
+ * ```
13
+ */
14
+ import * as dntShim from "../../../../../_dnt.shims.js";
15
+
16
+ export class AssertionState {
17
+ #state: {
18
+ assertionCount: number | undefined;
19
+ assertionCheck: boolean;
20
+ assertionTriggered: boolean;
21
+ assertionTriggeredCount: number;
22
+ };
23
+
24
+ constructor() {
25
+ this.#state = {
26
+ assertionCount: undefined,
27
+ assertionCheck: false,
28
+ assertionTriggered: false,
29
+ assertionTriggeredCount: 0,
30
+ };
31
+
32
+ if (typeof globalThis?.addEventListener === "function") {
33
+ globalThis.addEventListener("unload", () => {
34
+ this.#ensureCleanedUp();
35
+ });
36
+ } else if (
37
+ // deno-lint-ignore no-explicit-any
38
+ typeof (dntShim.dntGlobalThis as any)?.process?.on === "function"
39
+ ) {
40
+ // deno-lint-ignore no-explicit-any
41
+ (dntShim.dntGlobalThis as any).process.on("exit", () => {
42
+ this.#ensureCleanedUp();
43
+ });
44
+ } else {
45
+ // deno-lint-ignore no-console
46
+ console.warn("AssertionCounter cleanup step was not registered");
47
+ }
48
+ }
49
+
50
+ #ensureCleanedUp() {
51
+ // If any checks were registered, after the test suite runs the checks,
52
+ // `resetAssertionState` should also have been called. If it was not,
53
+ // then the test suite did not run the checks.
54
+ if (
55
+ this.#state.assertionCheck ||
56
+ this.#state.assertionCount !== undefined
57
+ ) {
58
+ throw new Error(
59
+ "AssertionCounter was not cleaned up: If tests are not otherwise failing, ensure `expect.hasAssertion` and `expect.assertions` are only run in bdd tests",
60
+ );
61
+ }
62
+ }
63
+
64
+ /**
65
+ * Get the number that through `expect.assertions` api set.
66
+ *
67
+ * @returns the number that through `expect.assertions` api set.
68
+ *
69
+ * @example Usage
70
+ * ```ts ignore
71
+ * import { AssertionState } from "@std/internal";
72
+ *
73
+ * const assertionState = new AssertionState();
74
+ * assertionState.assertionCount;
75
+ * ```
76
+ */
77
+ get assertionCount(): number | undefined {
78
+ return this.#state.assertionCount;
79
+ }
80
+
81
+ /**
82
+ * Get a certain number that assertions were called before.
83
+ *
84
+ * @returns return a certain number that assertions were called before.
85
+ *
86
+ * @example Usage
87
+ * ```ts ignore
88
+ * import { AssertionState } from "@std/internal";
89
+ *
90
+ * const assertionState = new AssertionState();
91
+ * assertionState.assertionTriggeredCount;
92
+ * ```
93
+ */
94
+ get assertionTriggeredCount(): number {
95
+ return this.#state.assertionTriggeredCount;
96
+ }
97
+
98
+ /**
99
+ * If `expect.hasAssertions` called, then through this method to update #state.assertionCheck value.
100
+ *
101
+ * @param val Set #state.assertionCheck's value
102
+ *
103
+ * @example Usage
104
+ * ```ts ignore
105
+ * import { AssertionState } from "@std/internal";
106
+ *
107
+ * const assertionState = new AssertionState();
108
+ * assertionState.setAssertionCheck(true);
109
+ * ```
110
+ */
111
+ setAssertionCheck(val: boolean) {
112
+ this.#state.assertionCheck = val;
113
+ }
114
+
115
+ /**
116
+ * If any matchers was called, `#state.assertionTriggered` will be set through this method.
117
+ *
118
+ * @param val Set #state.assertionTriggered's value
119
+ *
120
+ * @example Usage
121
+ * ```ts ignore
122
+ * import { AssertionState } from "@std/internal";
123
+ *
124
+ * const assertionState = new AssertionState();
125
+ * assertionState.setAssertionTriggered(true);
126
+ * ```
127
+ */
128
+ setAssertionTriggered(val: boolean) {
129
+ this.#state.assertionTriggered = val;
130
+ }
131
+
132
+ /**
133
+ * If `expect.assertions` called, then through this method to update #state.assertionCheck value.
134
+ *
135
+ * @param num Set #state.assertionCount's value, for example if the value is set 2, that means
136
+ * you must have two assertion matchers call in your test suite.
137
+ *
138
+ * @example Usage
139
+ * ```ts ignore
140
+ * import { AssertionState } from "@std/internal";
141
+ *
142
+ * const assertionState = new AssertionState();
143
+ * assertionState.setAssertionCount(2);
144
+ * ```
145
+ */
146
+ setAssertionCount(num: number) {
147
+ this.#state.assertionCount = num;
148
+ }
149
+
150
+ /**
151
+ * If any matchers was called, `#state.assertionTriggeredCount` value will plus one internally.
152
+ *
153
+ * @example Usage
154
+ * ```ts ignore
155
+ * import { AssertionState } from "@std/internal";
156
+ *
157
+ * const assertionState = new AssertionState();
158
+ * assertionState.updateAssertionTriggerCount();
159
+ * ```
160
+ */
161
+ updateAssertionTriggerCount() {
162
+ if (this.#state.assertionCount !== undefined) {
163
+ this.#state.assertionTriggeredCount += 1;
164
+ }
165
+ }
166
+
167
+ /**
168
+ * Check Assertion internal state, if `#state.assertionCheck` is set true, but
169
+ * `#state.assertionTriggered` is still false, then should throw an Assertion Error.
170
+ *
171
+ * @returns a boolean value, that the test suite is satisfied with the check. If not,
172
+ * it should throw an AssertionError.
173
+ *
174
+ * @example Usage
175
+ * ```ts ignore
176
+ * import { AssertionState } from "@std/internal";
177
+ *
178
+ * const assertionState = new AssertionState();
179
+ * if (assertionState.checkAssertionErrorState()) {
180
+ * // throw AssertionError("");
181
+ * }
182
+ * ```
183
+ */
184
+ checkAssertionErrorState(): boolean {
185
+ return this.#state.assertionCheck && !this.#state.assertionTriggered;
186
+ }
187
+
188
+ /**
189
+ * Reset all assertion state when every test suite function ran completely.
190
+ *
191
+ * @example Usage
192
+ * ```ts ignore
193
+ * import { AssertionState } from "@std/internal";
194
+ *
195
+ * const assertionState = new AssertionState();
196
+ * assertionState.resetAssertionState();
197
+ * ```
198
+ */
199
+ resetAssertionState(): void {
200
+ this.#state = {
201
+ assertionCount: undefined,
202
+ assertionCheck: false,
203
+ assertionTriggered: false,
204
+ assertionTriggeredCount: 0,
205
+ };
206
+ }
207
+
208
+ /**
209
+ * Check Assertion called state, if `#state.assertionCount` is set to a number value, but
210
+ * `#state.assertionTriggeredCount` is less then it, then should throw an assertion error.
211
+ *
212
+ * @returns a boolean value, that the test suite is satisfied with the check. If not,
213
+ * it should throw an AssertionError.
214
+ *
215
+ * @example Usage
216
+ * ```ts ignore
217
+ * import { AssertionState } from "@std/internal";
218
+ *
219
+ * const assertionState = new AssertionState();
220
+ * if (assertionState.checkAssertionCountSatisfied()) {
221
+ * // throw AssertionError("");
222
+ * }
223
+ * ```
224
+ */
225
+ checkAssertionCountSatisfied(): boolean {
226
+ return this.#state.assertionCount !== undefined &&
227
+ this.#state.assertionCount !== this.#state.assertionTriggeredCount;
228
+ }
229
+ }
230
+
231
+ const assertionState = new AssertionState();
232
+
233
+ /**
234
+ * return an instance of AssertionState
235
+ *
236
+ * @returns AssertionState
237
+ *
238
+ * @example Usage
239
+ * ```ts ignore
240
+ * import { getAssertionState } from "@std/internal";
241
+ *
242
+ * const assertionState = getAssertionState();
243
+ * assertionState.setAssertionTriggered(true);
244
+ * ```
245
+ */
246
+ export function getAssertionState(): AssertionState {
247
+ return assertionState;
248
+ }
@@ -0,0 +1,147 @@
1
+ // Copyright 2018-2026 the Deno authors. MIT license.
2
+ // This module is browser compatible.
3
+
4
+ import { bgGreen, bgRed, bold, gray, green, red, white } from "./styles.js";
5
+ import type { DiffResult, DiffType } from "./types.js";
6
+
7
+ /**
8
+ * Colors the output of assertion diffs.
9
+ *
10
+ * @param diffType Difference type, either added or removed.
11
+ * @param background If true, colors the background instead of the text.
12
+ *
13
+ * @returns A function that colors the input string.
14
+ *
15
+ * @example Usage
16
+ * ```ts
17
+ * import { createColor } from "@std/internal";
18
+ * import { assertEquals } from "@std/assert";
19
+ * import { bold, green, red, white } from "@std/fmt/colors";
20
+ *
21
+ * assertEquals(createColor("added")("foo"), green(bold("foo")));
22
+ * assertEquals(createColor("removed")("foo"), red(bold("foo")));
23
+ * assertEquals(createColor("common")("foo"), white("foo"));
24
+ * ```
25
+ */
26
+ export function createColor(
27
+ diffType: DiffType,
28
+ /**
29
+ * TODO(@littledivy): Remove this when we can detect true color terminals. See
30
+ * https://github.com/denoland/std/issues/2575.
31
+ */
32
+ background = false,
33
+ ): (s: string) => string {
34
+ switch (diffType) {
35
+ case "added":
36
+ return (s) => background ? bgGreen(white(s)) : green(bold(s));
37
+ case "removed":
38
+ return (s) => background ? bgRed(white(s)) : red(bold(s));
39
+ case "truncation":
40
+ return gray;
41
+ default:
42
+ return white;
43
+ }
44
+ }
45
+
46
+ /**
47
+ * Prefixes `+` or `-` in diff output.
48
+ *
49
+ * @param diffType Difference type, either added or removed
50
+ *
51
+ * @returns A string representing the sign.
52
+ *
53
+ * @example Usage
54
+ * ```ts
55
+ * import { createSign } from "@std/internal";
56
+ * import { assertEquals } from "@std/assert";
57
+ *
58
+ * assertEquals(createSign("added"), "+ ");
59
+ * assertEquals(createSign("removed"), "- ");
60
+ * assertEquals(createSign("common"), " ");
61
+ * ```
62
+ */
63
+ export function createSign(diffType: DiffType): string {
64
+ switch (diffType) {
65
+ case "added":
66
+ return "+ ";
67
+ case "removed":
68
+ return "- ";
69
+ default:
70
+ return " ";
71
+ }
72
+ }
73
+
74
+ /** Options for {@linkcode buildMessage}. */
75
+ export interface BuildMessageOptions {
76
+ /**
77
+ * Whether to output the diff as a single string.
78
+ * @default {false}
79
+ */
80
+ stringDiff?: boolean;
81
+ }
82
+
83
+ /**
84
+ * Builds a message based on the provided diff result.
85
+ *
86
+ * @param diffResult The diff result array.
87
+ * @param options Optional parameters for customizing the message.
88
+ * @param truncateDiff Function to truncate the diff (default is no truncation).
89
+ *
90
+ * @returns An array of strings representing the built message.
91
+ *
92
+ * @example Usage
93
+ * ```ts no-assert
94
+ * import { diffStr, buildMessage } from "@std/internal";
95
+ *
96
+ * diffStr("Hello, world!", "Hello, world");
97
+ * // [
98
+ * // "",
99
+ * // "",
100
+ * // " [Diff] Actual / Expected",
101
+ * // "",
102
+ * // "",
103
+ * // "- Hello, world!",
104
+ * // "+ Hello, world",
105
+ * // "",
106
+ * // ]
107
+ * ```
108
+ */
109
+ export function buildMessage(
110
+ diffResult: ReadonlyArray<DiffResult<string>>,
111
+ options: BuildMessageOptions = {},
112
+ truncateDiff?: (
113
+ diffResult: ReadonlyArray<DiffResult<string>>,
114
+ stringDiff: boolean,
115
+ contextLength?: number | null,
116
+ ) => ReadonlyArray<DiffResult<string>>,
117
+ ): string[] {
118
+ if (truncateDiff != null) {
119
+ diffResult = truncateDiff(diffResult, options.stringDiff ?? false);
120
+ }
121
+
122
+ const { stringDiff = false } = options;
123
+ const messages = [
124
+ "",
125
+ "",
126
+ ` ${gray(bold("[Diff]"))} ${red(bold("Actual"))} / ${
127
+ green(bold("Expected"))
128
+ }`,
129
+ "",
130
+ "",
131
+ ];
132
+ const diffMessages = diffResult.map((result) => {
133
+ const color = createColor(result.type);
134
+
135
+ const line = result.type === "added" || result.type === "removed"
136
+ ? result.details?.map((detail) =>
137
+ detail.type !== "common"
138
+ ? createColor(detail.type, true)(detail.value)
139
+ : detail.value
140
+ ).join("") ?? result.value
141
+ : result.value;
142
+
143
+ return color(`${createSign(result.type)}${line}`);
144
+ });
145
+ messages.push(...(stringDiff ? [diffMessages.join("")] : diffMessages), "");
146
+ return messages;
147
+ }
@@ -0,0 +1,317 @@
1
+ // Copyright 2018-2026 the Deno authors. MIT license.
2
+ // This module is browser compatible.
3
+
4
+ import type { DiffResult, DiffType } from "./types.js";
5
+
6
+ /** Represents the farthest point in the diff algorithm. */
7
+ export interface FarthestPoint {
8
+ /** The y-coordinate of the point. */
9
+ y: number;
10
+ /** The id of the point. */
11
+ id: number;
12
+ }
13
+
14
+ const REMOVED = 1;
15
+ const COMMON = 2;
16
+ const ADDED = 3;
17
+
18
+ /**
19
+ * Creates an array of common elements between two arrays.
20
+ *
21
+ * @typeParam T The type of elements in the arrays.
22
+ *
23
+ * @param A The first array.
24
+ * @param B The second array.
25
+ *
26
+ * @returns An array containing the common elements between the two arrays.
27
+ *
28
+ * @example Usage
29
+ * ```ts
30
+ * import { createCommon } from "@std/internal/diff";
31
+ * import { assertEquals } from "@std/assert";
32
+ *
33
+ * const a = [1, 2, 3];
34
+ * const b = [1, 2, 4];
35
+ *
36
+ * assertEquals(createCommon(a, b), [1, 2]);
37
+ * ```
38
+ */
39
+ export function createCommon<T>(A: T[], B: T[]): T[] {
40
+ const common: T[] = [];
41
+ if (A.length === 0 || B.length === 0) return [];
42
+ for (let i = 0; i < Math.min(A.length, B.length); i += 1) {
43
+ const a = A[i];
44
+ const b = B[i];
45
+ if (a !== undefined && a === b) {
46
+ common.push(a);
47
+ } else {
48
+ return common;
49
+ }
50
+ }
51
+ return common;
52
+ }
53
+
54
+ /**
55
+ * Asserts that the value is a {@linkcode FarthestPoint}.
56
+ * If not, an error is thrown.
57
+ *
58
+ * @param value The value to check.
59
+ *
60
+ * @returns A void value that returns once the assertion completes.
61
+ *
62
+ * @example Usage
63
+ * ```ts
64
+ * import { assertFp } from "@std/internal/diff";
65
+ * import { assertThrows } from "@std/assert";
66
+ *
67
+ * assertFp({ y: 0, id: 0 });
68
+ * assertThrows(() => assertFp({ id: 0 }));
69
+ * assertThrows(() => assertFp({ y: 0 }));
70
+ * assertThrows(() => assertFp(undefined));
71
+ * ```
72
+ */
73
+ export function assertFp(value: unknown): asserts value is FarthestPoint {
74
+ if (
75
+ value == null ||
76
+ typeof value !== "object" ||
77
+ typeof (value as FarthestPoint)?.y !== "number" ||
78
+ typeof (value as FarthestPoint)?.id !== "number"
79
+ ) {
80
+ throw new Error(
81
+ `Unexpected value, expected 'FarthestPoint': received ${typeof value}`,
82
+ );
83
+ }
84
+ }
85
+
86
+ /**
87
+ * Creates an array of backtraced differences.
88
+ *
89
+ * @typeParam T The type of elements in the arrays.
90
+ *
91
+ * @param A The first array.
92
+ * @param B The second array.
93
+ * @param current The current {@linkcode FarthestPoint}.
94
+ * @param swapped Boolean indicating if the arrays are swapped.
95
+ * @param routes The routes array.
96
+ * @param diffTypesPtrOffset The offset of the diff types in the routes array.
97
+ *
98
+ * @returns An array of backtraced differences.
99
+ *
100
+ * @example Usage
101
+ * ```ts
102
+ * import { backTrace } from "@std/internal/diff";
103
+ * import { assertEquals } from "@std/assert";
104
+ *
105
+ * assertEquals(
106
+ * backTrace([], [], { y: 0, id: 0 }, false, new Uint32Array(0), 0),
107
+ * [],
108
+ * );
109
+ * ```
110
+ */
111
+ export function backTrace<T>(
112
+ A: T[],
113
+ B: T[],
114
+ current: FarthestPoint,
115
+ swapped: boolean,
116
+ routes: Uint32Array,
117
+ diffTypesPtrOffset: number,
118
+ ): Array<{
119
+ type: DiffType;
120
+ value: T;
121
+ }> {
122
+ const M = A.length;
123
+ const N = B.length;
124
+ const result: { type: DiffType; value: T }[] = [];
125
+ let a = M - 1;
126
+ let b = N - 1;
127
+ let j = routes[current.id];
128
+ let type = routes[current.id + diffTypesPtrOffset];
129
+ while (true) {
130
+ if (!j && !type) break;
131
+ const prev = j!;
132
+ if (type === REMOVED) {
133
+ result.unshift({
134
+ type: swapped ? "removed" : "added",
135
+ value: B[b]!,
136
+ });
137
+ b -= 1;
138
+ } else if (type === ADDED) {
139
+ result.unshift({
140
+ type: swapped ? "added" : "removed",
141
+ value: A[a]!,
142
+ });
143
+ a -= 1;
144
+ } else {
145
+ result.unshift({ type: "common", value: A[a]! });
146
+ a -= 1;
147
+ b -= 1;
148
+ }
149
+ j = routes[prev];
150
+ type = routes[prev + diffTypesPtrOffset];
151
+ }
152
+ return result;
153
+ }
154
+
155
+ /**
156
+ * Creates a {@linkcode FarthestPoint}.
157
+ *
158
+ * @param k The current index.
159
+ * @param M The length of the first array.
160
+ * @param routes The routes array.
161
+ * @param diffTypesPtrOffset The offset of the diff types in the routes array.
162
+ * @param ptr The current pointer.
163
+ * @param slide The slide {@linkcode FarthestPoint}.
164
+ * @param down The down {@linkcode FarthestPoint}.
165
+ *
166
+ * @returns A {@linkcode FarthestPoint}.
167
+ *
168
+ * @example Usage
169
+ * ```ts
170
+ * import { createFp } from "@std/internal/diff";
171
+ * import { assertEquals } from "@std/assert";
172
+ *
173
+ * assertEquals(
174
+ * createFp(
175
+ * 0,
176
+ * 0,
177
+ * new Uint32Array(0),
178
+ * 0,
179
+ * 0,
180
+ * { y: -1, id: 0 },
181
+ * { y: 0, id: 0 },
182
+ * ),
183
+ * { y: -1, id: 1 },
184
+ * );
185
+ * ```
186
+ */
187
+ export function createFp(
188
+ k: number,
189
+ M: number,
190
+ routes: Uint32Array,
191
+ diffTypesPtrOffset: number,
192
+ ptr: number,
193
+ slide?: FarthestPoint,
194
+ down?: FarthestPoint,
195
+ ): FarthestPoint {
196
+ if (slide && slide.y === -1 && down && down.y === -1) {
197
+ return { y: 0, id: 0 };
198
+ }
199
+ const isAdding = (down?.y === -1) ||
200
+ k === M ||
201
+ (slide?.y ?? 0) > (down?.y ?? 0) + 1;
202
+ if (slide && isAdding) {
203
+ const prev = slide.id;
204
+ ptr++;
205
+ routes[ptr] = prev;
206
+ routes[ptr + diffTypesPtrOffset] = ADDED;
207
+ return { y: slide.y, id: ptr };
208
+ }
209
+ if (down && !isAdding) {
210
+ const prev = down.id;
211
+ ptr++;
212
+ routes[ptr] = prev;
213
+ routes[ptr + diffTypesPtrOffset] = REMOVED;
214
+ return { y: down.y + 1, id: ptr };
215
+ }
216
+ throw new Error("Unexpected missing FarthestPoint");
217
+ }
218
+
219
+ /**
220
+ * Renders the differences between the actual and expected values.
221
+ *
222
+ * @typeParam T The type of elements in the arrays.
223
+ *
224
+ * @param A Actual value
225
+ * @param B Expected value
226
+ *
227
+ * @returns An array of differences between the actual and expected values.
228
+ *
229
+ * @example Usage
230
+ * ```ts
231
+ * import { diff } from "@std/internal/diff";
232
+ * import { assertEquals } from "@std/assert";
233
+ *
234
+ * const a = [1, 2, 3];
235
+ * const b = [1, 2, 4];
236
+ *
237
+ * assertEquals(diff(a, b), [
238
+ * { type: "common", value: 1 },
239
+ * { type: "common", value: 2 },
240
+ * { type: "removed", value: 3 },
241
+ * { type: "added", value: 4 },
242
+ * ]);
243
+ * ```
244
+ */
245
+ export function diff<T>(A: T[], B: T[]): DiffResult<T>[] {
246
+ const prefixCommon = createCommon(A, B);
247
+ A = A.slice(prefixCommon.length);
248
+ B = B.slice(prefixCommon.length);
249
+ const swapped = B.length > A.length;
250
+ [A, B] = swapped ? [B, A] : [A, B];
251
+ const M = A.length;
252
+ const N = B.length;
253
+ if (!M && !N && !prefixCommon.length) return [];
254
+ if (!N) {
255
+ return [
256
+ ...prefixCommon.map((value) => ({ type: "common", value })),
257
+ ...A.map((value) => ({ type: swapped ? "added" : "removed", value })),
258
+ ] as DiffResult<T>[];
259
+ }
260
+ const offset = N;
261
+ const delta = M - N;
262
+ const length = M + N + 1;
263
+ const fp: FarthestPoint[] = Array.from({ length }, () => ({ y: -1, id: -1 }));
264
+
265
+ /**
266
+ * Note: this buffer is used to save memory and improve performance. The first
267
+ * half is used to save route and the last half is used to save diff type.
268
+ */
269
+ const routes = new Uint32Array((M * N + length + 1) * 2);
270
+ const diffTypesPtrOffset = routes.length / 2;
271
+ let ptr = 0;
272
+
273
+ function snake<T>(
274
+ k: number,
275
+ A: T[],
276
+ B: T[],
277
+ slide?: FarthestPoint,
278
+ down?: FarthestPoint,
279
+ ): FarthestPoint {
280
+ const M = A.length;
281
+ const N = B.length;
282
+ const fp = createFp(k, M, routes, diffTypesPtrOffset, ptr, slide, down);
283
+ ptr = fp.id;
284
+ while (fp.y + k < M && fp.y < N && A[fp.y + k] === B[fp.y]) {
285
+ const prev = fp.id;
286
+ ptr++;
287
+ fp.id = ptr;
288
+ fp.y += 1;
289
+ routes[ptr] = prev;
290
+ routes[ptr + diffTypesPtrOffset] = COMMON;
291
+ }
292
+ return fp;
293
+ }
294
+
295
+ let currentFp = fp[delta + offset];
296
+ assertFp(currentFp);
297
+ let p = -1;
298
+ while (currentFp.y < N) {
299
+ p = p + 1;
300
+ for (let k = -p; k < delta; ++k) {
301
+ const index = k + offset;
302
+ fp[index] = snake(k, A, B, fp[index - 1], fp[index + 1]);
303
+ }
304
+ for (let k = delta + p; k > delta; --k) {
305
+ const index = k + offset;
306
+ fp[index] = snake(k, A, B, fp[index - 1], fp[index + 1]);
307
+ }
308
+ const index = delta + offset;
309
+ fp[delta + offset] = snake(delta, A, B, fp[index - 1], fp[index + 1]);
310
+ currentFp = fp[delta + offset];
311
+ assertFp(currentFp);
312
+ }
313
+ return [
314
+ ...prefixCommon.map((value) => ({ type: "common", value })),
315
+ ...backTrace(A, B, currentFp, swapped, routes, diffTypesPtrOffset),
316
+ ] as DiffResult<T>[];
317
+ }