Skip to content

Buns Testrunner unterstützt Jest-ähnliche Snapshot-Tests über .toMatchSnapshot().

ts
import { test, expect } from "bun:test";

test("snapshot", () => {
  expect({ foo: "bar" }).toMatchSnapshot();
});

Beim ersten Ausführen dieses Tests bewertet Bun den an expect() übergebenen Wert und schreibt ihn auf die Festplatte in einem Verzeichnis namens __snapshots__, das sich neben der Testdatei befindet. (Beachten Sie die Zeile snapshots: +1 added in der Ausgabe.)

sh
bun test test/snap
txt
test/snap.test.ts:
✓ snapshot [1.48ms]

 1 bestanden
 0 fehlgeschlagen
 snapshots: +1 added
 1 expect()-Aufrufe
Ran 1 tests across 1 files. [82.00ms]

Das __snapshots__-Verzeichnis enthält eine .snap-Datei für jede Testdatei im Verzeichnis.

txt
test
├── __snapshots__
│   └── snap.test.ts.snap
└── snap.test.ts

Die snap.test.ts.snap-Datei ist eine JavaScript-Datei, die eine serialisierte Version des an expect() übergebenen Werts exportiert. Das {foo: "bar"}-Objekt wurde zu JSON serialisiert.

js
// Bun Snapshot v1, https://bun.com/docs/test/snapshots

exports[`snapshot 1`] = `
{
  "foo": "bar",
}
`;

Später, wenn diese Testdatei erneut ausgeführt wird, liest Bun die Snapshot-Datei und vergleicht sie mit dem an expect() übergebenen Wert. Wenn die Werte unterschiedlich sind, schlägt der Test fehl.

sh
bun test
txt
bun test v1.3.3 (9c68abdb)
test/snap.test.ts:
✓ snapshot [1.05ms]

 1 bestanden
 0 fehlgeschlagen
 1 snapshots, 1 expect() calls
Ran 1 tests across 1 files. [101.00ms]

Um Snapshots zu aktualisieren, verwenden Sie das --update-snapshots-Flag.

sh
bun test --update-snapshots
txt
bun test v1.3.3 (9c68abdb)
test/snap.test.ts:
✓ snapshot [0.86ms]

 1 bestanden
 0 fehlgeschlagen
 snapshots: +1 added  # der Snapshot wurde neu generiert
 1 expect() calls
Ran 1 tests across 1 files. [102.00ms]

Siehe Docs > Test Runner > Snapshots für die vollständige Dokumentation zu Snapshots mit dem Bun Testrunner.

Bun von www.bunjs.com.cn bearbeitet