Crea mocks con la función mock de bun:test.
ts
import { test, expect, mock } from "bun:test";
const random = mock(() => Math.random());La función mock puede aceptar argumentos.
ts
import { test, expect, mock } from "bun:test";
const random = mock((multiplier: number) => multiplier * Math.random());El resultado de mock() es una nueva función que ha sido decorada con algunas propiedades adicionales.
ts
import { mock } from "bun:test";
const random = mock((multiplier: number) => multiplier * Math.random());
random(2);
random(10);
random.mock.calls;
// [[ 2 ], [ 10 ]]
random.mock.results;
// [
// { type: "return", value: 0.6533907460954099 },
// { type: "return", value: 0.6452713933037312 }
// ]Estas propiedades adicionales hacen posible escribir aserciones expect sobre el uso de la función mock, incluyendo cuántas veces fue llamada, los argumentos y los valores de retorno.
ts
import { test, expect, mock } from "bun:test";
const random = mock((multiplier: number) => multiplier * Math.random());
test("random", async () => {
const a = random(1);
const b = random(2);
const c = random(3);
expect(random).toHaveBeenCalled();
expect(random).toHaveBeenCalledTimes(3);
expect(random.mock.args).toEqual([[1], [2], [3]]);
expect(random.mock.results[0]).toEqual({ type: "return", value: a });
});Consulta Documentación > Ejecutor de Pruebas > Mocks para documentación completa sobre simulación con el ejecutor de pruebas de Bun.