1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00
unleash.unleash/src/lib/middleware/api-token-middleware.test.ts

277 lines
7.0 KiB
TypeScript
Raw Normal View History

2021-03-29 19:58:11 +02:00
import getLogger from '../../test/fixtures/no-logger';
2021-05-02 20:58:02 +02:00
import { CLIENT } from '../types/permissions';
import { createTestConfig } from '../../test/config/test-config';
import ApiUser from '../types/api-user';
import { ALL, ApiTokenType } from '../types/models/api-token';
import apiTokenMiddleware, {
TOKEN_TYPE_ERROR_MESSAGE,
} from './api-token-middleware';
import { ApiTokenService } from '../services';
import { IUnleashConfig } from '../types';
2021-03-29 19:58:11 +02:00
let config: IUnleashConfig;
2021-03-29 19:58:11 +02:00
beforeEach(() => {
config = createTestConfig({
2021-03-29 19:58:11 +02:00
getLogger,
authentication: {
enableApiToken: true,
},
});
2021-03-29 19:58:11 +02:00
});
test('should not do anything if request does not contain a authorization', async () => {
2021-03-29 19:58:11 +02:00
const apiTokenService = {
getUserForToken: jest.fn(),
} as unknown as ApiTokenService;
2021-03-29 19:58:11 +02:00
const func = apiTokenMiddleware(config, { apiTokenService });
const cb = jest.fn();
2021-03-29 19:58:11 +02:00
const req = {
header: jest.fn(),
2021-03-29 19:58:11 +02:00
};
await func(req, undefined, cb);
expect(req.header).toHaveBeenCalledTimes(1);
expect(cb).toHaveBeenCalledTimes(1);
2021-03-29 19:58:11 +02:00
});
test('should not add user if unknown token', async () => {
2021-03-29 19:58:11 +02:00
const apiTokenService = {
getUserForToken: jest.fn(),
} as unknown as ApiTokenService;
2021-03-29 19:58:11 +02:00
const func = apiTokenMiddleware(config, { apiTokenService });
const cb = jest.fn();
2021-03-29 19:58:11 +02:00
const req = {
header: jest.fn().mockReturnValue('some-token'),
2021-03-29 19:58:11 +02:00
user: undefined,
};
await func(req, undefined, cb);
expect(cb).toHaveBeenCalled();
expect(req.header).toHaveBeenCalled();
expect(req.user).toBeFalsy();
2021-03-29 19:58:11 +02:00
});
test('should not make database query when provided PAT format', async () => {
const apiTokenService = {
getUserForToken: jest.fn(),
} as unknown as ApiTokenService;
const func = apiTokenMiddleware(config, { apiTokenService });
const cb = jest.fn();
const req = {
header: jest.fn().mockReturnValue('user:asdkjsdhg3'),
user: undefined,
};
await func(req, undefined, cb);
expect(apiTokenService.getUserForToken).not.toHaveBeenCalled();
expect(req.header).toHaveBeenCalled();
expect(cb).toHaveBeenCalled();
expect(req.user).toBeFalsy();
});
test('should add user if known token', async () => {
const apiUser = new ApiUser({
tokenName: 'default',
2021-03-29 19:58:11 +02:00
permissions: [CLIENT],
project: ALL,
environment: ALL,
type: ApiTokenType.CLIENT,
secret: 'a',
2021-03-29 19:58:11 +02:00
});
const apiTokenService = {
getUserForToken: jest.fn().mockReturnValue(apiUser),
} as unknown as ApiTokenService;
2021-03-29 19:58:11 +02:00
const func = apiTokenMiddleware(config, { apiTokenService });
const cb = jest.fn();
2021-03-29 19:58:11 +02:00
const req = {
header: jest.fn().mockReturnValue('some-known-token'),
2021-03-29 19:58:11 +02:00
user: undefined,
path: '/api/client',
2021-03-29 19:58:11 +02:00
};
await func(req, undefined, cb);
expect(cb).toHaveBeenCalled();
expect(req.header).toHaveBeenCalled();
expect(req.user).toBe(apiUser);
2021-03-29 19:58:11 +02:00
});
test('should not add user if not /api/client', async () => {
expect.assertions(5);
const apiUser = new ApiUser({
tokenName: 'default',
permissions: [CLIENT],
project: ALL,
environment: ALL,
type: ApiTokenType.CLIENT,
secret: 'a',
});
const apiTokenService = {
getUserForToken: jest.fn().mockReturnValue(apiUser),
} as unknown as ApiTokenService;
const func = apiTokenMiddleware(config, { apiTokenService });
const cb = jest.fn();
const res = {
status: (code: unknown) => ({
send: (data: unknown) => {
expect(code).toEqual(403);
expect(data).toEqual({ message: TOKEN_TYPE_ERROR_MESSAGE });
},
}),
};
const req = {
header: jest.fn().mockReturnValue('some-known-token'),
user: undefined,
path: '/api/admin',
};
await func(req, res, cb);
expect(cb).not.toHaveBeenCalled();
expect(req.header).toHaveBeenCalled();
expect(req.user).toBeUndefined();
});
test('should not add user if disabled', async () => {
const apiUser = new ApiUser({
tokenName: 'default',
2021-03-29 19:58:11 +02:00
permissions: [CLIENT],
project: ALL,
environment: ALL,
type: ApiTokenType.CLIENT,
secret: 'a',
2021-03-29 19:58:11 +02:00
});
const apiTokenService = {
getUserForToken: jest.fn().mockReturnValue(apiUser),
} as unknown as ApiTokenService;
2021-03-29 19:58:11 +02:00
const disabledConfig = createTestConfig({
2021-03-29 19:58:11 +02:00
getLogger,
authentication: {
enableApiToken: false,
createAdminUser: false,
2021-03-29 19:58:11 +02:00
},
});
2021-03-29 19:58:11 +02:00
const func = apiTokenMiddleware(disabledConfig, { apiTokenService });
const cb = jest.fn();
2021-03-29 19:58:11 +02:00
const req = {
header: jest.fn().mockReturnValue('some-known-token'),
2021-03-29 19:58:11 +02:00
user: undefined,
};
const send = jest.fn();
const res = {
status: () => {
return {
send: send,
};
},
};
await func(req, res, cb);
2021-03-29 19:58:11 +02:00
expect(send).not.toHaveBeenCalled();
expect(cb).toHaveBeenCalled();
expect(req.user).toBeFalsy();
2021-03-29 19:58:11 +02:00
});
test('should call next if apiTokenService throws', async () => {
2021-03-29 19:58:11 +02:00
getLogger.setMuteError(true);
const apiTokenService = {
getUserForToken: () => {
throw new Error('hi there, i am stupid');
},
} as unknown as ApiTokenService;
2021-03-29 19:58:11 +02:00
const func = apiTokenMiddleware(config, { apiTokenService });
const cb = jest.fn();
2021-03-29 19:58:11 +02:00
const req = {
header: jest.fn().mockReturnValue('some-token'),
2021-03-29 19:58:11 +02:00
user: undefined,
};
await func(req, undefined, cb);
expect(cb).toHaveBeenCalled();
2021-03-29 19:58:11 +02:00
getLogger.setMuteError(false);
});
test('should call next if apiTokenService throws x2', async () => {
jest.spyOn(global.console, 'error').mockImplementation(() => jest.fn());
2021-03-29 19:58:11 +02:00
const apiTokenService = {
getUserForToken: () => {
throw new Error('hi there, i am stupid');
},
} as unknown as ApiTokenService;
2021-03-29 19:58:11 +02:00
const func = apiTokenMiddleware(config, { apiTokenService });
const cb = jest.fn();
2021-03-29 19:58:11 +02:00
const req = {
header: jest.fn().mockReturnValue('some-token'),
2021-03-29 19:58:11 +02:00
user: undefined,
};
await func(req, undefined, cb);
expect(cb).toHaveBeenCalled();
2021-03-29 19:58:11 +02:00
});
test('should add user if client token and /edge/metrics', async () => {
const apiUser = new ApiUser({
tokenName: 'default',
permissions: [CLIENT],
project: ALL,
environment: ALL,
type: ApiTokenType.CLIENT,
secret: 'a',
});
const apiTokenService = {
getUserForToken: jest.fn().mockReturnValue(apiUser),
} as unknown as ApiTokenService;
const func = apiTokenMiddleware(config, { apiTokenService });
const cb = jest.fn();
const req = {
header: jest.fn().mockReturnValue('some-known-token'),
user: undefined,
path: '/edge/metrics',
method: 'POST',
};
await func(req, undefined, cb);
expect(cb).toHaveBeenCalled();
expect(req.header).toHaveBeenCalled();
expect(req.user).toBe(apiUser);
});