Skip to content

El ejecutor de pruebas de Bun admite pruebas de instantáneas estilo Jest a través de .toMatchSnapshot().

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

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

La primera vez que se ejecuta esta prueba, Bun evaluará el valor pasado a expect() y lo escribirá en disco en un directorio llamado __snapshots__ que vive junto al archivo de prueba. (Nota la línea snapshots: +1 added en la salida.)

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]

El directorio __snapshots__ contiene un archivo .snap por cada archivo de prueba en el directorio.

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

El archivo snap.test.ts.snap es un archivo JavaScript que exporta una versión serializada del valor pasado a expect(). El objeto {foo: "bar"} ha sido serializado a JSON.

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

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

Más tarde, cuando este archivo de prueba se ejecuta nuevamente, Bun leerá el archivo de instantánea y lo comparará con el valor pasado a expect(). Si los valores son diferentes, la prueba fallará.

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 actualizar las instantáneas, usa la bandera --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  # la instantánea fue regenerada
 1 expect() calls
Ran 1 tests across 1 files. [102.00ms]

Consulta Documentación > Ejecutor de Pruebas > Instantáneas para documentación completa sobre instantáneas con el ejecutor de pruebas de Bun.

Bun por www.bunjs.com.cn editar