* 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
99 lines
2.1 KiB
TypeScript
99 lines
2.1 KiB
TypeScript
import { buildUser } from "@server/test/factories";
|
|
import { getTestDatabase } from "@server/test/support";
|
|
import userInviter from "./userInviter";
|
|
|
|
const db = getTestDatabase();
|
|
|
|
afterAll(db.disconnect);
|
|
|
|
beforeEach(db.flush);
|
|
|
|
describe("userInviter", () => {
|
|
const ip = "127.0.0.1";
|
|
|
|
it("should return sent invites", async () => {
|
|
const user = await buildUser();
|
|
const response = await userInviter({
|
|
invites: [
|
|
{
|
|
role: "member",
|
|
email: "test@example.com",
|
|
name: "Test",
|
|
},
|
|
],
|
|
user,
|
|
ip,
|
|
});
|
|
expect(response.sent.length).toEqual(1);
|
|
});
|
|
|
|
it("should filter empty invites", async () => {
|
|
const user = await buildUser();
|
|
const response = await userInviter({
|
|
invites: [
|
|
{
|
|
role: "member",
|
|
email: " ",
|
|
name: "Test",
|
|
},
|
|
],
|
|
user,
|
|
ip,
|
|
});
|
|
expect(response.sent.length).toEqual(0);
|
|
});
|
|
|
|
it("should filter obviously bunk emails", async () => {
|
|
const user = await buildUser();
|
|
const response = await userInviter({
|
|
invites: [
|
|
{
|
|
role: "member",
|
|
email: "notanemail",
|
|
name: "Test",
|
|
},
|
|
],
|
|
user,
|
|
ip,
|
|
});
|
|
expect(response.sent.length).toEqual(0);
|
|
});
|
|
|
|
it("should not send duplicates", async () => {
|
|
const user = await buildUser();
|
|
const response = await userInviter({
|
|
invites: [
|
|
{
|
|
role: "member",
|
|
email: "the@same.com",
|
|
name: "Test",
|
|
},
|
|
{
|
|
role: "member",
|
|
email: "the@SAME.COM",
|
|
name: "Test",
|
|
},
|
|
],
|
|
user,
|
|
ip,
|
|
});
|
|
expect(response.sent.length).toEqual(1);
|
|
});
|
|
|
|
it("should not send invites to existing team members", async () => {
|
|
const user = await buildUser();
|
|
const response = await userInviter({
|
|
invites: [
|
|
{
|
|
role: "member",
|
|
email: user.email!,
|
|
name: user.name,
|
|
},
|
|
],
|
|
user,
|
|
ip,
|
|
});
|
|
expect(response.sent.length).toEqual(0);
|
|
});
|
|
});
|