unit test expired note removal
This commit is contained in:
parent
276ac5cfe0
commit
c64633ecd0
@ -5,3 +5,6 @@ POST_LIMIT_WINDOW_SECONDS=0.1
|
||||
GET_LIMIT=20
|
||||
GET_LIMIT_WINDOW_SECONDS=0.1
|
||||
LOG_LEVEL=warn
|
||||
|
||||
# Make cleanup interval very long to avoid automatic cleanup during tests
|
||||
CLEANUP_INTERVAL_SECONDS=99999
|
@ -1,4 +1,4 @@
|
||||
import app from "./app";
|
||||
import app, { cleanExpiredNotes } from "./app";
|
||||
import request from "supertest";
|
||||
import { describe, it, expect } from "vitest";
|
||||
import prisma from "./client";
|
||||
@ -136,3 +136,27 @@ describe("POST /api/note", () => {
|
||||
await new Promise((resolve) => setTimeout(resolve, 100));
|
||||
});
|
||||
});
|
||||
|
||||
describe("Clean expired notes", () => {
|
||||
it("removes expired notes", async () => {
|
||||
// insert a note with expiry date in the past using prisma
|
||||
const { id } = await prisma.encryptedNote.create({
|
||||
data: {
|
||||
...testNote,
|
||||
expire_time: new Date(0),
|
||||
},
|
||||
});
|
||||
|
||||
// make request for note and check that response is 200
|
||||
let res = await request(app).get(`/api/note/${id}`);
|
||||
expect(res.statusCode).toBe(200);
|
||||
|
||||
// run cleanup
|
||||
const nDeleted = await cleanExpiredNotes();
|
||||
expect(nDeleted).toBeGreaterThan(0);
|
||||
|
||||
// make sure note is gone
|
||||
res = await request(app).get(`/api/note/${id}`);
|
||||
expect(res.statusCode).toBe(404);
|
||||
});
|
||||
});
|
||||
|
@ -88,16 +88,8 @@ app.post("/api/note/", postLimiter, (req: Request, res: Response, next) => {
|
||||
.catch(next);
|
||||
});
|
||||
|
||||
// For testing purposes
|
||||
app.get("/api/test", (req, res, next) => {
|
||||
res.status(200).send("Hello world!");
|
||||
});
|
||||
|
||||
// Clean up expired notes periodically
|
||||
const interval =
|
||||
Math.max(parseInt(<string>process.env.CLEANUP_INTERVAL_SECONDS) || 1, 1) *
|
||||
1000;
|
||||
setInterval(async () => {
|
||||
export async function cleanExpiredNotes(): Promise<number | undefined> {
|
||||
try {
|
||||
logger.info("[Cleanup] Cleaning up expired notes...");
|
||||
const deleted = await prisma.encryptedNote.deleteMany({
|
||||
@ -108,10 +100,16 @@ setInterval(async () => {
|
||||
},
|
||||
});
|
||||
logger.info(`[Cleanup] Deleted ${deleted.count} expired notes.`);
|
||||
return deleted.count;
|
||||
} catch (err) {
|
||||
logger.error(`[Cleanup] Error cleaning expired notes:`);
|
||||
logger.error(err);
|
||||
}
|
||||
}, interval);
|
||||
}
|
||||
|
||||
const interval =
|
||||
Math.max(parseInt(<string>process.env.CLEANUP_INTERVAL_SECONDS) || 1, 1) *
|
||||
1000;
|
||||
setInterval(cleanExpiredNotes, interval);
|
||||
|
||||
export default app;
|
||||
|
Loading…
x
Reference in New Issue
Block a user