fresh-testing-library
provides various utilitites to write unit/integration
tests for fresh apps.
- Support testing of handlers/middlewares/islands/routes
- Jest-compatible
expect()
API - Emulate Partial rendering, etc. as much as possible
At first, you need to add this library as a dependency to deno.json
or
import_map.json
:
// ...
"imports": {
"$std/": "https://deno.land/std@0.190.0/",
"🏝️/": "./islands/",
"$fresh/": "https://deno.land/x/fresh@1.2.0/",
// ...
// Add the following lines to your deno.json
"$fresh-testing-library": "https://deno.land/x/fresh_testing_library@$MODULE_VERSION/mod.ts",
"$fresh-testing-library/": "https://deno.land/x/fresh_testing_library@$MODULE_VERSION/"
},
// ...
This package requires several permissions.
See docs/permissions for details.
$fresh-testing-library/components.ts
is a thin wrapper to
@testing-library/preact
and
@testing-library/user-event.
This module can be used to test island components.
See examples/island-component.test.tsx for usage.
$fresh-testing-library/expect.ts
provides the expect()
API. It is based on
expect and
jest-mock
packages, so it is compatible with Jest.
import { expect, fn } from "$fresh-testing-library/expect.ts";
expect(1).toBe(1);
const spy = fn();
expect(spy).not.toBeCalled();
spy();
expect(spy).toBeCalled();
// Matchers provided by `@testing-library/jest-dom` are also supported.
expect(expect(null).toBeInTheDocument).toBeTruthy();
You can test fresh middlewares using createFreshContext()
API. See
examples/middleware.test.ts for usage.
You can also test fresh handlers using createFreshContext()
API. See
examples/handler.test.ts for usage.
You can test async route components by combining createFreshContext()
and
render()
. See
examples/async-component.test.tsx for
details.
This library provides submodules so that only necessary functions can be imported.
import { createFreshContext } from "$fresh-testing-library/server.ts";
import {
cleanup,
render,
setup,
userEvent,
} from "$fresh-testing-library/components.ts";
import { expect } from "$fresh-testing-library/expect.ts";
By combining MSW and --location
flag, you can
test a component which calls fetch()
with a relative URL.
First, add the following setting to deno.json
:
{
"imports": {
// Add the following line:
"msw": "npm:msw@2.0.8"
}
}
Now you can use MSW! See examples/msw.test.ts for details.