bun-types 1.3.2-canary.20251105T140650 → 1.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (370) hide show
  1. package/bun.d.ts +102 -6
  2. package/docs/README.md +28 -0
  3. package/docs/bundler/bytecode.mdx +465 -0
  4. package/docs/bundler/{css.md → css.mdx} +97 -101
  5. package/docs/bundler/esbuild.mdx +253 -0
  6. package/docs/bundler/{executables.md → executables.mdx} +130 -221
  7. package/docs/bundler/fullstack.mdx +1064 -0
  8. package/docs/bundler/{hmr.md → hot-reloading.mdx} +74 -79
  9. package/docs/bundler/{html.md → html-static.mdx} +148 -111
  10. package/docs/bundler/index.mdx +1499 -0
  11. package/docs/bundler/loaders.mdx +356 -0
  12. package/docs/bundler/{macros.md → macros.mdx} +83 -84
  13. package/docs/bundler/minifier.mdx +1306 -0
  14. package/docs/bundler/plugins.mdx +411 -0
  15. package/docs/feedback.mdx +85 -0
  16. package/docs/guides/binary/{arraybuffer-to-array.md → arraybuffer-to-array.mdx} +3 -1
  17. package/docs/guides/binary/{arraybuffer-to-blob.md → arraybuffer-to-blob.mdx} +3 -1
  18. package/docs/guides/binary/{arraybuffer-to-buffer.md → arraybuffer-to-buffer.mdx} +3 -1
  19. package/docs/guides/binary/{arraybuffer-to-string.md → arraybuffer-to-string.mdx} +3 -1
  20. package/docs/guides/binary/{arraybuffer-to-typedarray.md → arraybuffer-to-typedarray.mdx} +3 -1
  21. package/docs/guides/binary/{blob-to-arraybuffer.md → blob-to-arraybuffer.mdx} +3 -1
  22. package/docs/guides/binary/{blob-to-dataview.md → blob-to-dataview.mdx} +3 -1
  23. package/docs/guides/binary/{blob-to-stream.md → blob-to-stream.mdx} +3 -1
  24. package/docs/guides/binary/{blob-to-string.md → blob-to-string.mdx} +3 -1
  25. package/docs/guides/binary/{blob-to-typedarray.md → blob-to-typedarray.mdx} +3 -1
  26. package/docs/guides/binary/{buffer-to-arraybuffer.md → buffer-to-arraybuffer.mdx} +3 -1
  27. package/docs/guides/binary/{buffer-to-blob.md → buffer-to-blob.mdx} +3 -1
  28. package/docs/guides/binary/{buffer-to-readablestream.md → buffer-to-readablestream.mdx} +3 -1
  29. package/docs/guides/binary/{buffer-to-string.md → buffer-to-string.mdx} +3 -1
  30. package/docs/guides/binary/{buffer-to-typedarray.md → buffer-to-typedarray.mdx} +3 -1
  31. package/docs/guides/binary/{dataview-to-string.md → dataview-to-string.mdx} +3 -1
  32. package/docs/guides/binary/{typedarray-to-arraybuffer.md → typedarray-to-arraybuffer.mdx} +3 -1
  33. package/docs/guides/binary/{typedarray-to-blob.md → typedarray-to-blob.mdx} +3 -1
  34. package/docs/guides/binary/{typedarray-to-buffer.md → typedarray-to-buffer.mdx} +3 -1
  35. package/docs/guides/binary/{typedarray-to-dataview.md → typedarray-to-dataview.mdx} +3 -1
  36. package/docs/guides/binary/{typedarray-to-readablestream.md → typedarray-to-readablestream.mdx} +3 -1
  37. package/docs/guides/binary/{typedarray-to-string.md → typedarray-to-string.mdx} +3 -1
  38. package/docs/guides/deployment/aws-lambda.mdx +204 -0
  39. package/docs/guides/deployment/digital-ocean.mdx +161 -0
  40. package/docs/guides/deployment/google-cloud-run.mdx +197 -0
  41. package/docs/guides/deployment/{railway.md → railway.mdx} +42 -54
  42. package/docs/guides/deployment/render.mdx +82 -0
  43. package/docs/guides/deployment/vercel.mdx +99 -0
  44. package/docs/guides/ecosystem/{astro.md → astro.mdx} +16 -6
  45. package/docs/guides/ecosystem/{discordjs.md → discordjs.mdx} +21 -18
  46. package/docs/guides/ecosystem/{docker.md → docker.mdx} +25 -14
  47. package/docs/guides/ecosystem/{drizzle.md → drizzle.mdx} +32 -22
  48. package/docs/guides/ecosystem/{edgedb.md → edgedb.mdx} +63 -34
  49. package/docs/guides/ecosystem/{elysia.md → elysia.mdx} +11 -11
  50. package/docs/guides/ecosystem/{express.md → express.mdx} +12 -9
  51. package/docs/guides/ecosystem/{hono.md → hono.mdx} +16 -8
  52. package/docs/guides/ecosystem/{mongoose.md → mongoose.mdx} +26 -21
  53. package/docs/guides/ecosystem/{neon-drizzle.md → neon-drizzle.mdx} +49 -35
  54. package/docs/guides/ecosystem/{neon-serverless-postgres.md → neon-serverless-postgres.mdx} +16 -11
  55. package/docs/guides/ecosystem/{nextjs.md → nextjs.mdx} +18 -10
  56. package/docs/guides/ecosystem/{nuxt.md → nuxt.mdx} +45 -11
  57. package/docs/guides/ecosystem/{pm2.md → pm2.mdx} +7 -9
  58. package/docs/guides/ecosystem/prisma-postgres.mdx +169 -0
  59. package/docs/guides/ecosystem/prisma.mdx +164 -0
  60. package/docs/guides/ecosystem/{qwik.md → qwik.mdx} +18 -11
  61. package/docs/guides/ecosystem/{react.md → react.mdx} +9 -7
  62. package/docs/guides/ecosystem/{remix.md → remix.mdx} +45 -26
  63. package/docs/guides/ecosystem/{sentry.md → sentry.mdx} +7 -5
  64. package/docs/guides/ecosystem/{solidstart.md → solidstart.mdx} +21 -13
  65. package/docs/guides/ecosystem/{ssr-react.md → ssr-react.mdx} +9 -11
  66. package/docs/guides/ecosystem/{stric.md → stric.mdx} +16 -17
  67. package/docs/guides/ecosystem/{sveltekit.md → sveltekit.mdx} +42 -29
  68. package/docs/guides/ecosystem/{systemd.md → systemd.mdx} +27 -26
  69. package/docs/guides/ecosystem/upstash.mdx +87 -0
  70. package/docs/guides/ecosystem/{vite.md → vite.mdx} +20 -14
  71. package/docs/guides/html-rewriter/{extract-links.md → extract-links.mdx} +11 -7
  72. package/docs/guides/html-rewriter/{extract-social-meta.md → extract-social-meta.mdx} +6 -2
  73. package/docs/guides/http/{cluster.md → cluster.mdx} +10 -7
  74. package/docs/guides/http/{fetch-unix.md → fetch-unix.mdx} +5 -3
  75. package/docs/guides/http/{fetch.md → fetch.mdx} +5 -3
  76. package/docs/guides/http/{file-uploads.md → file-uploads.mdx} +18 -15
  77. package/docs/guides/http/{hot.md → hot.mdx} +9 -7
  78. package/docs/guides/http/{proxy.md → proxy.mdx} +7 -5
  79. package/docs/guides/http/{server.md → server.mdx} +4 -2
  80. package/docs/guides/http/{simple.md → simple.mdx} +4 -2
  81. package/docs/guides/http/{stream-file.md → stream-file.mdx} +6 -4
  82. package/docs/guides/http/{stream-iterator.md → stream-iterator.mdx} +5 -3
  83. package/docs/guides/http/{stream-node-streams-in-bun.md → stream-node-streams-in-bun.mdx} +4 -2
  84. package/docs/guides/http/{tls.md → tls.mdx} +5 -3
  85. package/docs/guides/index.mdx +10 -0
  86. package/docs/guides/install/{add-dev.md → add-dev.mdx} +8 -6
  87. package/docs/guides/install/add-git.mdx +38 -0
  88. package/docs/guides/install/{add-optional.md → add-optional.mdx} +7 -5
  89. package/docs/guides/install/{add-peer.md → add-peer.mdx} +13 -11
  90. package/docs/guides/install/{add-tarball.md → add-tarball.mdx} +7 -5
  91. package/docs/guides/install/{add.md → add.mdx} +12 -10
  92. package/docs/guides/install/{azure-artifacts.md → azure-artifacts.mdx} +15 -12
  93. package/docs/guides/{runtime/cicd.md → install/cicd.mdx} +13 -13
  94. package/docs/guides/install/{custom-registry.md → custom-registry.mdx} +6 -4
  95. package/docs/guides/install/{from-npm-install-to-bun-install.md → from-npm-install-to-bun-install.mdx} +50 -34
  96. package/docs/guides/install/{git-diff-bun-lockfile.md → git-diff-bun-lockfile.mdx} +14 -11
  97. package/docs/guides/install/{jfrog-artifactory.md → jfrog-artifactory.mdx} +4 -4
  98. package/docs/guides/install/{npm-alias.md → npm-alias.mdx} +6 -4
  99. package/docs/guides/install/{registry-scope.md → registry-scope.mdx} +6 -4
  100. package/docs/guides/install/{trusted.md → trusted.mdx} +22 -18
  101. package/docs/guides/install/{workspaces.md → workspaces.mdx} +13 -13
  102. package/docs/guides/install/{yarnlock.md → yarnlock.mdx} +15 -9
  103. package/docs/guides/process/{argv.md → argv.mdx} +17 -9
  104. package/docs/guides/process/{ctrl-c.md → ctrl-c.mdx} +4 -2
  105. package/docs/guides/process/{ipc.md → ipc.mdx} +13 -10
  106. package/docs/guides/process/{nanoseconds.md → nanoseconds.mdx} +3 -1
  107. package/docs/guides/process/{os-signals.md → os-signals.mdx} +3 -1
  108. package/docs/guides/process/{spawn-stderr.md → spawn-stderr.mdx} +4 -1
  109. package/docs/guides/process/{spawn-stdout.md → spawn-stdout.mdx} +3 -1
  110. package/docs/guides/process/{spawn.md → spawn.mdx} +3 -1
  111. package/docs/guides/process/{stdin.md → stdin.mdx} +15 -7
  112. package/docs/guides/read-file/{arraybuffer.md → arraybuffer.mdx} +5 -3
  113. package/docs/guides/read-file/{buffer.md → buffer.mdx} +4 -2
  114. package/docs/guides/read-file/{exists.md → exists.mdx} +4 -2
  115. package/docs/guides/read-file/{json.md → json.mdx} +4 -2
  116. package/docs/guides/read-file/{mime.md → mime.mdx} +3 -1
  117. package/docs/guides/read-file/{stream.md → stream.mdx} +3 -1
  118. package/docs/guides/read-file/{string.md → string.mdx} +3 -1
  119. package/docs/guides/read-file/{uint8array.md → uint8array.mdx} +3 -1
  120. package/docs/guides/read-file/{watch.md → watch.mdx} +6 -8
  121. package/docs/guides/runtime/{build-time-constants.md → build-time-constants.mdx} +24 -22
  122. package/docs/guides/{install/cicd.md → runtime/cicd.mdx} +11 -7
  123. package/docs/guides/runtime/{codesign-macos-executable.md → codesign-macos-executable.mdx} +14 -9
  124. package/docs/guides/runtime/{define-constant.md → define-constant.mdx} +20 -16
  125. package/docs/guides/runtime/{delete-directory.md → delete-directory.mdx} +5 -3
  126. package/docs/guides/runtime/{delete-file.md → delete-file.mdx} +4 -2
  127. package/docs/guides/runtime/{heap-snapshot.md → heap-snapshot.mdx} +5 -3
  128. package/docs/guides/runtime/{import-html.md → import-html.mdx} +4 -2
  129. package/docs/guides/runtime/{import-json.md → import-json.mdx} +6 -4
  130. package/docs/guides/runtime/{import-toml.md → import-toml.mdx} +5 -3
  131. package/docs/guides/runtime/{import-yaml.md → import-yaml.mdx} +9 -7
  132. package/docs/guides/runtime/{read-env.md → read-env.mdx} +10 -5
  133. package/docs/guides/runtime/{set-env.md → set-env.mdx} +14 -10
  134. package/docs/guides/runtime/{shell.md → shell.mdx} +6 -4
  135. package/docs/guides/runtime/{timezone.md → timezone.mdx} +10 -7
  136. package/docs/guides/runtime/{tsconfig-paths.md → tsconfig-paths.mdx} +5 -3
  137. package/docs/guides/runtime/{typescript.md → typescript.mdx} +8 -6
  138. package/docs/guides/runtime/{vscode-debugger.md → vscode-debugger.mdx} +12 -11
  139. package/docs/guides/runtime/{web-debugger.md → web-debugger.mdx} +39 -18
  140. package/docs/guides/streams/{node-readable-to-arraybuffer.md → node-readable-to-arraybuffer.mdx} +3 -1
  141. package/docs/guides/streams/{node-readable-to-blob.md → node-readable-to-blob.mdx} +3 -1
  142. package/docs/guides/streams/{node-readable-to-json.md → node-readable-to-json.mdx} +3 -1
  143. package/docs/guides/streams/{node-readable-to-string.md → node-readable-to-string.mdx} +3 -1
  144. package/docs/guides/streams/{node-readable-to-uint8array.md → node-readable-to-uint8array.mdx} +3 -1
  145. package/docs/guides/streams/{to-array.md → to-array.mdx} +3 -1
  146. package/docs/guides/streams/{to-arraybuffer.md → to-arraybuffer.mdx} +3 -1
  147. package/docs/guides/streams/{to-blob.md → to-blob.mdx} +3 -1
  148. package/docs/guides/streams/{to-buffer.md → to-buffer.mdx} +3 -1
  149. package/docs/guides/streams/{to-json.md → to-json.mdx} +4 -2
  150. package/docs/guides/streams/{to-string.md → to-string.mdx} +3 -1
  151. package/docs/guides/streams/{to-typedarray.md → to-typedarray.mdx} +3 -1
  152. package/docs/guides/test/{bail.md → bail.mdx} +7 -5
  153. package/docs/guides/test/{coverage-threshold.md → coverage-threshold.mdx} +14 -7
  154. package/docs/guides/test/{coverage.md → coverage.mdx} +9 -4
  155. package/docs/guides/test/{happy-dom.md → happy-dom.mdx} +13 -8
  156. package/docs/guides/test/{migrate-from-jest.md → migrate-from-jest.mdx} +19 -37
  157. package/docs/guides/test/{mock-clock.md → mock-clock.mdx} +3 -1
  158. package/docs/guides/test/{mock-functions.md → mock-functions.mdx} +7 -5
  159. package/docs/guides/test/{rerun-each.md → rerun-each.mdx} +5 -3
  160. package/docs/guides/test/{run-tests.md → run-tests.mdx} +16 -11
  161. package/docs/guides/test/{skip-tests.md → skip-tests.mdx} +8 -4
  162. package/docs/guides/test/{snapshot.md → snapshot.mdx} +20 -13
  163. package/docs/guides/test/spy-on.mdx +49 -0
  164. package/docs/guides/test/{svelte-test.md → svelte-test.mdx} +16 -23
  165. package/docs/guides/test/{testing-library.md → testing-library.mdx} +18 -17
  166. package/docs/guides/test/{timeout.md → timeout.mdx} +5 -3
  167. package/docs/guides/test/{todo-tests.md → todo-tests.mdx} +13 -6
  168. package/docs/guides/test/{update-snapshots.md → update-snapshots.mdx} +9 -6
  169. package/docs/guides/test/{watch-mode.md → watch-mode.mdx} +9 -4
  170. package/docs/guides/util/{base64.md → base64.mdx} +3 -1
  171. package/docs/guides/util/{deep-equals.md → deep-equals.mdx} +5 -3
  172. package/docs/guides/util/{deflate.md → deflate.mdx} +3 -1
  173. package/docs/guides/util/{detect-bun.md → detect-bun.mdx} +3 -1
  174. package/docs/guides/util/{entrypoint.md → entrypoint.mdx} +4 -2
  175. package/docs/guides/util/{escape-html.md → escape-html.mdx} +3 -1
  176. package/docs/guides/util/{file-url-to-path.md → file-url-to-path.mdx} +3 -1
  177. package/docs/guides/util/{gzip.md → gzip.mdx} +3 -1
  178. package/docs/guides/util/{hash-a-password.md → hash-a-password.mdx} +3 -1
  179. package/docs/guides/util/{import-meta-dir.md → import-meta-dir.mdx} +4 -2
  180. package/docs/guides/util/{import-meta-file.md → import-meta-file.mdx} +4 -2
  181. package/docs/guides/util/{import-meta-path.md → import-meta-path.mdx} +4 -2
  182. package/docs/guides/util/{javascript-uuid.md → javascript-uuid.mdx} +3 -1
  183. package/docs/guides/util/{main.md → main.mdx} +19 -8
  184. package/docs/guides/util/{path-to-file-url.md → path-to-file-url.mdx} +3 -1
  185. package/docs/guides/util/{sleep.md → sleep.mdx} +3 -1
  186. package/docs/guides/util/{version.md → version.mdx} +6 -4
  187. package/docs/guides/util/{which-path-to-executable-bin.md → which-path-to-executable-bin.mdx} +4 -2
  188. package/docs/guides/websocket/{compression.md → compression.mdx} +5 -3
  189. package/docs/guides/websocket/{context.md → context.mdx} +9 -12
  190. package/docs/guides/websocket/{pubsub.md → pubsub.mdx} +5 -6
  191. package/docs/guides/websocket/{simple.md → simple.mdx} +5 -3
  192. package/docs/guides/write-file/{append.md → append.mdx} +3 -1
  193. package/docs/guides/write-file/{basic.md → basic.mdx} +3 -1
  194. package/docs/guides/write-file/{blob.md → blob.mdx} +3 -1
  195. package/docs/guides/write-file/{cat.md → cat.mdx} +4 -2
  196. package/docs/guides/write-file/{file-cp.md → file-cp.mdx} +3 -1
  197. package/docs/guides/write-file/{filesink.md → filesink.mdx} +3 -1
  198. package/docs/guides/write-file/{response.md → response.mdx} +3 -1
  199. package/docs/guides/write-file/{stdout.md → stdout.mdx} +3 -1
  200. package/docs/guides/write-file/{stream.md → stream.mdx} +3 -1
  201. package/docs/guides/write-file/{unlink.md → unlink.mdx} +3 -1
  202. package/docs/{index.md → index.mdx} +97 -41
  203. package/docs/installation.mdx +365 -0
  204. package/docs/{cli/bunx.md → pm/bunx.mdx} +25 -31
  205. package/docs/{install/catalogs.md → pm/catalogs.mdx} +18 -24
  206. package/docs/{cli/add.md → pm/cli/add.mdx} +61 -55
  207. package/docs/{install/audit.md → pm/cli/audit.mdx} +11 -8
  208. package/docs/{cli/install.md → pm/cli/install.mdx} +208 -81
  209. package/docs/{cli/link.md → pm/cli/link.mdx} +27 -19
  210. package/docs/{cli/outdated.md → pm/cli/outdated.mdx} +119 -12
  211. package/docs/{install/patch.md → pm/cli/patch.mdx} +25 -15
  212. package/docs/{cli/pm.md → pm/cli/pm.mdx} +96 -62
  213. package/docs/{cli/publish.md → pm/cli/publish.mdx} +38 -35
  214. package/docs/pm/cli/remove.mdx +16 -0
  215. package/docs/{cli/update.md → pm/cli/update.mdx} +26 -15
  216. package/docs/{cli/why.md → pm/cli/why.mdx} +27 -10
  217. package/docs/{cli/filter.md → pm/filter.mdx} +26 -14
  218. package/docs/{install/cache.md → pm/global-cache.mdx} +25 -12
  219. package/docs/{install/isolated.md → pm/isolated-installs.mdx} +32 -24
  220. package/docs/{install/lifecycle.md → pm/lifecycle.mdx} +20 -9
  221. package/docs/{install/lockfile.md → pm/lockfile.mdx} +18 -12
  222. package/docs/{install/npmrc.md → pm/npmrc.mdx} +30 -24
  223. package/docs/{install/overrides.md → pm/overrides.mdx} +47 -37
  224. package/docs/{install/registries.md → pm/scopes-registries.mdx} +8 -3
  225. package/docs/{install/security-scanner-api.md → pm/security-scanner-api.mdx} +22 -8
  226. package/docs/{install/workspaces.md → pm/workspaces.mdx} +17 -22
  227. package/docs/project/{benchmarking.md → benchmarking.mdx} +26 -11
  228. package/docs/project/{bindgen.md → bindgen.mdx} +12 -14
  229. package/docs/project/{building-windows.md → building-windows.mdx} +18 -47
  230. package/docs/project/{contributing.md → contributing.mdx} +56 -60
  231. package/docs/project/feedback.mdx +20 -0
  232. package/docs/project/license.mdx +78 -0
  233. package/docs/project/roadmap.mdx +8 -0
  234. package/docs/quickstart.mdx +240 -0
  235. package/docs/runtime/{autoimport.md → auto-install.mdx} +34 -31
  236. package/docs/{api/binary-data.md → runtime/binary-data.mdx} +77 -269
  237. package/docs/runtime/bun-apis.mdx +59 -0
  238. package/docs/runtime/{bunfig.md → bunfig.mdx} +95 -225
  239. package/docs/{api/cc.md → runtime/c-compiler.mdx} +16 -9
  240. package/docs/{api/spawn.md → runtime/child-process.mdx} +69 -119
  241. package/docs/{api/color.md → runtime/color.mdx} +6 -1
  242. package/docs/{api/console.md → runtime/console.mdx} +17 -7
  243. package/docs/{api/cookie.md → runtime/cookies.mdx} +24 -19
  244. package/docs/runtime/{debugger.md → debugger.mdx} +61 -51
  245. package/docs/runtime/environment-variables.mdx +214 -0
  246. package/docs/{api/ffi.md → runtime/ffi.mdx} +53 -45
  247. package/docs/{api/file-io.md → runtime/file-io.mdx} +41 -101
  248. package/docs/{api/file-system-router.md → runtime/file-system-router.mdx} +8 -2
  249. package/docs/{bundler/loaders.md → runtime/file-types.mdx} +56 -112
  250. package/docs/{api/glob.md → runtime/glob.mdx} +4 -1
  251. package/docs/runtime/globals.mdx +72 -0
  252. package/docs/{api/hashing.md → runtime/hashing.mdx} +18 -22
  253. package/docs/{api/html-rewriter.md → runtime/html-rewriter.mdx} +36 -30
  254. package/docs/runtime/http/cookies.mdx +79 -0
  255. package/docs/runtime/http/error-handling.mdx +40 -0
  256. package/docs/runtime/http/metrics.mdx +36 -0
  257. package/docs/runtime/http/routing.mdx +289 -0
  258. package/docs/runtime/http/server.mdx +647 -0
  259. package/docs/runtime/http/tls.mdx +101 -0
  260. package/docs/{api/websockets.md → runtime/http/websockets.mdx} +62 -231
  261. package/docs/{cli/run.md → runtime/index.mdx} +70 -108
  262. package/docs/runtime/jsx.mdx +115 -0
  263. package/docs/runtime/{modules.md → module-resolution.mdx} +83 -61
  264. package/docs/{api/dns.md → runtime/networking/dns.mdx} +23 -22
  265. package/docs/{api/fetch.md → runtime/networking/fetch.mdx} +10 -5
  266. package/docs/{api/tcp.md → runtime/networking/tcp.mdx} +59 -41
  267. package/docs/{api/udp.md → runtime/networking/udp.mdx} +14 -8
  268. package/docs/{api/node-api.md → runtime/node-api.mdx} +5 -0
  269. package/docs/runtime/{nodejs-apis.md → nodejs-compat.mdx} +9 -4
  270. package/docs/{bundler/plugins.md → runtime/plugins.mdx} +17 -61
  271. package/docs/{api/redis.md → runtime/redis.mdx} +65 -80
  272. package/docs/{api/s3.md → runtime/s3.mdx} +79 -66
  273. package/docs/{api/secrets.md → runtime/secrets.mdx} +27 -10
  274. package/docs/{api/semver.md → runtime/semver.mdx} +9 -4
  275. package/docs/runtime/{shell.md → shell.mdx} +52 -20
  276. package/docs/{api/sql.md → runtime/sql.mdx} +129 -99
  277. package/docs/{api/sqlite.md → runtime/sqlite.mdx} +162 -157
  278. package/docs/{api/streams.md → runtime/streams.mdx} +33 -31
  279. package/docs/{cli/bun-create.md → runtime/templating/create.mdx} +74 -143
  280. package/docs/{cli/init.md → runtime/templating/init.mdx} +24 -51
  281. package/docs/{api/transpiler.md → runtime/transpiler.mdx} +50 -38
  282. package/docs/{typescript.md → runtime/typescript.mdx} +7 -2
  283. package/docs/{api/utils.md → runtime/utils.mdx} +81 -50
  284. package/docs/runtime/{hot.md → watch-mode.mdx} +53 -37
  285. package/docs/runtime/web-apis.mdx +29 -0
  286. package/docs/{api/workers.md → runtime/workers.mdx} +28 -22
  287. package/docs/{api/yaml.md → runtime/yaml.mdx} +33 -232
  288. package/docs/snippets/cli/add.mdx +166 -0
  289. package/docs/snippets/cli/build.mdx +196 -0
  290. package/docs/snippets/cli/feedback.mdx +17 -0
  291. package/docs/snippets/cli/init.mdx +84 -0
  292. package/docs/snippets/cli/install.mdx +173 -0
  293. package/docs/snippets/cli/link.mdx +163 -0
  294. package/docs/snippets/cli/outdated.mdx +140 -0
  295. package/docs/snippets/cli/patch.mdx +171 -0
  296. package/docs/snippets/cli/publish.mdx +198 -0
  297. package/docs/snippets/cli/remove.mdx +146 -0
  298. package/docs/snippets/cli/run.mdx +293 -0
  299. package/docs/snippets/cli/test.mdx +100 -0
  300. package/docs/snippets/cli/update.mdx +144 -0
  301. package/docs/snippets/product-card.mdx +32 -0
  302. package/docs/snippets/product-tiles.mdx +94 -0
  303. package/docs/test/code-coverage.mdx +409 -0
  304. package/docs/test/configuration.mdx +467 -0
  305. package/docs/test/{time.md → dates-times.mdx} +23 -20
  306. package/docs/test/{discovery.md → discovery.mdx} +15 -10
  307. package/docs/test/dom.mdx +226 -0
  308. package/docs/{cli/test.md → test/index.mdx} +77 -94
  309. package/docs/test/lifecycle.mdx +348 -0
  310. package/docs/test/mocks.mdx +637 -0
  311. package/docs/test/{reporters.md → reporters.mdx} +15 -15
  312. package/docs/test/runtime-behavior.mdx +342 -0
  313. package/docs/test/snapshots.mdx +434 -0
  314. package/docs/test/writing-tests.mdx +635 -0
  315. package/docs/typescript.mdx +54 -0
  316. package/package.json +8 -6
  317. package/test.d.ts +2 -2
  318. package/docs/api/file.md +0 -19
  319. package/docs/api/globals.md +0 -387
  320. package/docs/api/http.md +0 -1408
  321. package/docs/api/import-meta.md +0 -69
  322. package/docs/benchmarks.md +0 -120
  323. package/docs/bun-flavored-toml.md +0 -42
  324. package/docs/bundler/css_modules.md +0 -145
  325. package/docs/bundler/fullstack.md +0 -418
  326. package/docs/bundler/index.md +0 -1735
  327. package/docs/bundler/intro.md +0 -75
  328. package/docs/bundler/vs-esbuild.md +0 -1127
  329. package/docs/cli/bun-completions.md +0 -3
  330. package/docs/cli/bun-install.md +0 -349
  331. package/docs/cli/bun-upgrade.md +0 -39
  332. package/docs/cli/info.md +0 -65
  333. package/docs/cli/patch-commit.md +0 -11
  334. package/docs/cli/remove.md +0 -7
  335. package/docs/cli/unlink.md +0 -9
  336. package/docs/contributing/upgrading-webkit.md +0 -57
  337. package/docs/ecosystem/elysia.md +0 -24
  338. package/docs/ecosystem/express.md +0 -37
  339. package/docs/ecosystem/hono.md +0 -18
  340. package/docs/ecosystem/react.md +0 -65
  341. package/docs/ecosystem/stric.md +0 -38
  342. package/docs/guides/ecosystem/prisma.md +0 -141
  343. package/docs/guides/ecosystem/render.md +0 -79
  344. package/docs/guides/install/add-git.md +0 -36
  345. package/docs/guides/test/spy-on.md +0 -46
  346. package/docs/install/index.md +0 -248
  347. package/docs/installation.md +0 -327
  348. package/docs/project/asan.md +0 -124
  349. package/docs/project/internals/build-process-for-ci.md +0 -75
  350. package/docs/project/licensing.md +0 -73
  351. package/docs/project/roadmap.md +0 -87
  352. package/docs/quickstart.md +0 -157
  353. package/docs/runtime/bun-apis.md +0 -207
  354. package/docs/runtime/env.md +0 -253
  355. package/docs/runtime/index.md +0 -312
  356. package/docs/runtime/jsx.md +0 -385
  357. package/docs/runtime/loaders.md +0 -130
  358. package/docs/runtime/plugins.md +0 -561
  359. package/docs/runtime/typescript.md +0 -139
  360. package/docs/runtime/web-apis.md +0 -128
  361. package/docs/test/configuration.md +0 -154
  362. package/docs/test/coverage.md +0 -142
  363. package/docs/test/dom.md +0 -75
  364. package/docs/test/examples/concurrent-test-glob.md +0 -132
  365. package/docs/test/hot.md +0 -15
  366. package/docs/test/lifecycle.md +0 -81
  367. package/docs/test/mocks.md +0 -313
  368. package/docs/test/runtime-behavior.md +0 -95
  369. package/docs/test/snapshots.md +0 -68
  370. package/docs/test/writing.md +0 -825
@@ -0,0 +1,637 @@
1
+ ---
2
+ title: "Mocks"
3
+ description: "Learn how to create and use mock functions, spies, and module mocks in Bun tests"
4
+ ---
5
+
6
+ Mocking is essential for testing by allowing you to replace dependencies with controlled implementations. Bun provides comprehensive mocking capabilities including function mocks, spies, and module mocks.
7
+
8
+ ## Basic Function Mocks
9
+
10
+ Create mocks with the `mock` function.
11
+
12
+ ```ts title="test.ts" icon="/icons/typescript.svg"
13
+ import { test, expect, mock } from "bun:test";
14
+
15
+ const random = mock(() => Math.random());
16
+
17
+ test("random", () => {
18
+ const val = random();
19
+ expect(val).toBeGreaterThan(0);
20
+ expect(random).toHaveBeenCalled();
21
+ expect(random).toHaveBeenCalledTimes(1);
22
+ });
23
+ ```
24
+
25
+ ### Jest Compatibility
26
+
27
+ Alternatively, you can use the `jest.fn()` function, as in Jest. It behaves identically.
28
+
29
+ ```ts title="test.ts" icon="/icons/typescript.svg"
30
+ import { test, expect, jest } from "bun:test";
31
+
32
+ const random = jest.fn(() => Math.random());
33
+
34
+ test("random", () => {
35
+ const val = random();
36
+ expect(val).toBeGreaterThan(0);
37
+ expect(random).toHaveBeenCalled();
38
+ expect(random).toHaveBeenCalledTimes(1);
39
+ });
40
+ ```
41
+
42
+ ## Mock Function Properties
43
+
44
+ The result of `mock()` is a new function that's been decorated with some additional properties.
45
+
46
+ ```ts title="test.ts" icon="/icons/typescript.svg"
47
+ import { mock } from "bun:test";
48
+
49
+ const random = mock((multiplier: number) => multiplier * Math.random());
50
+
51
+ random(2);
52
+ random(10);
53
+
54
+ random.mock.calls;
55
+ // [[ 2 ], [ 10 ]]
56
+
57
+ random.mock.results;
58
+ // [
59
+ // { type: "return", value: 0.6533907460954099 },
60
+ // { type: "return", value: 0.6452713933037312 }
61
+ // ]
62
+ ```
63
+
64
+ ### Available Properties and Methods
65
+
66
+ The following properties and methods are implemented on mock functions:
67
+
68
+ | Property/Method | Description |
69
+ | ----------------------------------------- | ---------------------------------------------- |
70
+ | `mockFn.getMockName()` | Returns the mock name |
71
+ | `mockFn.mock.calls` | Array of call arguments for each invocation |
72
+ | `mockFn.mock.results` | Array of return values for each invocation |
73
+ | `mockFn.mock.instances` | Array of `this` contexts for each invocation |
74
+ | `mockFn.mock.contexts` | Array of `this` contexts for each invocation |
75
+ | `mockFn.mock.lastCall` | Arguments of the most recent call |
76
+ | `mockFn.mockClear()` | Clears call history |
77
+ | `mockFn.mockReset()` | Clears call history and removes implementation |
78
+ | `mockFn.mockRestore()` | Restores original implementation |
79
+ | `mockFn.mockImplementation(fn)` | Sets a new implementation |
80
+ | `mockFn.mockImplementationOnce(fn)` | Sets implementation for next call only |
81
+ | `mockFn.mockName(name)` | Sets the mock name |
82
+ | `mockFn.mockReturnThis()` | Sets the return value to `this` |
83
+ | `mockFn.mockReturnValue(value)` | Sets a return value |
84
+ | `mockFn.mockReturnValueOnce(value)` | Sets return value for next call only |
85
+ | `mockFn.mockResolvedValue(value)` | Sets a resolved Promise value |
86
+ | `mockFn.mockResolvedValueOnce(value)` | Sets resolved Promise for next call only |
87
+ | `mockFn.mockRejectedValue(value)` | Sets a rejected Promise value |
88
+ | `mockFn.mockRejectedValueOnce(value)` | Sets rejected Promise for next call only |
89
+ | `mockFn.withImplementation(fn, callback)` | Temporarily changes implementation |
90
+
91
+ ### Practical Examples
92
+
93
+ #### Basic Mock Usage
94
+
95
+ ```ts title="test.ts" icon="/icons/typescript.svg"
96
+ import { test, expect, mock } from "bun:test";
97
+
98
+ test("mock function behavior", () => {
99
+ const mockFn = mock((x: number) => x * 2);
100
+
101
+ // Call the mock
102
+ const result1 = mockFn(5);
103
+ const result2 = mockFn(10);
104
+
105
+ // Verify calls
106
+ expect(mockFn).toHaveBeenCalledTimes(2);
107
+ expect(mockFn).toHaveBeenCalledWith(5);
108
+ expect(mockFn).toHaveBeenLastCalledWith(10);
109
+
110
+ // Check results
111
+ expect(result1).toBe(10);
112
+ expect(result2).toBe(20);
113
+
114
+ // Inspect call history
115
+ expect(mockFn.mock.calls).toEqual([[5], [10]]);
116
+ expect(mockFn.mock.results).toEqual([
117
+ { type: "return", value: 10 },
118
+ { type: "return", value: 20 },
119
+ ]);
120
+ });
121
+ ```
122
+
123
+ #### Dynamic Mock Implementations
124
+
125
+ ```ts title="test.ts" icon="/icons/typescript.svg"
126
+ import { test, expect, mock } from "bun:test";
127
+
128
+ test("dynamic mock implementations", () => {
129
+ const mockFn = mock();
130
+
131
+ // Set different implementations
132
+ mockFn.mockImplementationOnce(() => "first");
133
+ mockFn.mockImplementationOnce(() => "second");
134
+ mockFn.mockImplementation(() => "default");
135
+
136
+ expect(mockFn()).toBe("first");
137
+ expect(mockFn()).toBe("second");
138
+ expect(mockFn()).toBe("default");
139
+ expect(mockFn()).toBe("default"); // Uses default implementation
140
+ });
141
+ ```
142
+
143
+ #### Async Mocks
144
+
145
+ ```ts title="test.ts" icon="/icons/typescript.svg"
146
+ import { test, expect, mock } from "bun:test";
147
+
148
+ test("async mock functions", async () => {
149
+ const asyncMock = mock();
150
+
151
+ // Mock resolved values
152
+ asyncMock.mockResolvedValueOnce("first result");
153
+ asyncMock.mockResolvedValue("default result");
154
+
155
+ expect(await asyncMock()).toBe("first result");
156
+ expect(await asyncMock()).toBe("default result");
157
+
158
+ // Mock rejected values
159
+ const rejectMock = mock();
160
+ rejectMock.mockRejectedValue(new Error("Mock error"));
161
+
162
+ await expect(rejectMock()).rejects.toThrow("Mock error");
163
+ });
164
+ ```
165
+
166
+ ## Spies with spyOn()
167
+
168
+ It's possible to track calls to a function without replacing it with a mock. Use `spyOn()` to create a spy; these spies can be passed to `.toHaveBeenCalled()` and `.toHaveBeenCalledTimes()`.
169
+
170
+ ```ts title="test.ts" icon="/icons/typescript.svg"
171
+ import { test, expect, spyOn } from "bun:test";
172
+
173
+ const ringo = {
174
+ name: "Ringo",
175
+ sayHi() {
176
+ console.log(`Hello I'm ${this.name}`);
177
+ },
178
+ };
179
+
180
+ const spy = spyOn(ringo, "sayHi");
181
+
182
+ test("spyon", () => {
183
+ expect(spy).toHaveBeenCalledTimes(0);
184
+ ringo.sayHi();
185
+ expect(spy).toHaveBeenCalledTimes(1);
186
+ });
187
+ ```
188
+
189
+ ### Advanced Spy Usage
190
+
191
+ ```ts title="test.ts" icon="/icons/typescript.svg"
192
+ import { test, expect, spyOn, afterEach } from "bun:test";
193
+
194
+ class UserService {
195
+ async getUser(id: string) {
196
+ // Original implementation
197
+ return { id, name: `User ${id}` };
198
+ }
199
+
200
+ async saveUser(user: any) {
201
+ // Original implementation
202
+ return { ...user, saved: true };
203
+ }
204
+ }
205
+
206
+ const userService = new UserService();
207
+
208
+ afterEach(() => {
209
+ // Restore all spies after each test
210
+ jest.restoreAllMocks();
211
+ });
212
+
213
+ test("spy on service methods", async () => {
214
+ // Spy without changing implementation
215
+ const getUserSpy = spyOn(userService, "getUser");
216
+ const saveUserSpy = spyOn(userService, "saveUser");
217
+
218
+ // Use the service normally
219
+ const user = await userService.getUser("123");
220
+ await userService.saveUser(user);
221
+
222
+ // Verify calls
223
+ expect(getUserSpy).toHaveBeenCalledWith("123");
224
+ expect(saveUserSpy).toHaveBeenCalledWith(user);
225
+ });
226
+
227
+ test("spy with mock implementation", async () => {
228
+ // Spy and override implementation
229
+ const getUserSpy = spyOn(userService, "getUser").mockResolvedValue({
230
+ id: "123",
231
+ name: "Mocked User",
232
+ });
233
+
234
+ const result = await userService.getUser("123");
235
+
236
+ expect(result.name).toBe("Mocked User");
237
+ expect(getUserSpy).toHaveBeenCalledWith("123");
238
+ });
239
+ ```
240
+
241
+ ## Module Mocks with mock.module()
242
+
243
+ Module mocking lets you override the behavior of a module. Use `mock.module(path: string, callback: () => Object)` to mock a module.
244
+
245
+ ```ts title="test.ts" icon="/icons/typescript.svg"
246
+ import { test, expect, mock } from "bun:test";
247
+
248
+ mock.module("./module", () => {
249
+ return {
250
+ foo: "bar",
251
+ };
252
+ });
253
+
254
+ test("mock.module", async () => {
255
+ const esm = await import("./module");
256
+ expect(esm.foo).toBe("bar");
257
+
258
+ const cjs = require("./module");
259
+ expect(cjs.foo).toBe("bar");
260
+ });
261
+ ```
262
+
263
+ Like the rest of Bun, module mocks support both `import` and `require`.
264
+
265
+ ### Overriding Already Imported Modules
266
+
267
+ If you need to override a module that's already been imported, there's nothing special you need to do. Just call `mock.module()` and the module will be overridden.
268
+
269
+ ```ts title="test.ts" icon="/icons/typescript.svg"
270
+ import { test, expect, mock } from "bun:test";
271
+
272
+ // The module we're going to mock is here:
273
+ import { foo } from "./module";
274
+
275
+ test("mock.module", async () => {
276
+ const cjs = require("./module");
277
+ expect(foo).toBe("bar");
278
+ expect(cjs.foo).toBe("bar");
279
+
280
+ // We update it here:
281
+ mock.module("./module", () => {
282
+ return {
283
+ foo: "baz",
284
+ };
285
+ });
286
+
287
+ // And the live bindings are updated.
288
+ expect(foo).toBe("baz");
289
+
290
+ // The module is also updated for CJS.
291
+ expect(cjs.foo).toBe("baz");
292
+ });
293
+ ```
294
+
295
+ ### Hoisting & Preloading
296
+
297
+ If you need to ensure a module is mocked before it's imported, you should use `--preload` to load your mocks before your tests run.
298
+
299
+ ```ts title="my-preload.ts" icon="/icons/typescript.svg"
300
+ import { mock } from "bun:test";
301
+
302
+ mock.module("./module", () => {
303
+ return {
304
+ foo: "bar",
305
+ };
306
+ });
307
+ ```
308
+
309
+ ```bash terminal icon="terminal"
310
+ bun test --preload ./my-preload
311
+ ```
312
+
313
+ To make your life easier, you can put preload in your `bunfig.toml`:
314
+
315
+ ```toml title="bunfig.toml" icon="settings"
316
+ [test]
317
+ # Load these modules before running tests.
318
+ preload = ["./my-preload"]
319
+ ```
320
+
321
+ ### Module Mock Best Practices
322
+
323
+ #### When to Use Preload
324
+
325
+ **What happens if I mock a module that's already been imported?**
326
+
327
+ If you mock a module that's already been imported, the module will be updated in the module cache. This means that any modules that import the module will get the mocked version, BUT the original module will still have been evaluated. That means that any side effects from the original module will still have happened.
328
+
329
+ If you want to prevent the original module from being evaluated, you should use `--preload` to load your mocks before your tests run.
330
+
331
+ #### Practical Module Mock Examples
332
+
333
+ ```ts title="api-client.test.ts" icon="/icons/typescript.svg"
334
+ import { test, expect, mock, beforeEach } from "bun:test";
335
+
336
+ // Mock the API client module
337
+ mock.module("./api-client", () => ({
338
+ fetchUser: mock(async (id: string) => ({ id, name: `User ${id}` })),
339
+ createUser: mock(async (user: any) => ({ ...user, id: "new-id" })),
340
+ updateUser: mock(async (id: string, user: any) => ({ ...user, id })),
341
+ }));
342
+
343
+ test("user service with mocked API", async () => {
344
+ const { fetchUser } = await import("./api-client");
345
+ const { UserService } = await import("./user-service");
346
+
347
+ const userService = new UserService();
348
+ const user = await userService.getUser("123");
349
+
350
+ expect(fetchUser).toHaveBeenCalledWith("123");
351
+ expect(user.name).toBe("User 123");
352
+ });
353
+ ```
354
+
355
+ #### Mocking External Dependencies
356
+
357
+ ```ts title="database.test.ts" icon="/icons/typescript.svg"
358
+ import { test, expect, mock } from "bun:test";
359
+
360
+ // Mock external database library
361
+ mock.module("pg", () => ({
362
+ Client: mock(function () {
363
+ return {
364
+ connect: mock(async () => {}),
365
+ query: mock(async (sql: string) => ({
366
+ rows: [{ id: 1, name: "Test User" }],
367
+ })),
368
+ end: mock(async () => {}),
369
+ };
370
+ }),
371
+ }));
372
+
373
+ test("database operations", async () => {
374
+ const { Database } = await import("./database");
375
+ const db = new Database();
376
+
377
+ const users = await db.getUsers();
378
+ expect(users).toHaveLength(1);
379
+ expect(users[0].name).toBe("Test User");
380
+ });
381
+ ```
382
+
383
+ ## Global Mock Functions
384
+
385
+ ### Clear All Mocks
386
+
387
+ Reset all mock function state (calls, results, etc.) without restoring their original implementation:
388
+
389
+ ```ts title="test.ts" icon="/icons/typescript.svg"
390
+ import { expect, mock, test } from "bun:test";
391
+
392
+ const random1 = mock(() => Math.random());
393
+ const random2 = mock(() => Math.random());
394
+
395
+ test("clearing all mocks", () => {
396
+ random1();
397
+ random2();
398
+
399
+ expect(random1).toHaveBeenCalledTimes(1);
400
+ expect(random2).toHaveBeenCalledTimes(1);
401
+
402
+ mock.clearAllMocks();
403
+
404
+ expect(random1).toHaveBeenCalledTimes(0);
405
+ expect(random2).toHaveBeenCalledTimes(0);
406
+
407
+ // Note: implementations are preserved
408
+ expect(typeof random1()).toBe("number");
409
+ expect(typeof random2()).toBe("number");
410
+ });
411
+ ```
412
+
413
+ This resets the `.mock.calls`, `.mock.instances`, `.mock.contexts`, and `.mock.results` properties of all mocks, but unlike `mock.restore()`, it does not restore the original implementation.
414
+
415
+ ### Restore All Mocks
416
+
417
+ Instead of manually restoring each mock individually with `mockFn.mockRestore()`, restore all mocks with one command by calling `mock.restore()`. Doing so does not reset the value of modules overridden with `mock.module()`.
418
+
419
+ ```ts title="test.ts" icon="/icons/typescript.svg"
420
+ import { expect, mock, spyOn, test } from "bun:test";
421
+
422
+ import * as fooModule from "./foo.ts";
423
+ import * as barModule from "./bar.ts";
424
+ import * as bazModule from "./baz.ts";
425
+
426
+ test("foo, bar, baz", () => {
427
+ const fooSpy = spyOn(fooModule, "foo");
428
+ const barSpy = spyOn(barModule, "bar");
429
+ const bazSpy = spyOn(bazModule, "baz");
430
+
431
+ // Original values
432
+ expect(fooSpy).toBe("foo");
433
+ expect(barSpy).toBe("bar");
434
+ expect(bazSpy).toBe("baz");
435
+
436
+ // Mock implementations
437
+ fooSpy.mockImplementation(() => 42);
438
+ barSpy.mockImplementation(() => 43);
439
+ bazSpy.mockImplementation(() => 44);
440
+
441
+ expect(fooSpy()).toBe(42);
442
+ expect(barSpy()).toBe(43);
443
+ expect(bazSpy()).toBe(44);
444
+
445
+ // Restore all
446
+ mock.restore();
447
+
448
+ expect(fooSpy()).toBe("foo");
449
+ expect(barSpy()).toBe("bar");
450
+ expect(bazSpy()).toBe("baz");
451
+ });
452
+ ```
453
+
454
+ Using `mock.restore()` can reduce the amount of code in your tests by adding it to `afterEach` blocks in each test file or even in your test preload code.
455
+
456
+ ## Vitest Compatibility
457
+
458
+ For added compatibility with tests written for Vitest, Bun provides the `vi` global object as an alias for parts of the Jest mocking API:
459
+
460
+ ```ts title="test.ts" icon="/icons/typescript.svg"
461
+ import { test, expect } from "bun:test";
462
+
463
+ // Using the 'vi' alias similar to Vitest
464
+ test("vitest compatibility", () => {
465
+ const mockFn = vi.fn(() => 42);
466
+
467
+ mockFn();
468
+ expect(mockFn).toHaveBeenCalled();
469
+
470
+ // The following functions are available on the vi object:
471
+ // vi.fn
472
+ // vi.spyOn
473
+ // vi.mock
474
+ // vi.restoreAllMocks
475
+ // vi.clearAllMocks
476
+ });
477
+ ```
478
+
479
+ This makes it easier to port tests from Vitest to Bun without having to rewrite all your mocks.
480
+
481
+ ## Implementation Details
482
+
483
+ Understanding how `mock.module()` works helps you use it more effectively:
484
+
485
+ ### Cache Interaction
486
+
487
+ Module mocks interact with both ESM and CommonJS module caches.
488
+
489
+ ### Lazy Evaluation
490
+
491
+ The mock factory callback is only evaluated when the module is actually imported or required.
492
+
493
+ ### Path Resolution
494
+
495
+ Bun automatically resolves the module specifier as though you were doing an import, supporting:
496
+
497
+ - Relative paths (`'./module'`)
498
+ - Absolute paths (`'/path/to/module'`)
499
+ - Package names (`'lodash'`)
500
+
501
+ ### Import Timing Effects
502
+
503
+ - **When mocking before first import**: No side effects from the original module occur
504
+ - **When mocking after import**: The original module's side effects have already happened
505
+
506
+ For this reason, using `--preload` is recommended for mocks that need to prevent side effects.
507
+
508
+ ### Live Bindings
509
+
510
+ Mocked ESM modules maintain live bindings, so changing the mock will update all existing imports.
511
+
512
+ ## Advanced Patterns
513
+
514
+ ### Factory Functions
515
+
516
+ ```ts title="test.ts" icon="/icons/typescript.svg"
517
+ import { mock } from "bun:test";
518
+
519
+ function createMockUser(overrides = {}) {
520
+ return {
521
+ id: "mock-id",
522
+ name: "Mock User",
523
+ email: "mock@example.com",
524
+ ...overrides,
525
+ };
526
+ }
527
+
528
+ const mockUserService = {
529
+ getUser: mock(async (id: string) => createMockUser({ id })),
530
+ createUser: mock(async (data: any) => createMockUser(data)),
531
+ updateUser: mock(async (id: string, data: any) => createMockUser({ id, ...data })),
532
+ };
533
+ ```
534
+
535
+ ### Conditional Mocking
536
+
537
+ ```ts title="test.ts" icon="/icons/typescript.svg"
538
+ import { test, expect, mock } from "bun:test";
539
+
540
+ const shouldUseMockApi = process.env.NODE_ENV === "test";
541
+
542
+ if (shouldUseMockApi) {
543
+ mock.module("./api", () => ({
544
+ fetchData: mock(async () => ({ data: "mocked" })),
545
+ }));
546
+ }
547
+
548
+ test("conditional API usage", async () => {
549
+ const { fetchData } = await import("./api");
550
+ const result = await fetchData();
551
+
552
+ if (shouldUseMockApi) {
553
+ expect(result.data).toBe("mocked");
554
+ }
555
+ });
556
+ ```
557
+
558
+ ### Mock Cleanup Patterns
559
+
560
+ ```ts title="test.ts" icon="/icons/typescript.svg"
561
+ import { afterEach, beforeEach } from "bun:test";
562
+
563
+ beforeEach(() => {
564
+ // Set up common mocks
565
+ mock.module("./logger", () => ({
566
+ log: mock(() => {}),
567
+ error: mock(() => {}),
568
+ warn: mock(() => {}),
569
+ }));
570
+ });
571
+
572
+ afterEach(() => {
573
+ // Clean up all mocks
574
+ mock.restore();
575
+ mock.clearAllMocks();
576
+ });
577
+ ```
578
+
579
+ ## Best Practices
580
+
581
+ ### Keep Mocks Simple
582
+
583
+ ```ts title="test.ts" icon="/icons/typescript.svg"
584
+ // Good: Simple, focused mock
585
+ const mockUserApi = {
586
+ getUser: mock(async id => ({ id, name: "Test User" })),
587
+ };
588
+
589
+ // Avoid: Overly complex mock behavior
590
+ const complexMock = mock(input => {
591
+ if (input.type === "A") {
592
+ return processTypeA(input);
593
+ } else if (input.type === "B") {
594
+ return processTypeB(input);
595
+ }
596
+ // ... lots of complex logic
597
+ });
598
+ ```
599
+
600
+ ### Use Type-Safe Mocks
601
+
602
+ ```ts
603
+ interface UserService {
604
+ getUser(id: string): Promise<User>;
605
+ createUser(data: CreateUserData): Promise<User>;
606
+ }
607
+
608
+ const mockUserService: UserService = {
609
+ getUser: mock(async (id: string) => ({ id, name: "Test User" })),
610
+ createUser: mock(async data => ({ id: "new-id", ...data })),
611
+ };
612
+ ```
613
+
614
+ ### Test Mock Behavior
615
+
616
+ ```ts title="test.ts" icon="/icons/typescript.svg"
617
+ test("service calls API correctly", async () => {
618
+ const mockApi = { fetchUser: mock(async () => ({ id: "1" })) };
619
+
620
+ const service = new UserService(mockApi);
621
+ await service.getUser("123");
622
+
623
+ // Verify the mock was called correctly
624
+ expect(mockApi.fetchUser).toHaveBeenCalledWith("123");
625
+ expect(mockApi.fetchUser).toHaveBeenCalledTimes(1);
626
+ });
627
+ ```
628
+
629
+ ## Notes
630
+
631
+ ### Auto-mocking
632
+
633
+ `__mocks__` directory and auto-mocking are not supported yet. If this is blocking you from switching to Bun, please [file an issue](https://github.com/oven-sh/bun/issues).
634
+
635
+ ### ESM vs CommonJS
636
+
637
+ Module mocks have different implementations for ESM and CommonJS modules. For ES Modules, Bun has added patches to JavaScriptCore that allow Bun to override export values at runtime and update live bindings recursively.
@@ -1,12 +1,19 @@
1
+ ---
2
+ title: Test Reporters
3
+ description:
4
+ ---
5
+
1
6
  bun test supports different output formats through reporters. This document covers both built-in reporters and how to implement your own custom reporters.
2
7
 
8
+ ---
9
+
3
10
  ## Built-in Reporters
4
11
 
5
12
  ### Default Console Reporter
6
13
 
7
14
  By default, bun test outputs results to the console in a human-readable format:
8
15
 
9
- ```sh
16
+ ```sh terminal icon="terminal"
10
17
  test/package-json-lint.test.ts:
11
18
  ✓ test/package.json [0.88ms]
12
19
  ✓ test/js/third_party/grpc-js/package.json [0.18ms]
@@ -21,7 +28,7 @@ Ran 4 tests in 1.44ms
21
28
 
22
29
  When a terminal doesn't support colors, the output avoids non-ascii characters:
23
30
 
24
- ```sh
31
+ ```sh terminal icon="terminal"
25
32
  test/package-json-lint.test.ts:
26
33
  (pass) test/package.json [0.48ms]
27
34
  (pass) test/js/third_party/grpc-js/package.json [0.10ms]
@@ -34,15 +41,6 @@ test/package-json-lint.test.ts:
34
41
  Ran 4 tests across 1 files. [0.66ms]
35
42
  ```
36
43
 
37
- ### Dots Reporter
38
-
39
- The dots reporter shows `.` for passing tests and `F` for failures—useful for large test suites.
40
-
41
- ```sh
42
- $ bun test --dots
43
- $ bun test --reporter=dots
44
- ```
45
-
46
44
  ### JUnit XML Reporter
47
45
 
48
46
  For CI/CD environments, Bun supports generating JUnit XML reports. JUnit XML is a widely-adopted format for test results that can be parsed by many CI/CD systems, including GitLab, Jenkins, and others.
@@ -51,8 +49,8 @@ For CI/CD environments, Bun supports generating JUnit XML reports. JUnit XML is
51
49
 
52
50
  To generate a JUnit XML report, use the `--reporter=junit` flag along with `--reporter-outfile` to specify the output file:
53
51
 
54
- ```sh
55
- $ bun test --reporter=junit --reporter-outfile=./junit.xml
52
+ ```sh terminal icon="terminal"
53
+ bun test --reporter=junit --reporter-outfile=./junit.xml
56
54
  ```
57
55
 
58
56
  This continues to output to the console as usual while also writing the JUnit XML report to the specified path at the end of the test run.
@@ -61,7 +59,7 @@ This continues to output to the console as usual while also writing the JUnit XM
61
59
 
62
60
  You can also configure the JUnit reporter in your `bunfig.toml` file:
63
61
 
64
- ```toml
62
+ ```toml title="bunfig.toml" icon="settings"
65
63
  [test.reporter]
66
64
  junit = "path/to/junit.xml" # Output path for JUnit XML report
67
65
  ```
@@ -91,7 +89,9 @@ The JUnit reporter currently has a few limitations that will be addressed in fut
91
89
 
92
90
  Bun test automatically detects when it's running inside GitHub Actions and emits GitHub Actions annotations to the console directly. No special configuration is needed beyond installing Bun and running `bun test`.
93
91
 
94
- For a GitHub Actions workflow configuration example, see the [CI/CD integration](../cli/test.md#cicd-integration) section of the CLI documentation.
92
+ For a GitHub Actions workflow configuration example, see the [CI/CD integration](/pm/cli/install#ci%2Fcd) section of the CLI documentation.
93
+
94
+ ---
95
95
 
96
96
  ## Custom Reporters
97
97