Skip to content

O runner de testes do Bun suporta teste de snapshot no estilo Jest via .toMatchSnapshot().

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

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

Na primeira vez que este teste é executado, Bun avaliará o valor passado para expect() e o escreverá no disco em um diretório chamado __snapshots__ que fica junto com o arquivo de teste. (Observe a linha snapshots: +1 added na saída.)

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]

O diretório __snapshots__ contém um arquivo .snap para cada arquivo de teste no diretório.

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

O arquivo snap.test.ts.snap é um arquivo JavaScript que exporta uma versão serializada do valor passado para expect(). O objeto {foo: "bar"} foi serializado para JSON.

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

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

Mais tarde, quando este arquivo de teste for executado novamente, Bun lerá o arquivo de snapshot e o comparará com o valor passado para expect(). Se os valores forem diferentes, o teste falhará.

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]

Para atualizar snapshots, use a flag --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  # o snapshot foi regenerado
 1 expect() calls
Ran 1 tests across 1 files. [102.00ms]

Consulte Docs > Test Runner > Snapshots para documentação completa sobre snapshots com o runner de testes do Bun.

Bun by www.bunjs.com.cn edit