@depup/bun-types 1.3.11-depup.0

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 (361) hide show
  1. package/CLAUDE.md +105 -0
  2. package/README.md +25 -0
  3. package/bun.d.ts +8712 -0
  4. package/bun.ns.d.ts +5 -0
  5. package/bundle.d.ts +74 -0
  6. package/changes.json +5 -0
  7. package/deprecated.d.ts +184 -0
  8. package/devserver.d.ts +187 -0
  9. package/docs/README.md +28 -0
  10. package/docs/bundler/bytecode.mdx +447 -0
  11. package/docs/bundler/css.mdx +1024 -0
  12. package/docs/bundler/esbuild.mdx +304 -0
  13. package/docs/bundler/executables.mdx +1318 -0
  14. package/docs/bundler/fullstack.mdx +1086 -0
  15. package/docs/bundler/hot-reloading.mdx +229 -0
  16. package/docs/bundler/html-static.mdx +498 -0
  17. package/docs/bundler/index.mdx +1840 -0
  18. package/docs/bundler/loaders.mdx +451 -0
  19. package/docs/bundler/macros.mdx +328 -0
  20. package/docs/bundler/minifier.mdx +1286 -0
  21. package/docs/bundler/plugins.mdx +477 -0
  22. package/docs/bundler/standalone-html.mdx +314 -0
  23. package/docs/feedback.mdx +75 -0
  24. package/docs/guides/binary/arraybuffer-to-array.mdx +29 -0
  25. package/docs/guides/binary/arraybuffer-to-blob.mdx +26 -0
  26. package/docs/guides/binary/arraybuffer-to-buffer.mdx +27 -0
  27. package/docs/guides/binary/arraybuffer-to-string.mdx +17 -0
  28. package/docs/guides/binary/arraybuffer-to-typedarray.mdx +41 -0
  29. package/docs/guides/binary/blob-to-arraybuffer.mdx +16 -0
  30. package/docs/guides/binary/blob-to-dataview.mdx +16 -0
  31. package/docs/guides/binary/blob-to-stream.mdx +16 -0
  32. package/docs/guides/binary/blob-to-string.mdx +17 -0
  33. package/docs/guides/binary/blob-to-typedarray.mdx +16 -0
  34. package/docs/guides/binary/buffer-to-arraybuffer.mdx +16 -0
  35. package/docs/guides/binary/buffer-to-blob.mdx +16 -0
  36. package/docs/guides/binary/buffer-to-readablestream.mdx +43 -0
  37. package/docs/guides/binary/buffer-to-string.mdx +27 -0
  38. package/docs/guides/binary/buffer-to-typedarray.mdx +16 -0
  39. package/docs/guides/binary/dataview-to-string.mdx +17 -0
  40. package/docs/guides/binary/typedarray-to-arraybuffer.mdx +27 -0
  41. package/docs/guides/binary/typedarray-to-blob.mdx +18 -0
  42. package/docs/guides/binary/typedarray-to-buffer.mdx +16 -0
  43. package/docs/guides/binary/typedarray-to-dataview.mdx +16 -0
  44. package/docs/guides/binary/typedarray-to-readablestream.mdx +43 -0
  45. package/docs/guides/binary/typedarray-to-string.mdx +18 -0
  46. package/docs/guides/deployment/aws-lambda.mdx +204 -0
  47. package/docs/guides/deployment/digital-ocean.mdx +161 -0
  48. package/docs/guides/deployment/google-cloud-run.mdx +194 -0
  49. package/docs/guides/deployment/railway.mdx +145 -0
  50. package/docs/guides/deployment/render.mdx +82 -0
  51. package/docs/guides/deployment/vercel.mdx +97 -0
  52. package/docs/guides/ecosystem/astro.mdx +82 -0
  53. package/docs/guides/ecosystem/discordjs.mdx +80 -0
  54. package/docs/guides/ecosystem/docker.mdx +151 -0
  55. package/docs/guides/ecosystem/drizzle.mdx +195 -0
  56. package/docs/guides/ecosystem/elysia.mdx +31 -0
  57. package/docs/guides/ecosystem/express.mdx +43 -0
  58. package/docs/guides/ecosystem/gel.mdx +261 -0
  59. package/docs/guides/ecosystem/hono.mdx +47 -0
  60. package/docs/guides/ecosystem/mongoose.mdx +92 -0
  61. package/docs/guides/ecosystem/neon-drizzle.mdx +234 -0
  62. package/docs/guides/ecosystem/neon-serverless-postgres.mdx +60 -0
  63. package/docs/guides/ecosystem/nextjs.mdx +103 -0
  64. package/docs/guides/ecosystem/nuxt.mdx +96 -0
  65. package/docs/guides/ecosystem/pm2.mdx +55 -0
  66. package/docs/guides/ecosystem/prisma-postgres.mdx +169 -0
  67. package/docs/guides/ecosystem/prisma.mdx +164 -0
  68. package/docs/guides/ecosystem/qwik.mdx +114 -0
  69. package/docs/guides/ecosystem/react.mdx +52 -0
  70. package/docs/guides/ecosystem/remix.mdx +97 -0
  71. package/docs/guides/ecosystem/sentry.mdx +54 -0
  72. package/docs/guides/ecosystem/solidstart.mdx +62 -0
  73. package/docs/guides/ecosystem/ssr-react.mdx +49 -0
  74. package/docs/guides/ecosystem/stric.mdx +54 -0
  75. package/docs/guides/ecosystem/sveltekit.mdx +138 -0
  76. package/docs/guides/ecosystem/systemd.mdx +114 -0
  77. package/docs/guides/ecosystem/tanstack-start.mdx +791 -0
  78. package/docs/guides/ecosystem/upstash.mdx +87 -0
  79. package/docs/guides/ecosystem/vite.mdx +77 -0
  80. package/docs/guides/html-rewriter/extract-links.mdx +71 -0
  81. package/docs/guides/html-rewriter/extract-social-meta.mdx +97 -0
  82. package/docs/guides/http/cluster.mdx +69 -0
  83. package/docs/guides/http/fetch-unix.mdx +35 -0
  84. package/docs/guides/http/fetch.mdx +26 -0
  85. package/docs/guides/http/file-uploads.mdx +97 -0
  86. package/docs/guides/http/hot.mdx +28 -0
  87. package/docs/guides/http/proxy.mdx +50 -0
  88. package/docs/guides/http/server.mdx +48 -0
  89. package/docs/guides/http/simple.mdx +20 -0
  90. package/docs/guides/http/sse.mdx +91 -0
  91. package/docs/guides/http/stream-file.mdx +50 -0
  92. package/docs/guides/http/stream-iterator.mdx +49 -0
  93. package/docs/guides/http/stream-node-streams-in-bun.mdx +22 -0
  94. package/docs/guides/http/tls.mdx +32 -0
  95. package/docs/guides/index.mdx +10 -0
  96. package/docs/guides/install/add-dev.mdx +28 -0
  97. package/docs/guides/install/add-git.mdx +40 -0
  98. package/docs/guides/install/add-optional.mdx +27 -0
  99. package/docs/guides/install/add-peer.mdx +45 -0
  100. package/docs/guides/install/add-tarball.mdx +35 -0
  101. package/docs/guides/install/add.mdx +44 -0
  102. package/docs/guides/install/azure-artifacts.mdx +76 -0
  103. package/docs/guides/install/cicd.mdx +43 -0
  104. package/docs/guides/install/custom-registry.mdx +32 -0
  105. package/docs/guides/install/from-npm-install-to-bun-install.mdx +230 -0
  106. package/docs/guides/install/git-diff-bun-lockfile.mdx +48 -0
  107. package/docs/guides/install/jfrog-artifactory.mdx +28 -0
  108. package/docs/guides/install/npm-alias.mdx +25 -0
  109. package/docs/guides/install/registry-scope.mdx +40 -0
  110. package/docs/guides/install/trusted.mdx +52 -0
  111. package/docs/guides/install/workspaces.mdx +70 -0
  112. package/docs/guides/install/yarnlock.mdx +51 -0
  113. package/docs/guides/process/argv.mdx +66 -0
  114. package/docs/guides/process/ctrl-c.mdx +18 -0
  115. package/docs/guides/process/ipc.mdx +69 -0
  116. package/docs/guides/process/nanoseconds.mdx +15 -0
  117. package/docs/guides/process/os-signals.mdx +31 -0
  118. package/docs/guides/process/spawn-stderr.mdx +34 -0
  119. package/docs/guides/process/spawn-stdout.mdx +28 -0
  120. package/docs/guides/process/spawn.mdx +43 -0
  121. package/docs/guides/process/stdin.mdx +62 -0
  122. package/docs/guides/read-file/arraybuffer.mdx +30 -0
  123. package/docs/guides/read-file/buffer.mdx +21 -0
  124. package/docs/guides/read-file/exists.mdx +18 -0
  125. package/docs/guides/read-file/json.mdx +19 -0
  126. package/docs/guides/read-file/mime.mdx +22 -0
  127. package/docs/guides/read-file/stream.mdx +28 -0
  128. package/docs/guides/read-file/string.mdx +24 -0
  129. package/docs/guides/read-file/uint8array.mdx +23 -0
  130. package/docs/guides/read-file/watch.mdx +66 -0
  131. package/docs/guides/runtime/build-time-constants.mdx +295 -0
  132. package/docs/guides/runtime/cicd.mdx +45 -0
  133. package/docs/guides/runtime/codesign-macos-executable.mdx +61 -0
  134. package/docs/guides/runtime/define-constant.mdx +149 -0
  135. package/docs/guides/runtime/delete-directory.mdx +39 -0
  136. package/docs/guides/runtime/delete-file.mdx +21 -0
  137. package/docs/guides/runtime/heap-snapshot.mdx +28 -0
  138. package/docs/guides/runtime/import-html.mdx +15 -0
  139. package/docs/guides/runtime/import-json.mdx +46 -0
  140. package/docs/guides/runtime/import-json5.mdx +74 -0
  141. package/docs/guides/runtime/import-toml.mdx +32 -0
  142. package/docs/guides/runtime/import-yaml.mdx +104 -0
  143. package/docs/guides/runtime/read-env.mdx +37 -0
  144. package/docs/guides/runtime/set-env.mdx +51 -0
  145. package/docs/guides/runtime/shell.mdx +42 -0
  146. package/docs/guides/runtime/timezone.mdx +38 -0
  147. package/docs/guides/runtime/tsconfig-paths.mdx +31 -0
  148. package/docs/guides/runtime/typescript.mdx +51 -0
  149. package/docs/guides/runtime/vscode-debugger.mdx +47 -0
  150. package/docs/guides/runtime/web-debugger.mdx +103 -0
  151. package/docs/guides/streams/node-readable-to-arraybuffer.mdx +13 -0
  152. package/docs/guides/streams/node-readable-to-blob.mdx +13 -0
  153. package/docs/guides/streams/node-readable-to-json.mdx +14 -0
  154. package/docs/guides/streams/node-readable-to-string.mdx +14 -0
  155. package/docs/guides/streams/node-readable-to-uint8array.mdx +13 -0
  156. package/docs/guides/streams/to-array.mdx +16 -0
  157. package/docs/guides/streams/to-arraybuffer.mdx +16 -0
  158. package/docs/guides/streams/to-blob.mdx +16 -0
  159. package/docs/guides/streams/to-buffer.mdx +17 -0
  160. package/docs/guides/streams/to-json.mdx +16 -0
  161. package/docs/guides/streams/to-string.mdx +16 -0
  162. package/docs/guides/streams/to-typedarray.mdx +24 -0
  163. package/docs/guides/test/bail.mdx +24 -0
  164. package/docs/guides/test/concurrent-test-glob.mdx +146 -0
  165. package/docs/guides/test/coverage-threshold.mdx +67 -0
  166. package/docs/guides/test/coverage.mdx +49 -0
  167. package/docs/guides/test/happy-dom.mdx +73 -0
  168. package/docs/guides/test/migrate-from-jest.mdx +125 -0
  169. package/docs/guides/test/mock-clock.mdx +50 -0
  170. package/docs/guides/test/mock-functions.mdx +70 -0
  171. package/docs/guides/test/rerun-each.mdx +16 -0
  172. package/docs/guides/test/run-tests.mdx +116 -0
  173. package/docs/guides/test/skip-tests.mdx +43 -0
  174. package/docs/guides/test/snapshot.mdx +102 -0
  175. package/docs/guides/test/spy-on.mdx +49 -0
  176. package/docs/guides/test/svelte-test.mdx +113 -0
  177. package/docs/guides/test/testing-library.mdx +93 -0
  178. package/docs/guides/test/timeout.mdx +17 -0
  179. package/docs/guides/test/todo-tests.mdx +74 -0
  180. package/docs/guides/test/update-snapshots.mdx +49 -0
  181. package/docs/guides/test/watch-mode.mdx +24 -0
  182. package/docs/guides/util/base64.mdx +17 -0
  183. package/docs/guides/util/deep-equals.mdx +41 -0
  184. package/docs/guides/util/deflate.mdx +20 -0
  185. package/docs/guides/util/detect-bun.mdx +28 -0
  186. package/docs/guides/util/entrypoint.mdx +19 -0
  187. package/docs/guides/util/escape-html.mdx +24 -0
  188. package/docs/guides/util/file-url-to-path.mdx +16 -0
  189. package/docs/guides/util/gzip.mdx +20 -0
  190. package/docs/guides/util/hash-a-password.mdx +56 -0
  191. package/docs/guides/util/import-meta-dir.mdx +15 -0
  192. package/docs/guides/util/import-meta-file.mdx +15 -0
  193. package/docs/guides/util/import-meta-path.mdx +15 -0
  194. package/docs/guides/util/javascript-uuid.mdx +25 -0
  195. package/docs/guides/util/main.mdx +43 -0
  196. package/docs/guides/util/path-to-file-url.mdx +16 -0
  197. package/docs/guides/util/sleep.mdx +24 -0
  198. package/docs/guides/util/upgrade.mdx +93 -0
  199. package/docs/guides/util/version.mdx +23 -0
  200. package/docs/guides/util/which-path-to-executable-bin.mdx +17 -0
  201. package/docs/guides/websocket/compression.mdx +33 -0
  202. package/docs/guides/websocket/context.mdx +79 -0
  203. package/docs/guides/websocket/pubsub.mdx +43 -0
  204. package/docs/guides/websocket/simple.mdx +38 -0
  205. package/docs/guides/write-file/append.mdx +54 -0
  206. package/docs/guides/write-file/basic.mdx +46 -0
  207. package/docs/guides/write-file/blob.mdx +30 -0
  208. package/docs/guides/write-file/cat.mdx +19 -0
  209. package/docs/guides/write-file/file-cp.mdx +18 -0
  210. package/docs/guides/write-file/filesink.mdx +54 -0
  211. package/docs/guides/write-file/response.mdx +19 -0
  212. package/docs/guides/write-file/stdout.mdx +23 -0
  213. package/docs/guides/write-file/stream.mdx +19 -0
  214. package/docs/guides/write-file/unlink.mdx +18 -0
  215. package/docs/index.mdx +133 -0
  216. package/docs/installation.mdx +372 -0
  217. package/docs/pm/bunx.mdx +91 -0
  218. package/docs/pm/catalogs.mdx +292 -0
  219. package/docs/pm/cli/add.mdx +179 -0
  220. package/docs/pm/cli/audit.mdx +60 -0
  221. package/docs/pm/cli/info.mdx +70 -0
  222. package/docs/pm/cli/install.mdx +591 -0
  223. package/docs/pm/cli/link.mdx +61 -0
  224. package/docs/pm/cli/outdated.mdx +197 -0
  225. package/docs/pm/cli/patch.mdx +69 -0
  226. package/docs/pm/cli/pm.mdx +323 -0
  227. package/docs/pm/cli/publish.mdx +131 -0
  228. package/docs/pm/cli/remove.mdx +16 -0
  229. package/docs/pm/cli/update.mdx +140 -0
  230. package/docs/pm/cli/why.mdx +84 -0
  231. package/docs/pm/filter.mdx +127 -0
  232. package/docs/pm/global-cache.mdx +72 -0
  233. package/docs/pm/isolated-installs.mdx +220 -0
  234. package/docs/pm/lifecycle.mdx +64 -0
  235. package/docs/pm/lockfile.mdx +64 -0
  236. package/docs/pm/npmrc.mdx +245 -0
  237. package/docs/pm/overrides.mdx +83 -0
  238. package/docs/pm/scopes-registries.mdx +35 -0
  239. package/docs/pm/security-scanner-api.mdx +95 -0
  240. package/docs/pm/workspaces.mdx +115 -0
  241. package/docs/project/benchmarking.mdx +296 -0
  242. package/docs/project/bindgen.mdx +223 -0
  243. package/docs/project/building-windows.mdx +143 -0
  244. package/docs/project/contributing.mdx +366 -0
  245. package/docs/project/feedback.mdx +20 -0
  246. package/docs/project/license.mdx +78 -0
  247. package/docs/project/roadmap.mdx +8 -0
  248. package/docs/quickstart.mdx +251 -0
  249. package/docs/runtime/archive.mdx +452 -0
  250. package/docs/runtime/auto-install.mdx +97 -0
  251. package/docs/runtime/binary-data.mdx +846 -0
  252. package/docs/runtime/bun-apis.mdx +60 -0
  253. package/docs/runtime/bunfig.mdx +765 -0
  254. package/docs/runtime/c-compiler.mdx +204 -0
  255. package/docs/runtime/child-process.mdx +659 -0
  256. package/docs/runtime/color.mdx +267 -0
  257. package/docs/runtime/console.mdx +67 -0
  258. package/docs/runtime/cookies.mdx +454 -0
  259. package/docs/runtime/cron.mdx +358 -0
  260. package/docs/runtime/csrf.mdx +171 -0
  261. package/docs/runtime/debugger.mdx +335 -0
  262. package/docs/runtime/environment-variables.mdx +231 -0
  263. package/docs/runtime/ffi.mdx +567 -0
  264. package/docs/runtime/file-io.mdx +306 -0
  265. package/docs/runtime/file-system-router.mdx +118 -0
  266. package/docs/runtime/file-types.mdx +482 -0
  267. package/docs/runtime/glob.mdx +181 -0
  268. package/docs/runtime/globals.mdx +72 -0
  269. package/docs/runtime/hashing.mdx +315 -0
  270. package/docs/runtime/html-rewriter.mdx +333 -0
  271. package/docs/runtime/http/cookies.mdx +79 -0
  272. package/docs/runtime/http/error-handling.mdx +40 -0
  273. package/docs/runtime/http/metrics.mdx +36 -0
  274. package/docs/runtime/http/routing.mdx +289 -0
  275. package/docs/runtime/http/server.mdx +672 -0
  276. package/docs/runtime/http/tls.mdx +101 -0
  277. package/docs/runtime/http/websockets.mdx +414 -0
  278. package/docs/runtime/index.mdx +223 -0
  279. package/docs/runtime/json5.mdx +271 -0
  280. package/docs/runtime/jsonl.mdx +188 -0
  281. package/docs/runtime/jsx.mdx +115 -0
  282. package/docs/runtime/markdown.mdx +381 -0
  283. package/docs/runtime/module-resolution.mdx +374 -0
  284. package/docs/runtime/networking/dns.mdx +111 -0
  285. package/docs/runtime/networking/fetch.mdx +484 -0
  286. package/docs/runtime/networking/tcp.mdx +239 -0
  287. package/docs/runtime/networking/udp.mdx +180 -0
  288. package/docs/runtime/node-api.mdx +19 -0
  289. package/docs/runtime/nodejs-compat.mdx +468 -0
  290. package/docs/runtime/plugins.mdx +419 -0
  291. package/docs/runtime/redis.mdx +583 -0
  292. package/docs/runtime/repl.mdx +176 -0
  293. package/docs/runtime/s3.mdx +881 -0
  294. package/docs/runtime/secrets.mdx +340 -0
  295. package/docs/runtime/semver.mdx +57 -0
  296. package/docs/runtime/shell.mdx +637 -0
  297. package/docs/runtime/sql.mdx +1404 -0
  298. package/docs/runtime/sqlite.mdx +721 -0
  299. package/docs/runtime/streams.mdx +232 -0
  300. package/docs/runtime/templating/create.mdx +269 -0
  301. package/docs/runtime/templating/init.mdx +58 -0
  302. package/docs/runtime/toml.mdx +238 -0
  303. package/docs/runtime/transpiler.mdx +288 -0
  304. package/docs/runtime/typescript.mdx +58 -0
  305. package/docs/runtime/utils.mdx +1010 -0
  306. package/docs/runtime/watch-mode.mdx +161 -0
  307. package/docs/runtime/web-apis.mdx +29 -0
  308. package/docs/runtime/workers.mdx +314 -0
  309. package/docs/runtime/yaml.mdx +470 -0
  310. package/docs/snippets/cli/add.mdx +166 -0
  311. package/docs/snippets/cli/build.mdx +197 -0
  312. package/docs/snippets/cli/bunx.mdx +49 -0
  313. package/docs/snippets/cli/feedback.mdx +17 -0
  314. package/docs/snippets/cli/init.mdx +84 -0
  315. package/docs/snippets/cli/install.mdx +173 -0
  316. package/docs/snippets/cli/link.mdx +163 -0
  317. package/docs/snippets/cli/outdated.mdx +140 -0
  318. package/docs/snippets/cli/patch.mdx +171 -0
  319. package/docs/snippets/cli/publish.mdx +198 -0
  320. package/docs/snippets/cli/remove.mdx +146 -0
  321. package/docs/snippets/cli/run.mdx +305 -0
  322. package/docs/snippets/cli/test.mdx +105 -0
  323. package/docs/snippets/cli/update.mdx +144 -0
  324. package/docs/test/code-coverage.mdx +409 -0
  325. package/docs/test/configuration.mdx +574 -0
  326. package/docs/test/dates-times.mdx +129 -0
  327. package/docs/test/discovery.mdx +90 -0
  328. package/docs/test/dom.mdx +226 -0
  329. package/docs/test/index.mdx +409 -0
  330. package/docs/test/lifecycle.mdx +366 -0
  331. package/docs/test/mocks.mdx +637 -0
  332. package/docs/test/reporters.mdx +126 -0
  333. package/docs/test/runtime-behavior.mdx +342 -0
  334. package/docs/test/snapshots.mdx +434 -0
  335. package/docs/test/writing-tests.mdx +672 -0
  336. package/docs/typescript.mdx +54 -0
  337. package/extensions.d.ts +40 -0
  338. package/fetch.d.ts +79 -0
  339. package/ffi.d.ts +1154 -0
  340. package/globals.d.ts +2067 -0
  341. package/html-rewriter.d.ts +186 -0
  342. package/index.d.ts +32 -0
  343. package/jsc.d.ts +233 -0
  344. package/jsx.d.ts +11 -0
  345. package/overrides.d.ts +376 -0
  346. package/package.json +53 -0
  347. package/redis.d.ts +3352 -0
  348. package/s3.d.ts +1354 -0
  349. package/security.d.ts +101 -0
  350. package/serve.d.ts +1296 -0
  351. package/shell.d.ts +380 -0
  352. package/sql.d.ts +887 -0
  353. package/sqlite.d.ts +1322 -0
  354. package/test-globals.d.ts +22 -0
  355. package/test.d.ts +2392 -0
  356. package/vendor/expect-type/branding.d.ts +283 -0
  357. package/vendor/expect-type/index.d.ts +1207 -0
  358. package/vendor/expect-type/messages.d.ts +395 -0
  359. package/vendor/expect-type/overloads.d.ts +669 -0
  360. package/vendor/expect-type/utils.d.ts +431 -0
  361. package/wasm.d.ts +193 -0
@@ -0,0 +1,409 @@
1
+ ---
2
+ title: "Test runner"
3
+ description: "Bun's fast, built-in, Jest-compatible test runner with TypeScript support, lifecycle hooks, mocking, and watch mode"
4
+ ---
5
+
6
+ import Test from "/snippets/cli/test.mdx";
7
+
8
+ Bun ships with a fast, built-in, Jest-compatible test runner. Tests are executed with the Bun runtime, and support the following features.
9
+
10
+ - TypeScript and JSX
11
+ - Lifecycle hooks
12
+ - Snapshot testing
13
+ - UI & DOM testing
14
+ - Watch mode with `--watch`
15
+ - Script pre-loading with `--preload`
16
+
17
+ <Note>
18
+ Bun aims for compatibility with Jest, but not everything is implemented. To track compatibility, see [this tracking
19
+ issue](https://github.com/oven-sh/bun/issues/1825).
20
+ </Note>
21
+
22
+ ## Run tests
23
+
24
+ ```bash terminal icon="terminal"
25
+ bun test
26
+ ```
27
+
28
+ Tests are written in JavaScript or TypeScript with a Jest-like API. Refer to [Writing tests](/docs/test/writing-tests) for full documentation.
29
+
30
+ ```ts math.test.ts icon="/icons/typescript.svg"
31
+ import { expect, test } from "bun:test";
32
+
33
+ test("2 + 2", () => {
34
+ expect(2 + 2).toBe(4);
35
+ });
36
+ ```
37
+
38
+ The runner recursively searches the working directory for files that match the following patterns:
39
+
40
+ - `*.test.{js|jsx|ts|tsx}`
41
+ - `*_test.{js|jsx|ts|tsx}`
42
+ - `*.spec.{js|jsx|ts|tsx}`
43
+ - `*_spec.{js|jsx|ts|tsx}`
44
+
45
+ You can filter the set of _test files_ to run by passing additional positional arguments to `bun test`. Any test file with a path that matches one of the filters will run. Commonly, these filters will be file or directory names; glob patterns are not yet supported.
46
+
47
+ ```bash terminal icon="terminal"
48
+ bun test <filter> <filter> ...
49
+ ```
50
+
51
+ To filter by _test name_, use the `-t`/`--test-name-pattern` flag.
52
+
53
+ ```sh terminal icon="terminal"
54
+ # run all tests or test suites with "addition" in the name
55
+ bun test --test-name-pattern addition
56
+ ```
57
+
58
+ To run a specific file in the test runner, make sure the path starts with `./` or `/` to distinguish it from a filter name.
59
+
60
+ ```bash terminal icon="terminal"
61
+ bun test ./test/specific-file.test.ts
62
+ ```
63
+
64
+ The test runner runs all tests in a single process. It loads all `--preload` scripts (see [Lifecycle](/docs/test/lifecycle) for details), then runs all tests. If a test fails, the test runner will exit with a non-zero exit code.
65
+
66
+ ## CI/CD integration
67
+
68
+ `bun test` supports a variety of CI/CD integrations.
69
+
70
+ ### GitHub Actions
71
+
72
+ `bun test` automatically detects if it's running inside GitHub Actions and will emit GitHub Actions annotations to the console directly.
73
+
74
+ No configuration is needed, other than installing `bun` in the workflow and running `bun test`.
75
+
76
+ #### How to install `bun` in a GitHub Actions workflow
77
+
78
+ To use `bun test` in a GitHub Actions workflow, add the following step:
79
+
80
+ ```yaml title=".github/workflows/test.yml" icon="file-code"
81
+ jobs:
82
+ build:
83
+ name: build-app
84
+ runs-on: ubuntu-latest
85
+ steps:
86
+ - name: Checkout
87
+ uses: actions/checkout@v4
88
+ - name: Install bun
89
+ uses: oven-sh/setup-bun@v2
90
+ - name: Install dependencies # (assuming your project has dependencies)
91
+ run: bun install # You can use npm/yarn/pnpm instead if you prefer
92
+ - name: Run tests
93
+ run: bun test
94
+ ```
95
+
96
+ From there, you'll get GitHub Actions annotations.
97
+
98
+ ### JUnit XML reports (GitLab, etc.)
99
+
100
+ To use `bun test` with a JUnit XML reporter, you can use the `--reporter=junit` in combination with `--reporter-outfile`.
101
+
102
+ ```sh terminal icon="terminal"
103
+ bun test --reporter=junit --reporter-outfile=./bun.xml
104
+ ```
105
+
106
+ This will continue to output to stdout/stderr as usual, and also write a JUnit
107
+ XML report to the given path at the very end of the test run.
108
+
109
+ JUnit XML is a popular format for reporting test results in CI/CD pipelines.
110
+
111
+ ## Timeouts
112
+
113
+ Use the `--timeout` flag to specify a _per-test_ timeout in milliseconds. If a test times out, it will be marked as failed. The default value is `5000`.
114
+
115
+ ```bash terminal icon="terminal"
116
+ # default value is 5000
117
+ bun test --timeout 20
118
+ ```
119
+
120
+ ## Concurrent test execution
121
+
122
+ By default, Bun runs all tests sequentially within each test file. You can enable concurrent execution to run async tests in parallel, significantly speeding up test suites with independent tests.
123
+
124
+ ### `--concurrent` flag
125
+
126
+ Use the `--concurrent` flag to run all tests concurrently within their respective files:
127
+
128
+ ```sh terminal icon="terminal"
129
+ bun test --concurrent
130
+ ```
131
+
132
+ When this flag is enabled, all tests will run in parallel unless explicitly marked with `test.serial`.
133
+
134
+ ### `--max-concurrency` flag
135
+
136
+ Control the maximum number of tests running simultaneously with the `--max-concurrency` flag:
137
+
138
+ ```sh terminal icon="terminal"
139
+ # Limit to 4 concurrent tests
140
+ bun test --concurrent --max-concurrency 4
141
+
142
+ # Default: 20
143
+ bun test --concurrent
144
+ ```
145
+
146
+ This helps prevent resource exhaustion when running many concurrent tests. The default value is 20.
147
+
148
+ ### `test.concurrent`
149
+
150
+ Mark individual tests to run concurrently, even when the `--concurrent` flag is not used:
151
+
152
+ ```ts title="math.test.ts" icon="/icons/typescript.svg"
153
+ import { test, expect } from "bun:test";
154
+
155
+ // These tests run in parallel with each other
156
+ test.concurrent("concurrent test 1", async () => {
157
+ await fetch("/api/endpoint1");
158
+ expect(true).toBe(true);
159
+ });
160
+
161
+ test.concurrent("concurrent test 2", async () => {
162
+ await fetch("/api/endpoint2");
163
+ expect(true).toBe(true);
164
+ });
165
+
166
+ // This test runs sequentially
167
+ test("sequential test", () => {
168
+ expect(1 + 1).toBe(2);
169
+ });
170
+ ```
171
+
172
+ ### `test.serial`
173
+
174
+ Force tests to run sequentially, even when the `--concurrent` flag is enabled:
175
+
176
+ ```ts title="math.test.ts" icon="/icons/typescript.svg"
177
+ import { test, expect } from "bun:test";
178
+
179
+ let sharedState = 0;
180
+
181
+ // These tests must run in order
182
+ test.serial("first serial test", () => {
183
+ sharedState = 1;
184
+ expect(sharedState).toBe(1);
185
+ });
186
+
187
+ test.serial("second serial test", () => {
188
+ // Depends on the previous test
189
+ expect(sharedState).toBe(1);
190
+ sharedState = 2;
191
+ });
192
+
193
+ // This test can run concurrently if --concurrent is enabled
194
+ test("independent test", () => {
195
+ expect(true).toBe(true);
196
+ });
197
+
198
+ // Chaining test qualifiers
199
+ test.failing.each([1, 2, 3])("chained qualifiers %d", input => {
200
+ expect(input).toBe(0); // This test is expected to fail for each input
201
+ });
202
+ ```
203
+
204
+ ## Retry failed tests
205
+
206
+ Use the `--retry` flag to automatically retry failed tests up to a given number of times. If a test fails and then passes on a subsequent attempt, it is reported as passing.
207
+
208
+ ```sh terminal icon="terminal"
209
+ bun test --retry 3
210
+ ```
211
+
212
+ Per-test `{ retry: N }` overrides the global `--retry` value:
213
+
214
+ ```ts
215
+ // Uses the global --retry value
216
+ test("uses global retry", () => {
217
+ /* ... */
218
+ });
219
+
220
+ // Overrides --retry with its own value
221
+ test("custom retry", { retry: 1 }, () => {
222
+ /* ... */
223
+ });
224
+ ```
225
+
226
+ You can also set this in `bunfig.toml`:
227
+
228
+ ```toml title="bunfig.toml" icon="settings"
229
+ [test]
230
+ retry = 3
231
+ ```
232
+
233
+ ## Rerun tests
234
+
235
+ Use the `--rerun-each` flag to run each test multiple times. This is useful for detecting flaky or non-deterministic test failures.
236
+
237
+ ```sh terminal icon="terminal"
238
+ bun test --rerun-each 100
239
+ ```
240
+
241
+ ## Randomize test execution order
242
+
243
+ Use the `--randomize` flag to run tests in a random order. This helps detect tests that depend on shared state or execution order.
244
+
245
+ ```sh terminal icon="terminal"
246
+ bun test --randomize
247
+ ```
248
+
249
+ When using `--randomize`, the seed used for randomization will be displayed in the test summary:
250
+
251
+ ```sh terminal icon="terminal"
252
+ bun test --randomize
253
+ ```
254
+
255
+ ```txt
256
+ # ... test output ...
257
+ --seed=12345
258
+ 2 pass
259
+ 8 fail
260
+ Ran 10 tests across 2 files. [50.00ms]
261
+ ```
262
+
263
+ ### Reproducible random order with `--seed`
264
+
265
+ Use the `--seed` flag to specify a seed for the randomization. This allows you to reproduce the same test order when debugging order-dependent failures.
266
+
267
+ ```sh terminal icon="terminal"
268
+ # Reproduce a previous randomized run
269
+ bun test --seed 123456
270
+ ```
271
+
272
+ The `--seed` flag implies `--randomize`, so you don't need to specify both. Using the same seed value will always produce the same test execution order, making it easier to debug intermittent failures caused by test interdependencies.
273
+
274
+ ## Bail out with `--bail`
275
+
276
+ Use the `--bail` flag to abort the test run early after a pre-determined number of test failures. By default Bun will run all tests and report all failures, but sometimes in CI environments it's preferable to terminate earlier to reduce CPU usage.
277
+
278
+ ```sh terminal icon="terminal"
279
+ # bail after 1 failure
280
+ bun test --bail
281
+
282
+ # bail after 10 failure
283
+ bun test --bail=10
284
+ ```
285
+
286
+ ## Watch mode
287
+
288
+ Similar to `bun run`, you can pass the `--watch` flag to `bun test` to watch for changes and re-run tests.
289
+
290
+ ```bash terminal icon="terminal"
291
+ bun test --watch
292
+ ```
293
+
294
+ ## Lifecycle hooks
295
+
296
+ Bun supports the following lifecycle hooks:
297
+
298
+ | Hook | Description |
299
+ | ------------ | --------------------------- |
300
+ | `beforeAll` | Runs once before all tests. |
301
+ | `beforeEach` | Runs before each test. |
302
+ | `afterEach` | Runs after each test. |
303
+ | `afterAll` | Runs once after all tests. |
304
+
305
+ These hooks can be defined inside test files, or in a separate file that is preloaded with the `--preload` flag.
306
+
307
+ ```sh terminal icon="terminal"
308
+ bun test --preload ./setup.ts
309
+ ```
310
+
311
+ See [Test > Lifecycle](/docs/test/lifecycle) for complete documentation.
312
+
313
+ ## Mocks
314
+
315
+ Create mock functions with the `mock` function.
316
+
317
+ ```ts title="math.test.ts" icon="/icons/typescript.svg"
318
+ import { test, expect, mock } from "bun:test";
319
+ const random = mock(() => Math.random());
320
+
321
+ test("random", () => {
322
+ const val = random();
323
+ expect(val).toBeGreaterThan(0);
324
+ expect(random).toHaveBeenCalled();
325
+ expect(random).toHaveBeenCalledTimes(1);
326
+ });
327
+ ```
328
+
329
+ Alternatively, you can use `jest.fn()`, it behaves identically.
330
+
331
+ ```ts title="math.test.ts" icon="/icons/typescript.svg"
332
+ import { test, expect, mock } from "bun:test"; // [!code --]
333
+ import { test, expect, jest } from "bun:test"; // [!code ++]
334
+
335
+ const random = mock(() => Math.random()); // [!code --]
336
+ const random = jest.fn(() => Math.random()); // [!code ++]
337
+ ```
338
+
339
+ See [Test > Mocks](/docs/test/mocks) for complete documentation.
340
+
341
+ ## Snapshot testing
342
+
343
+ Snapshots are supported by `bun test`.
344
+
345
+ ```ts title="math.test.ts" icon="/icons/typescript.svg"
346
+ // example usage of toMatchSnapshot
347
+ import { test, expect } from "bun:test";
348
+
349
+ test("snapshot", () => {
350
+ expect({ a: 1 }).toMatchSnapshot();
351
+ });
352
+ ```
353
+
354
+ To update snapshots, use the `--update-snapshots` flag.
355
+
356
+ ```sh terminal icon="terminal"
357
+ bun test --update-snapshots
358
+ ```
359
+
360
+ See [Test > Snapshots](/docs/test/snapshots) for complete documentation.
361
+
362
+ ## UI & DOM testing
363
+
364
+ Bun is compatible with popular UI testing libraries:
365
+
366
+ - [HappyDOM](https://github.com/capricorn86/happy-dom)
367
+ - [DOM Testing Library](https://testing-library.com/docs/dom-testing-library/intro/)
368
+ - [React Testing Library](https://testing-library.com/docs/react-testing-library/intro)
369
+
370
+ See [Test > DOM Testing](/docs/test/dom) for complete documentation.
371
+
372
+ ## Performance
373
+
374
+ Bun's test runner is fast.
375
+
376
+ <Frame>![Running 266 React SSR tests faster than Jest can print its version number.](https://bun.com/images/buntest.jpeg)</Frame>
377
+
378
+ ## AI Agent Integration
379
+
380
+ When using Bun's test runner with AI coding assistants, you can enable quieter output to improve readability and reduce context noise. This feature minimizes test output verbosity while preserving essential failure information.
381
+
382
+ ### Environment Variables
383
+
384
+ Set any of the following environment variables to enable AI-friendly output:
385
+
386
+ - `CLAUDECODE=1` - For Claude Code
387
+ - `REPL_ID=1` - For Replit
388
+ - `AGENT=1` - Generic AI agent flag
389
+
390
+ ### Behavior
391
+
392
+ When an AI agent environment is detected:
393
+
394
+ - Only test failures are displayed in detail
395
+ - Passing, skipped, and todo test indicators are hidden
396
+ - Summary statistics remain intact
397
+
398
+ ```bash terminal icon="terminal"
399
+ # Example: Enable quiet output for Claude Code
400
+ CLAUDECODE=1 bun test
401
+
402
+ # Still shows failures and summary, but hides verbose passing test output
403
+ ```
404
+
405
+ This feature is particularly useful in AI-assisted development workflows where reduced output verbosity improves context efficiency while maintaining visibility into test failures.
406
+
407
+ ---
408
+
409
+ <Test />