prisma-cleaner is a prisma extension to automatically delete data when running tests using prisma. Performance is optimized by executing deletion only on tables where data has been added.
import { Prisma, PrismaClient } from "@prisma/client";
import { PrismaCleaner } from "@ubie/prisma-cleaner";
const cleaner = new PrismaCleaner({
prisma: new PrismaClient(),
models: Prisma.dmmf.datamodel.models,
});
const prisma = new PrismaClient().$extends(cleaner.withCleaner());
(async () => {
await prisma.user.create({ ... });
// Delete only user table
await cleaner.cleanup(); // => TRUNCATE TABLE "public"."user" CASCADE
await prisma.user.create({ ... });
await prisma.comment.create({ ... });
// Delete post and comment tables, user table is not included
await cleaner.cleanup(); // => TRUNCATE TABLE "public"."post", "public"."comment" CASCADE
})();
Warning
Currently only PostgreSQL is supported.
$ npm install --save-dev @ubie/prisma-cleaner
// ./src/client.ts
import { PrismaClient } from "@prisma/client";
export const prisma = new PrismaClient();
// ./src/UserService.ts
import type { PrismaClient } from "@prisma/client";
export class UserService {
constructor(private readonly prisma: PrismaClient) {}
createUser(name: string) {
return this.prisma.user.create({
data: { name },
});
}
}
// jest.config.ts
const config: Config = {
// ...
globalSetup: "<rootDir>/test/global-setup.ts",
setupFilesAfterEnv: ["<rootDir>/test/setup.ts"],
};
// ./test/cleander.ts
import { Prisma, PrismaClient } from "@prisma/client";
import { PrismaCleaner } from "@ubie/prisma-cleaner";
export const cleaner = new PrismaCleaner({
prisma: new PrismaClient(),
models: Prisma.dmmf.datamodel.models,
});
// ./test/global-setup.ts
import { cleaner } from "./cleaner";
export default async function setup() {
// This is optional, cleaning all tables first increases the stability of the test.
await cleaner.cleanupAllTables();
}
// ./test/setup.ts
import { PrismaClient } from "@prisma/client";
import { cleaner } from "./cleaner";
afterEach(async () => {
await cleaner.cleanup();
});
// ./src/UserService.test.ts
import { PrismaClient } from "@prisma/client";
import { UserService } from "./UserService";
import { cleaner } from "../test/cleaner";
describe("UserService", () => {
const prisma = new PrismaClient().$extends(cleaner.withCleaner()) as PrismaClient;
const userService = new UserService(prisma);
it("should create a new user", async () => {
// this record will delete by prisma-cleaner in afterEach defined by setup.ts
const user = await userService.createUser("xxx");
expect(user.name).toEqual("xxx");
expect(await prisma.user.count()).toEqual(1);
});
it("should be cleanup user table by cleaner", async () => {
const count = await prisma.user.count();
expect(count).toEqual(0);
});
});
See more examples.
Prisma-cleaner adds tables targeted for deletion triggered by the execution of Prisma's create
, createMany
, upsert
. If added via $executeRaw
or similar, they will not be automatically deleted, so you will need to manually delete them.
await prisma.$executeRaw`INSERT INTO "User" (name) VALUES ('xxx')`;
// You should delete manually.
await cleaner.cleanupTables(["User"]);