* 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
237 lines
8.1 KiB
TypeScript
237 lines
8.1 KiB
TypeScript
import randomstring from "randomstring";
|
|
import ApiKey from "@server/models/ApiKey";
|
|
import { buildUser, buildTeam } from "@server/test/factories";
|
|
import { getTestDatabase } from "@server/test/support";
|
|
import auth from "./authentication";
|
|
|
|
const db = getTestDatabase();
|
|
|
|
afterAll(db.disconnect);
|
|
|
|
beforeEach(db.flush);
|
|
|
|
describe("Authentication middleware", () => {
|
|
describe("with JWT", () => {
|
|
it("should authenticate with correct token", async () => {
|
|
const state = {};
|
|
const user = await buildUser();
|
|
const authMiddleware = auth();
|
|
await authMiddleware(
|
|
{
|
|
// @ts-expect-error ts-migrate(2740) FIXME: Type '{ get: Mock<string, []>; }' is missing the f... Remove this comment to see the full error message
|
|
request: {
|
|
get: jest.fn(() => `Bearer ${user.getJwtToken()}`),
|
|
},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
// @ts-expect-error ts-migrate(2339) FIXME: Property 'user' does not exist on type '{}'.
|
|
expect(state.user.id).toEqual(user.id);
|
|
});
|
|
it("should return error with invalid token", async () => {
|
|
const state = {};
|
|
const user = await buildUser();
|
|
const authMiddleware = auth();
|
|
|
|
try {
|
|
await authMiddleware(
|
|
{
|
|
// @ts-expect-error ts-migrate(2740) FIXME: Type '{ get: Mock<string, []>; }' is missing the f... Remove this comment to see the full error message
|
|
request: {
|
|
get: jest.fn(() => `Bearer ${user.getJwtToken()}error`),
|
|
},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
} catch (e) {
|
|
expect(e.message).toBe("Invalid token");
|
|
}
|
|
});
|
|
});
|
|
describe("with API key", () => {
|
|
it("should authenticate user with valid API key", async () => {
|
|
const state = {};
|
|
const user = await buildUser();
|
|
const authMiddleware = auth();
|
|
const key = await ApiKey.create({
|
|
userId: user.id,
|
|
});
|
|
await authMiddleware(
|
|
{
|
|
// @ts-expect-error ts-migrate(2740) FIXME: Type '{ get: Mock<string, []>; }' is missing the f... Remove this comment to see the full error message
|
|
request: {
|
|
get: jest.fn(() => `Bearer ${key.secret}`),
|
|
},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
// @ts-expect-error ts-migrate(2339) FIXME: Property 'user' does not exist on type '{}'.
|
|
expect(state.user.id).toEqual(user.id);
|
|
});
|
|
it("should return error with invalid API key", async () => {
|
|
const state = {};
|
|
const authMiddleware = auth();
|
|
|
|
try {
|
|
await authMiddleware(
|
|
{
|
|
// @ts-expect-error ts-migrate(2740) FIXME: Type '{ get: Mock<string, []>; }' is missing the f... Remove this comment to see the full error message
|
|
request: {
|
|
get: jest.fn(() => `Bearer ${randomstring.generate(38)}`),
|
|
},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
} catch (e) {
|
|
expect(e.message).toBe("Invalid API key");
|
|
}
|
|
});
|
|
});
|
|
|
|
it("should return error message if no auth token is available", async () => {
|
|
const state = {};
|
|
const authMiddleware = auth();
|
|
|
|
try {
|
|
await authMiddleware(
|
|
{
|
|
// @ts-expect-error ts-migrate(2740) FIXME: Type '{ get: Mock<string, []>; }' is missing the f... Remove this comment to see the full error message
|
|
request: {
|
|
get: jest.fn(() => "error"),
|
|
},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
} catch (e) {
|
|
expect(e.message).toBe(
|
|
'Bad Authorization header format. Format is "Authorization: Bearer <token>"'
|
|
);
|
|
}
|
|
});
|
|
|
|
it("should allow passing auth token as a GET param", async () => {
|
|
const state = {};
|
|
const user = await buildUser();
|
|
const authMiddleware = auth();
|
|
await authMiddleware(
|
|
{
|
|
request: {
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type 'Mock<null, []>' is not assignable to type '(... Remove this comment to see the full error message
|
|
get: jest.fn(() => null),
|
|
query: {
|
|
token: user.getJwtToken(),
|
|
},
|
|
},
|
|
body: {},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
// @ts-expect-error ts-migrate(2339) FIXME: Property 'user' does not exist on type '{}'.
|
|
expect(state.user.id).toEqual(user.id);
|
|
});
|
|
|
|
it("should allow passing auth token in body params", async () => {
|
|
const state = {};
|
|
const user = await buildUser();
|
|
const authMiddleware = auth();
|
|
await authMiddleware(
|
|
{
|
|
request: {
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type 'Mock<null, []>' is not assignable to type '(... Remove this comment to see the full error message
|
|
get: jest.fn(() => null),
|
|
},
|
|
body: {
|
|
token: user.getJwtToken(),
|
|
},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
// @ts-expect-error ts-migrate(2339) FIXME: Property 'user' does not exist on type '{}'.
|
|
expect(state.user.id).toEqual(user.id);
|
|
});
|
|
|
|
it("should return an error for suspended users", async () => {
|
|
const state = {};
|
|
const admin = await buildUser();
|
|
const user = await buildUser({
|
|
suspendedAt: new Date(),
|
|
suspendedById: admin.id,
|
|
});
|
|
const authMiddleware = auth();
|
|
let error;
|
|
|
|
try {
|
|
await authMiddleware(
|
|
{
|
|
// @ts-expect-error ts-migrate(2740) FIXME: Type '{ get: Mock<string, []>; }' is missing the f... Remove this comment to see the full error message
|
|
request: {
|
|
get: jest.fn(() => `Bearer ${user.getJwtToken()}`),
|
|
},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
} catch (err) {
|
|
error = err;
|
|
}
|
|
|
|
expect(error.message).toEqual(
|
|
"Your access has been suspended by the team admin"
|
|
);
|
|
expect(error.errorData.adminEmail).toEqual(admin.email);
|
|
});
|
|
|
|
it("should return an error for deleted team", async () => {
|
|
const state = {};
|
|
const team = await buildTeam();
|
|
const user = await buildUser({
|
|
teamId: team.id,
|
|
});
|
|
await team.destroy();
|
|
const authMiddleware = auth();
|
|
let error;
|
|
|
|
try {
|
|
await authMiddleware(
|
|
{
|
|
// @ts-expect-error ts-migrate(2740) FIXME: Type '{ get: Mock<string, []>; }' is missing the f... Remove this comment to see the full error message
|
|
request: {
|
|
get: jest.fn(() => `Bearer ${user.getJwtToken()}`),
|
|
},
|
|
// @ts-expect-error ts-migrate(2322) FIXME: Type '{}' is not assignable to type 'DefaultState ... Remove this comment to see the full error message
|
|
state,
|
|
cache: {},
|
|
},
|
|
jest.fn()
|
|
);
|
|
} catch (err) {
|
|
error = err;
|
|
}
|
|
|
|
expect(error.message).toEqual("Invalid token");
|
|
});
|
|
});
|