Skip to content

Le runner de tests de Bun prend en charge les tests de snapshot de style Jest via .toMatchSnapshot().

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

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

La première fois que ce test est exécuté, Bun évaluera la valeur passée dans expect() et l'écrira sur le disque dans un répertoire appelé __snapshots__ qui se trouve à côté du fichier de test. (Notez la ligne snapshots: +1 added dans la sortie.)

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

 1 pass
 0 fail
 snapshots: +1 added
 1 expect() calls
Ran 1 tests across 1 files. [82.00ms]

Le répertoire __snapshots__ contient un fichier .snap pour chaque fichier de test dans le répertoire.

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

Le fichier snap.test.ts.snap est un fichier JavaScript qui exporte une version sérialisée de la valeur passée dans expect(). L'objet {foo: "bar"} a été sérialisé en JSON.

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

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

Plus tard, lorsque ce fichier de test est exécuté à nouveau, Bun lira le fichier de snapshot et le comparera à la valeur passée dans expect(). Si les valeurs sont différentes, le test échouera.

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

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

Pour mettre à jour les snapshots, utilisez l'option --update-snapshots.

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

 1 pass
 0 fail
 snapshots: +1 added  # le snapshot a été régénéré
 1 expect() calls
Ran 1 tests across 1 files. [102.00ms]

Consultez Docs > Test Runner > Snapshots pour la documentation complète sur les snapshots avec le runner de tests Bun.

Bun édité par www.bunjs.com.cn