* 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
66 lines
2.2 KiB
TypeScript
66 lines
2.2 KiB
TypeScript
import { buildShare, buildDocument } from "@server/test/factories";
|
|
import { getTestDatabase, getTestServer } from "@server/test/support";
|
|
|
|
const db = getTestDatabase();
|
|
const server = getTestServer();
|
|
|
|
afterAll(server.disconnect);
|
|
|
|
beforeEach(db.flush);
|
|
|
|
describe("/share/:id", () => {
|
|
it("should return standard title in html when loading unpublished share", async () => {
|
|
const share = await buildShare({
|
|
published: false,
|
|
});
|
|
const res = await server.get(`/share/${share.id}`);
|
|
const body = await res.text();
|
|
expect(res.status).toEqual(404);
|
|
expect(body).toContain("<title>Outline</title>");
|
|
});
|
|
|
|
it("should return standard title in html when share does not exist", async () => {
|
|
const res = await server.get(`/share/junk`);
|
|
const body = await res.text();
|
|
expect(res.status).toEqual(404);
|
|
expect(body).toContain("<title>Outline</title>");
|
|
});
|
|
|
|
it("should return standard title in html when document is deleted", async () => {
|
|
const document = await buildDocument();
|
|
const share = await buildShare({
|
|
documentId: document.id,
|
|
teamId: document.teamId,
|
|
});
|
|
await document.destroy();
|
|
const res = await server.get(`/share/${share.id}`);
|
|
const body = await res.text();
|
|
expect(res.status).toEqual(404);
|
|
expect(body).toContain("<title>Outline</title>");
|
|
});
|
|
|
|
it("should return document title in html when loading published share", async () => {
|
|
const document = await buildDocument();
|
|
const share = await buildShare({
|
|
documentId: document.id,
|
|
teamId: document.teamId,
|
|
});
|
|
const res = await server.get(`/share/${share.id}`);
|
|
const body = await res.text();
|
|
expect(res.status).toEqual(200);
|
|
expect(body).toContain(`<title>${document.title}</title>`);
|
|
});
|
|
|
|
it("should return document title in html when loading published share with nested doc route", async () => {
|
|
const document = await buildDocument();
|
|
const share = await buildShare({
|
|
documentId: document.id,
|
|
teamId: document.teamId,
|
|
});
|
|
const res = await server.get(`/share/${share.id}/doc/${document.urlId}`);
|
|
const body = await res.text();
|
|
expect(res.status).toEqual(200);
|
|
expect(body).toContain(`<title>${document.title}</title>`);
|
|
});
|
|
});
|