Files
outline/server/routes/api/revisions/revisions.test.ts
T
Tom Moor 77cee2806c chore: getJWTToken -> getSessionToken (#12371)
* getJWTToken -> getSessionToken

Ensure expiry is included in payload

* Refactor test harness to avoid direct usage of getSessionToken
2026-05-17 16:58:52 -04:00

328 lines
8.8 KiB
TypeScript

import { createContext } from "@server/context";
import { UserMembership, Revision } from "@server/models";
import {
buildAdmin,
buildCollection,
buildDocument,
buildUser,
} from "@server/test/factories";
import { getTestServer } from "@server/test/support";
const server = getTestServer();
describe("#revisions.info", () => {
it("should return a document revision", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await Revision.createFromDocument(
createContext({ user }),
document
);
const res = await server.post("/api/revisions.info", user, {
body: {
id: revision.id,
},
});
const body = await res.json();
expect(res.status).toEqual(200);
expect(body.data.id).not.toEqual(document.id);
expect(body.data.title).toEqual(document.title);
});
it("should require authorization", async () => {
const admin = await buildAdmin();
const document = await buildDocument({
teamId: admin.teamId,
userId: admin.id,
});
const revision = await Revision.createFromDocument(
createContext({ user: admin }),
document
);
const user = await buildUser();
const res = await server.post("/api/revisions.info", user, {
body: {
id: revision.id,
},
});
expect(res.status).toEqual(403);
});
});
describe("#revisions.update", () => {
it("should update a document revision", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await Revision.createFromDocument(
createContext({ user }),
document
);
const res = await server.post("/api/revisions.update", user, {
body: {
id: revision.id,
name: "new name",
},
});
const body = await res.json();
expect(res.status).toEqual(200);
expect(body.data.name).toEqual("new name");
});
it("should allow setting name to null", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await Revision.createFromDocument(
createContext({ user }),
document
);
const res = await server.post("/api/revisions.update", user, {
body: {
id: revision.id,
name: null,
},
});
const body = await res.json();
expect(res.status).toEqual(200);
expect(body.data.name).toBeNull();
});
it("should not allow setting name to empty string", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await Revision.createFromDocument(
createContext({ user }),
document
);
const res = await server.post("/api/revisions.update", user, {
body: {
id: revision.id,
name: "",
},
});
expect(res.status).toEqual(400);
});
it("should allow an admin to update a document revision", async () => {
const admin = await buildAdmin();
const document = await buildDocument({
teamId: admin.teamId,
userId: admin.id,
});
const revision = await Revision.createFromDocument(
createContext({ user: admin }),
document
);
const res = await server.post("/api/revisions.update", admin, {
body: {
id: revision.id,
name: "new name",
},
});
const body = await res.json();
expect(res.status).toEqual(200);
expect(body.data.name).toEqual("new name");
});
it("should require authorization", async () => {
const admin = await buildAdmin();
const document = await buildDocument({
teamId: admin.teamId,
userId: admin.id,
});
const revision = await Revision.createFromDocument(
createContext({ user: admin }),
document
);
const user = await buildUser();
const res = await server.post("/api/revisions.update", user, {
body: {
id: revision.id,
name: "new name",
},
});
expect(res.status).toEqual(403);
});
});
describe("#revisions.list", () => {
it("should return a document's revisions", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
await Revision.createFromDocument(createContext({ user }), document);
const res = await server.post("/api/revisions.list", user, {
body: {
documentId: document.id,
},
});
const body = await res.json();
expect(res.status).toEqual(200);
expect(body.data.length).toEqual(1);
expect(body.data[0].id).not.toEqual(document.id);
expect(body.data[0].title).toEqual(document.title);
});
it("should not return revisions for document in collection not a member of", async () => {
const user = await buildUser();
const collection = await buildCollection({
userId: user.id,
teamId: user.teamId,
});
const document = await buildDocument({
userId: user.id,
collectionId: collection.id,
teamId: user.teamId,
});
await Revision.createFromDocument(createContext({ user }), document);
collection.permission = null;
await collection.save();
await UserMembership.destroy({
where: {
userId: user.id,
collectionId: collection.id,
},
});
const res = await server.post("/api/revisions.list", user, {
body: {
documentId: document.id,
},
});
expect(res.status).toEqual(403);
});
it("should require authorization", async () => {
const document = await buildDocument();
const user = await buildUser();
const res = await server.post("/api/revisions.list", user, {
body: {
documentId: document.id,
},
});
expect(res.status).toEqual(403);
});
});
describe("#revisions.export", () => {
it("should return revision as markdown by default", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await Revision.createFromDocument(
createContext({ user }),
document
);
const res = await server.post("/api/revisions.export", user, {
body: {
id: revision.id,
},
});
const body = await res.json();
expect(res.status).toEqual(200);
expect(body.data).toContain(document.title);
});
it("should return revision as markdown with accept header", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await Revision.createFromDocument(
createContext({ user }),
document
);
const res = await server.post("/api/revisions.export", user, {
body: {
id: revision.id,
},
headers: {
accept: "text/markdown",
},
});
const body = await res.text();
expect(res.status).toEqual(200);
expect(body).toContain(document.title);
});
it("should return revision as html with accept header", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await Revision.createFromDocument(
createContext({ user }),
document
);
const res = await server.post("/api/revisions.export", user, {
body: {
id: revision.id,
},
headers: {
accept: "text/html",
},
});
const body = await res.text();
expect(res.status).toEqual(200);
expect(body).toContain("<html");
expect(body).toContain(document.title);
});
it("should require authorization without token", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await Revision.createFromDocument(
createContext({ user }),
document
);
const res = await server.post("/api/revisions.export", {
body: {
id: revision.id,
},
});
expect(res.status).toEqual(401);
});
it("should require authorization with incorrect token", async () => {
const admin = await buildAdmin();
const document = await buildDocument({
teamId: admin.teamId,
userId: admin.id,
});
const revision = await Revision.createFromDocument(
createContext({ user: admin }),
document
);
const user = await buildUser();
const res = await server.post("/api/revisions.export", user, {
body: {
id: revision.id,
},
});
expect(res.status).toEqual(403);
});
});