* perf: reduce memory usage upon running server tests * perf: plug leaks in server/routes * perf: plug leaks in server/scripts * perf: plug leaks in server/policies * perf: plug leaks in server/models * perf: plug leaks in server/middlewares * perf: plug leaks in server/commands * fix: missing await on db.flush * perf: plug leaks in server/queues * chore: remove unused legacy funcs * fix: await on db.flush * perf: await on GC to run in between tests * fix: remove db refs * fix: revert embeds * perf: plug leaks in shared/i18n
38 lines
1.2 KiB
TypeScript
38 lines
1.2 KiB
TypeScript
import { subDays } from "date-fns";
|
|
import { WebhookDelivery } from "@server/models";
|
|
import { buildWebhookDelivery } from "@server/test/factories";
|
|
import { getTestDatabase } from "@server/test/support";
|
|
import CleanupWebhookDeliveriesTask from "./CleanupWebhookDeliveriesTask";
|
|
|
|
const db = getTestDatabase();
|
|
|
|
afterAll(db.disconnect);
|
|
|
|
beforeEach(db.flush);
|
|
|
|
const deliveryExists = async (delivery: WebhookDelivery) => {
|
|
const results = await WebhookDelivery.findOne({ where: { id: delivery.id } });
|
|
return !!results;
|
|
};
|
|
|
|
describe("CleanupWebookDeliveriesTask", () => {
|
|
it("should delete Webhook Deliveries older than 1 week", async () => {
|
|
const brandNewWebhookDelivery = await buildWebhookDelivery({
|
|
createdAt: new Date(),
|
|
});
|
|
const newishWebhookDelivery = await buildWebhookDelivery({
|
|
createdAt: subDays(new Date(), 5),
|
|
});
|
|
const oldWebhookDelivery = await buildWebhookDelivery({
|
|
createdAt: subDays(new Date(), 8),
|
|
});
|
|
|
|
const task = new CleanupWebhookDeliveriesTask();
|
|
await task.perform();
|
|
|
|
expect(await deliveryExists(brandNewWebhookDelivery)).toBe(true);
|
|
expect(await deliveryExists(newishWebhookDelivery)).toBe(true);
|
|
expect(await deliveryExists(oldWebhookDelivery)).toBe(false);
|
|
});
|
|
});
|