Skip to content

Тестовый раннер Bun поддерживает тестирование по снимкам в стиле Jest через .toMatchSnapshot().

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

test("снимок", () => {
  expect({ foo: "bar" }).toMatchSnapshot();
});

При первом запуске этого теста Bun вычислит значение, переданное в expect(), и запишет его на диск в каталог с именем __snapshots__, который находится рядом с тестовым файлом. (Обратите внимание на строку snapshots: +1 added в выводе.)

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]

Каталог __snapshots__ содержит файл .snap для каждого тестового файла в каталоге.

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

Файл snap.test.ts.snap — это JavaScript-файл, который экспортирует сериализованную версию значения, переданного в expect(). Объект {foo: "bar"} был сериализован в JSON.

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

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

Позже, когда этот тестовый файл будет выполнен снова, Bun прочитает файл снимка и сравнит его со значением, переданным в expect(). Если значения различаются, тест не пройдёт.

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]

Для обновления снимков используйте флаг --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  # снимок был перегенерирован
 1 expect() calls
Ran 1 tests across 1 files. [102.00ms]

Смотрите Документация > Тестирование > Снимки для полной документации о снимках с тестовым раннером Bun.

Bun от www.bunjs.com.cn