1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-20 00:08:02 +01:00
unleash.unleash/src/test/e2e/services/api-token-service.e2e.test.ts

250 lines
7.7 KiB
TypeScript
Raw Normal View History

2021-03-29 19:58:11 +02:00
import dbInit from '../helpers/database-init';
import getLogger from '../../fixtures/no-logger';
import { ApiTokenService } from '../../../lib/services/api-token-service';
import { createTestConfig } from '../../config/test-config';
import { ApiTokenType, IApiToken } from '../../../lib/types/models/api-token';
import { DEFAULT_ENV } from '../../../lib/util/constants';
import { addDays, subDays } from 'date-fns';
import ProjectService from '../../../lib/services/project-service';
import FeatureToggleService from '../../../lib/services/feature-toggle-service';
import { AccessService } from '../../../lib/services/access-service';
import { SegmentService } from '../../../lib/services/segment-service';
import { GroupService } from '../../../lib/services/group-service';
import { FavoritesService } from '../../../lib/services';
import { ChangeRequestAccessReadModel } from '../../../lib/features/change-request-access-service/sql-change-request-access-read-model';
2021-03-29 19:58:11 +02:00
let db;
let stores;
let apiTokenService: ApiTokenService;
let projectService: ProjectService;
let favoritesService: FavoritesService;
2021-03-29 19:58:11 +02:00
beforeAll(async () => {
const config = createTestConfig({
server: { baseUriPath: '/test' },
});
db = await dbInit('api_token_service_serial', getLogger);
2021-03-29 19:58:11 +02:00
stores = db.stores;
const groupService = new GroupService(stores, config);
const accessService = new AccessService(stores, config, groupService);
const changeRequestAccessReadModel = new ChangeRequestAccessReadModel(
db.rawDatabase,
accessService,
);
const featureToggleService = new FeatureToggleService(
stores,
config,
new SegmentService(stores, changeRequestAccessReadModel, config),
accessService,
changeRequestAccessReadModel,
);
const project = {
id: 'test-project',
name: 'Test Project',
description: 'Fancy',
2023-03-16 15:29:52 +01:00
mode: 'open' as const,
defaultStickiness: 'clientId',
};
const user = await stores.userStore.insert({
name: 'Some Name',
email: 'test@getunleash.io',
});
favoritesService = new FavoritesService(stores, config);
projectService = new ProjectService(
stores,
config,
accessService,
featureToggleService,
groupService,
favoritesService,
);
await projectService.createProject(project, user);
apiTokenService = new ApiTokenService(stores, config);
2021-03-29 19:58:11 +02:00
});
afterAll(async () => {
if (db) {
await db.destroy();
}
2021-03-29 19:58:11 +02:00
});
afterEach(async () => {
2021-03-29 19:58:11 +02:00
const tokens = await stores.apiTokenStore.getAll();
const deleteAll = tokens.map((t: IApiToken) =>
stores.apiTokenStore.delete(t.secret),
);
await Promise.all(deleteAll);
});
test('should have empty list of tokens', async () => {
2021-03-29 19:58:11 +02:00
const allTokens = await apiTokenService.getAllTokens();
const activeTokens = await apiTokenService.getAllTokens();
expect(allTokens.length).toBe(0);
expect(activeTokens.length).toBe(0);
2021-03-29 19:58:11 +02:00
});
test('should create client token', async () => {
const token = await apiTokenService.createApiToken({
tokenName: 'default-client',
2021-03-29 19:58:11 +02:00
type: ApiTokenType.CLIENT,
project: '*',
environment: DEFAULT_ENV,
2021-03-29 19:58:11 +02:00
});
const allTokens = await apiTokenService.getAllTokens();
expect(allTokens.length).toBe(1);
expect(token.secret.length > 32).toBe(true);
expect(token.type).toBe(ApiTokenType.CLIENT);
expect(token.username).toBe('default-client');
expect(allTokens[0].secret).toBe(token.secret);
2021-03-29 19:58:11 +02:00
});
test('should create admin token', async () => {
const token = await apiTokenService.createApiToken({
tokenName: 'admin',
2021-03-29 19:58:11 +02:00
type: ApiTokenType.ADMIN,
project: '*',
environment: '*',
2021-03-29 19:58:11 +02:00
});
expect(token.secret.length > 32).toBe(true);
expect(token.type).toBe(ApiTokenType.ADMIN);
2021-03-29 19:58:11 +02:00
});
test('should set expiry of token', async () => {
2021-03-29 19:58:11 +02:00
const time = new Date('2022-01-01');
await apiTokenService.createApiToken({
tokenName: 'default-client',
2021-03-29 19:58:11 +02:00
type: ApiTokenType.CLIENT,
expiresAt: time,
project: '*',
environment: DEFAULT_ENV,
2021-03-29 19:58:11 +02:00
});
const [token] = await apiTokenService.getAllTokens();
expect(token.expiresAt).toEqual(time);
2021-03-29 19:58:11 +02:00
});
test('should update expiry of token', async () => {
2021-03-29 19:58:11 +02:00
const time = new Date('2022-01-01');
const newTime = new Date('2023-01-01');
const token = await apiTokenService.createApiToken(
{
tokenName: 'default-client',
type: ApiTokenType.CLIENT,
expiresAt: time,
project: '*',
environment: DEFAULT_ENV,
},
'tester',
);
2021-03-29 19:58:11 +02:00
await apiTokenService.updateExpiry(token.secret, newTime, 'tester');
2021-03-29 19:58:11 +02:00
const [updatedToken] = await apiTokenService.getAllTokens();
expect(updatedToken.expiresAt).toEqual(newTime);
2021-03-29 19:58:11 +02:00
});
test('should only return valid tokens', async () => {
const now = Date.now();
const yesterday = subDays(now, 1);
const tomorrow = addDays(now, 1);
2021-03-29 19:58:11 +02:00
await apiTokenService.createApiToken({
tokenName: 'default-expired',
2021-03-29 19:58:11 +02:00
type: ApiTokenType.CLIENT,
expiresAt: yesterday,
project: '*',
environment: DEFAULT_ENV,
2021-03-29 19:58:11 +02:00
});
const activeToken = await apiTokenService.createApiToken({
tokenName: 'default-valid',
2021-03-29 19:58:11 +02:00
type: ApiTokenType.CLIENT,
expiresAt: tomorrow,
project: '*',
environment: DEFAULT_ENV,
2021-03-29 19:58:11 +02:00
});
const tokens = await apiTokenService.getAllActiveTokens();
expect(tokens.length).toBe(1);
expect(activeToken.secret).toBe(tokens[0].secret);
2021-03-29 19:58:11 +02:00
});
test('should create client token with project list', async () => {
const token = await apiTokenService.createApiToken({
tokenName: 'default-client',
type: ApiTokenType.CLIENT,
projects: ['default', 'test-project'],
environment: DEFAULT_ENV,
});
expect(token.secret.slice(0, 2)).toEqual('[]');
expect(token.projects).toStrictEqual(['default', 'test-project']);
});
test('should strip all other projects if ALL_PROJECTS is present', async () => {
const token = await apiTokenService.createApiToken({
tokenName: 'default-client',
type: ApiTokenType.CLIENT,
projects: ['*', 'default'],
environment: DEFAULT_ENV,
});
expect(token.projects).toStrictEqual(['*']);
});
test('should return user with multiple projects', async () => {
const now = Date.now();
const tomorrow = addDays(now, 1);
await apiTokenService.createApiToken({
tokenName: 'default-valid',
type: ApiTokenType.CLIENT,
expiresAt: tomorrow,
projects: ['test-project', 'default'],
environment: DEFAULT_ENV,
});
await apiTokenService.createApiToken({
tokenName: 'default-also-valid',
type: ApiTokenType.CLIENT,
expiresAt: tomorrow,
projects: ['test-project'],
environment: DEFAULT_ENV,
});
const tokens = await apiTokenService.getAllActiveTokens();
const multiProjectUser = await apiTokenService.getUserForToken(
tokens[0].secret,
);
const singleProjectUser = await apiTokenService.getUserForToken(
tokens[1].secret,
);
2023-03-16 15:29:52 +01:00
expect(multiProjectUser!.projects).toStrictEqual([
'test-project',
'default',
]);
2023-03-16 15:29:52 +01:00
expect(singleProjectUser!.projects).toStrictEqual(['test-project']);
});
test('should not partially create token if projects are invalid', async () => {
try {
await apiTokenService.createApiTokenWithProjects({
tokenName: 'default-client',
type: ApiTokenType.CLIENT,
projects: ['non-existent-project'],
environment: DEFAULT_ENV,
});
} catch (e) {}
const allTokens = await apiTokenService.getAllTokens();
expect(allTokens.length).toBe(0);
});