* 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
92 lines
2.5 KiB
TypeScript
92 lines
2.5 KiB
TypeScript
import fs from "fs";
|
|
import path from "path";
|
|
import { FileOperation } from "@server/models";
|
|
import { buildFileOperation } from "@server/test/factories";
|
|
import { getTestDatabase } from "@server/test/support";
|
|
import ImportMarkdownZipTask from "./ImportMarkdownZipTask";
|
|
|
|
const db = getTestDatabase();
|
|
|
|
afterAll(db.disconnect);
|
|
|
|
beforeEach(db.flush);
|
|
|
|
describe("ImportMarkdownZipTask", () => {
|
|
it("should import the documents, attachments", async () => {
|
|
const fileOperation = await buildFileOperation();
|
|
Object.defineProperty(fileOperation, "buffer", {
|
|
get() {
|
|
return fs.readFileSync(
|
|
path.resolve(__dirname, "..", "..", "test", "fixtures", "outline.zip")
|
|
);
|
|
},
|
|
});
|
|
jest.spyOn(FileOperation, "findByPk").mockResolvedValue(fileOperation);
|
|
|
|
const props = {
|
|
fileOperationId: fileOperation.id,
|
|
};
|
|
|
|
const task = new ImportMarkdownZipTask();
|
|
const response = await task.perform(props);
|
|
|
|
expect(response.collections.size).toEqual(1);
|
|
expect(response.documents.size).toEqual(8);
|
|
expect(response.attachments.size).toEqual(6);
|
|
});
|
|
|
|
it("should throw an error with corrupt zip", async () => {
|
|
const fileOperation = await buildFileOperation();
|
|
Object.defineProperty(fileOperation, "buffer", {
|
|
get() {
|
|
return fs.readFileSync(
|
|
path.resolve(__dirname, "..", "..", "test", "fixtures", "corrupt.zip")
|
|
);
|
|
},
|
|
});
|
|
jest.spyOn(FileOperation, "findByPk").mockResolvedValue(fileOperation);
|
|
|
|
const props = {
|
|
fileOperationId: fileOperation.id,
|
|
};
|
|
|
|
let error;
|
|
try {
|
|
const task = new ImportMarkdownZipTask();
|
|
await task.perform(props);
|
|
} catch (err) {
|
|
error = err;
|
|
}
|
|
|
|
expect(error && error.message).toBeTruthy();
|
|
});
|
|
|
|
it("should throw an error with empty collection in zip", async () => {
|
|
const fileOperation = await buildFileOperation();
|
|
Object.defineProperty(fileOperation, "buffer", {
|
|
get() {
|
|
return fs.readFileSync(
|
|
path.resolve(__dirname, "..", "..", "test", "fixtures", "empty.zip")
|
|
);
|
|
},
|
|
});
|
|
jest.spyOn(FileOperation, "findByPk").mockResolvedValue(fileOperation);
|
|
|
|
const props = {
|
|
fileOperationId: fileOperation.id,
|
|
};
|
|
|
|
let error;
|
|
try {
|
|
const task = new ImportMarkdownZipTask();
|
|
await task.perform(props);
|
|
} catch (err) {
|
|
error = err;
|
|
}
|
|
|
|
expect(error && error.message).toBe(
|
|
"Uploaded file does not contain any valid documents"
|
|
);
|
|
});
|
|
});
|