[Runtime
](../../../index.md)[Package Manager
](../../../pm/cli/install/index.md)[Bundler
](../../../bundler/index.md)[Test Runner
](../../../test/index.md)[Guides
](../../index.md)[Reference
](https://bun.com/reference)[Blog
](https://bun.com/blog)[Feedback
](../../../feedback/index.md)
Bun’s test runner supports Jest-style snapshot testing via .toMatchSnapshot().
snap.test.ts
import { test, expect } from "bun:test";
test("snapshot", () => {
expect({ foo: "bar" }).toMatchSnapshot();
});
The first time this test is executed, Bun will write a snapshot file to disk in a directory called __snapshots__ that lives alongside the test file.
File Tree
test
├── __snapshots__
│ └── snap.test.ts.snap
└── snap.test.ts
To regenerate snapshots, use the --update-snapshots flag.
terminal
bun test --update-snapshots
test/snap.test.ts:
✓ snapshot [0.86ms]
1 pass
0 fail
snapshots: +1 added # the snapshot was regenerated
1 expect() calls
Ran 1 tests across 1 files. [102.00ms]
See Docs > Test Runner > Snapshots for complete documentation on snapshots with the Bun test runner.
Was this page helpful?
[
Use snapshot testing in `bun test`
Previous
](../snapshot/index.md)[
Generate code coverage reports with the Bun test runner
Next
](../coverage/index.md)