test get embed controller

This commit is contained in:
Maxime Cannoodt 2022-09-11 17:47:01 +02:00
parent a675de3420
commit 3b08d84b26
5 changed files with 137 additions and 8 deletions

View File

@ -197,6 +197,47 @@ describe("POST /api/note", () => {
}); });
}); });
describe("Use case: POST note with embeds, then GET embeds", () => {
it("returns a view_url on correct POST body with embeds", async () => {
const payload = {
ciphertext: Buffer.from("sample_ciphertext").toString("base64"),
hmac: Buffer.from("sample_hmac").toString("base64"),
user_id: "f06536e7df6857fc",
embeds: [
{
embed_id: "EMBED_ID",
ciphertext: Buffer.from("sample_ciphertext").toString("base64"),
hmac: Buffer.from("sample_hmac").toString("base64"),
},
],
};
// make post request
const res = await supertest(app).post("/api/note").send(payload);
// check response and extract note id
expectCodeOrThrowResponse(res, 200);
expect(res.body).toHaveProperty("view_url");
const match = (res.body.view_url as string).match(/note\/(.+)$/);
expect(match).not.toBeNull();
const note_id = (match as RegExpMatchArray)[1];
// make get request for note
const noteRes = await supertest(app).get(`/api/note/${note_id}`);
expectCodeOrThrowResponse(noteRes, 200);
expect(noteRes.body?.ciphertext).toEqual(payload.ciphertext);
expect(noteRes.body?.hmac).toEqual(payload.hmac);
// make get request for embed
const embedRes = await supertest(app).get(
`/api/note/${note_id}/embeds/EMBED_ID`
);
expectCodeOrThrowResponse(embedRes, 200);
expect(embedRes.body?.ciphertext).toEqual(payload.embeds[0].ciphertext);
expect(embedRes.body?.hmac).toEqual(payload.embeds[0].hmac);
});
});
describe("Clean expired notes", () => { describe("Clean expired notes", () => {
it("removes expired notes", async () => { it("removes expired notes", async () => {
// insert a note with expiry date in the past using prisma // insert a note with expiry date in the past using prisma
@ -238,9 +279,10 @@ function expectCodeOrThrowResponse(res: supertest.Response, expected: number) {
try { try {
expect(res.status).toBe(expected); expect(res.status).toBe(expected);
} catch (e) { } catch (e) {
throw new Error(` (e as Error).message = `
Unexpected status ${res.status} (expected ${expected}): Unexpected status ${res.status} (expected ${expected}):
Response body: ${res.text}`); Response body: ${res.text}`;
throw e;
} }
} }

View File

@ -1,7 +1,7 @@
import type { NextFunction, Request, Response } from "express"; import type { NextFunction, Request, Response } from "express";
import { getEmbed } from "../../../db/embed.dao"; import { getEmbed } from "../../../db/embed.dao";
export async function getNoteController( export async function getEmbedController(
req: Request, req: Request,
res: Response, res: Response,
next: NextFunction next: NextFunction

View File

@ -0,0 +1,87 @@
import express from "express";
import supertest from "supertest";
import { vi, it, expect, describe, beforeEach, afterEach } from "vitest";
import { getEmbedController } from "./embeds.get.controller";
import * as embedDao from "../../../db/embed.dao";
vi.mock("../../../db/embed.dao");
const MOCK_EMBED_DTO: embedDao.EncryptedEmbedDTO = {
note_id: "valid_note_id",
embed_id: "valid_embed_id",
ciphertext: Buffer.from("sample_ciphertext").toString("base64"),
hmac: Buffer.from("sample_hmac").toString("base64"),
};
describe("Test GET embeds", () => {
let app: express.Express;
let mockEmbedDao = vi.mocked(embedDao);
beforeEach(() => {
app = express()
.use(express.json())
.get("/:id/embeds/:embed_id", getEmbedController);
});
afterEach(() => {
vi.resetAllMocks();
});
it("Should return 200 for a valid note_id+embed_id pair", async () => {
// mock db response
mockEmbedDao.getEmbed.mockImplementation(async (noteId, embedId) => {
if (
noteId === MOCK_EMBED_DTO.note_id &&
embedId === MOCK_EMBED_DTO.embed_id
) {
return MOCK_EMBED_DTO;
}
return null;
});
// make request
const res = await supertest(app).get(
"/valid_note_id/embeds/valid_embed_id"
);
// check response
expect(res.statusCode).toBe(200);
expect(res.body).toMatchObject(MOCK_EMBED_DTO);
});
it("Should return 404 for an invalid note_id+embed_id pair", async () => {
// mock db response
mockEmbedDao.getEmbed.mockImplementation(async (noteId, embedId) => {
if (
noteId === MOCK_EMBED_DTO.note_id &&
embedId === MOCK_EMBED_DTO.embed_id
) {
return MOCK_EMBED_DTO;
}
return null;
});
// make request
const res = await supertest(app).get(
"/invalid_note_id/embeds/invalid_embed_id"
);
// check response
expect(res.statusCode).toBe(404);
});
it("Should return 500 on database failure", async () => {
// mock db response
mockEmbedDao.getEmbed.mockImplementation(async (noteId, embedId) => {
throw new Error("Database failure");
});
// make request
const res = await supertest(app).get(
"/valid_note_id/embeds/valid_embed_id"
);
// check response
expect(res.statusCode).toBe(500);
});
});

View File

@ -1,6 +1,6 @@
import express from "express"; import express from "express";
import { getNoteController } from "../note.get.controller"; import { getEmbedController } from "./embeds.get.controller";
export const embedsRoute = express.Router({ mergeParams: true }); export const embedsRoute = express.Router({ mergeParams: true });
embedsRoute.get("/:embed_id", getNoteController); embedsRoute.get("/:embed_id", getEmbedController);

View File

@ -25,8 +25,8 @@ const getRateLimit = rateLimit({
}); });
// notesRoute.use(jsonParser, uploadLimit); // notesRoute.use(jsonParser, uploadLimit);
notesRoute.use("/:id/embeds", embedsRoute);
notesRoute.use(uploadLimit); notesRoute.use(uploadLimit);
notesRoute.use(jsonParser); notesRoute.use(jsonParser);
notesRoute.post("", postRateLimit, postNoteController); notesRoute.route("/").post(postRateLimit, postNoteController);
notesRoute.get("/:id", getRateLimit, getNoteController); notesRoute.route("/:id").get(getRateLimit, getNoteController);
notesRoute.use("/:id/embeds/", embedsRoute);