unleash-server
Version:
Unleash is an enterprise ready feature toggles service. It provides different strategies for handling feature toggles.
203 lines • 6.87 kB
JavaScript
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const database_init_1 = __importDefault(require("../../helpers/database-init"));
const test_helper_1 = require("../../helpers/test-helper");
const no_logger_1 = __importDefault(require("../../../fixtures/no-logger"));
let db;
let app;
beforeAll(async () => {
db = await (0, database_init_1.default)('context_api_serial', no_logger_1.default);
app = await (0, test_helper_1.setupApp)(db.stores);
});
afterAll(async () => {
await app.destroy();
await db.destroy();
});
test('gets all context fields', async () => {
expect.assertions(1);
return app.request
.get('/api/admin/context')
.expect('Content-Type', /json/)
.expect(200)
.expect((res) => {
expect(res.body.length).toBe(3);
});
});
test('get the context field', async () => {
expect.assertions(1);
return app.request
.get('/api/admin/context/environment')
.expect('Content-Type', /json/)
.expect(200)
.expect((res) => {
expect(res.body.name).toBe('environment');
});
});
test('should create context field', async () => {
expect.assertions(0);
return app.request
.post('/api/admin/context')
.send({
name: 'country',
description: 'A Country',
})
.set('Content-Type', 'application/json')
.expect(201);
});
test('should create context field with legalValues', async () => {
expect.assertions(3);
const data = {
name: 'region',
description: 'A region',
legalValues: [
{ value: 'north' },
{ value: 'south', description: 'south-desc' },
],
};
await app.request
.post('/api/admin/context')
.send(data)
.set('Content-Type', 'application/json')
.expect(201);
const res = await app.request.get(`/api/admin/context/${data.name}`);
expect(res.body.name).toEqual(data.name);
expect(res.body.description).toEqual(data.description);
expect(res.body.legalValues).toEqual(data.legalValues);
});
test('should update context field with legalValues', async () => {
expect.assertions(3);
const data = {
name: 'environment',
description: 'Updated description',
legalValues: [
{ value: 'dev', description: 'dev-desc' },
{ value: 'prod' },
],
};
await app.request
.put('/api/admin/context/environment')
.send(data)
.set('Content-Type', 'application/json')
.expect(200);
const res = await app.request.get(`/api/admin/context/${data.name}`);
expect(res.body.name).toEqual(data.name);
expect(res.body.description).toEqual(data.description);
expect(res.body.legalValues).toEqual(data.legalValues);
});
test('should reject string legalValues', async () => {
await app.request
.put('/api/admin/context/environment')
.send({ name: 'environment', legalValues: ['a'] })
.set('Content-Type', 'application/json')
.expect(400);
});
test('should reject empty legalValues', async () => {
await app.request
.put('/api/admin/context/environment')
.send({ name: 'environment', legalValues: [{ description: 'b' }] })
.set('Content-Type', 'application/json')
.expect(400);
});
test('should reject legalValues without value', async () => {
await app.request
.put('/api/admin/context/environment')
.send({ name: 'environment', legalValues: [{ description: 'b' }] })
.set('Content-Type', 'application/json')
.expect(400);
});
test('should create context field with stickiness', async () => {
expect.assertions(1);
const name = 'with-sticky';
await app.request
.post('/api/admin/context')
.send({
name,
description: 'A context field supporting stickiness',
stickiness: true,
})
.set('Content-Type', 'application/json');
const res = await app.request.get(`/api/admin/context/${name}`);
const contextField = res.body;
expect(contextField.stickiness).toBe(true);
});
test('should not create context field when name is missing', async () => {
expect.assertions(0);
return app.request
.post('/api/admin/context')
.send({
description: 'A Country',
})
.set('Content-Type', 'application/json')
.expect(400);
});
test('refuses to create a context field with an existing name', async () => {
expect.assertions(0);
return app.request
.post('/api/admin/context')
.send({ name: 'userId' })
.set('Content-Type', 'application/json')
.expect(409);
});
test('should delete context field', async () => {
expect.assertions(0);
return app.request.delete('/api/admin/context/userId').expect(200);
});
test('refuses to create a context not url-friendly name', async () => {
expect.assertions(0);
return app.request
.post('/api/admin/context')
.send({ name: 'not very nice' })
.set('Content-Type', 'application/json')
.expect(400);
});
test('should validate name to ok', async () => {
expect.assertions(0);
return app.request
.post('/api/admin/context/validate')
.send({ name: 'newField' })
.set('Content-Type', 'application/json')
.expect(200);
});
test('should validate name to not ok', async () => {
expect.assertions(0);
return app.request
.post('/api/admin/context/validate')
.send({ name: 'environment' })
.set('Content-Type', 'application/json')
.expect(409);
});
test('should validate name to not ok for non url-friendly', async () => {
expect.assertions(0);
return app.request
.post('/api/admin/context/validate')
.send({ name: 'not url friendly' })
.set('Content-Type', 'application/json')
.expect(400);
});
test('should update context field with stickiness', async () => {
const name = 'with-sticky-update';
await app.request
.post('/api/admin/context')
.send({
name,
description: 'A context field supporting stickiness',
})
.set('Content-Type', 'application/json');
await app.request
.put(`/api/admin/context/${name}`)
.send({
description: 'asd',
legalValues: [],
name,
stickiness: true,
})
.set('Content-Type', 'application/json');
const res = await app.request.get(`/api/admin/context/${name}`);
const contextField = res.body;
expect(contextField.description).toBe('asd');
expect(contextField.stickiness).toBe(true);
});
//# sourceMappingURL=context.e2e.test.js.map