2017-06-28 10:20:22 +02:00
|
|
|
'use strict';
|
|
|
|
|
2018-12-17 09:24:49 +01:00
|
|
|
const test = require('ava');
|
2017-06-28 10:20:22 +02:00
|
|
|
const { setupApp } = require('./../../helpers/test-helper');
|
|
|
|
|
|
|
|
test.serial('returns three feature toggles', async t => {
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.get('/api/admin/features')
|
|
|
|
.expect('Content-Type', /json/)
|
|
|
|
.expect(200)
|
|
|
|
.expect(res => {
|
|
|
|
t.true(res.body.features.length === 3);
|
|
|
|
})
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('gets a feature by name', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.get('/api/admin/features/featureX')
|
|
|
|
.expect('Content-Type', /json/)
|
|
|
|
.expect(200)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('cant get feature that dose not exist', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.get('/api/admin/features/myfeature')
|
|
|
|
.expect('Content-Type', /json/)
|
|
|
|
.expect(404)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('creates new feature toggle', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.post('/api/admin/features')
|
|
|
|
.send({
|
|
|
|
name: 'com.test.feature',
|
|
|
|
enabled: false,
|
|
|
|
strategies: [{ name: 'default' }],
|
|
|
|
})
|
|
|
|
.set('Content-Type', 'application/json')
|
|
|
|
.expect(201)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
2017-11-16 16:45:01 +01:00
|
|
|
test.serial('creates new feature toggle with createdBy unknown', async t => {
|
2017-06-28 10:20:22 +02:00
|
|
|
t.plan(1);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
2017-11-16 16:45:01 +01:00
|
|
|
await request.post('/api/admin/features').send({
|
|
|
|
name: 'com.test.Username',
|
|
|
|
enabled: false,
|
|
|
|
strategies: [{ name: 'default' }],
|
|
|
|
});
|
2017-06-28 10:20:22 +02:00
|
|
|
await request
|
|
|
|
.get('/api/admin/events')
|
|
|
|
.expect(res => {
|
2017-11-16 16:45:01 +01:00
|
|
|
t.true(res.body.events[0].createdBy === 'unknown');
|
2017-06-28 10:20:22 +02:00
|
|
|
})
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('require new feature toggle to have a name', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.post('/api/admin/features')
|
|
|
|
.send({ name: '' })
|
|
|
|
.set('Content-Type', 'application/json')
|
|
|
|
.expect(400)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial(
|
|
|
|
'can not change status of feature toggle that does not exist',
|
|
|
|
async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.put('/api/admin/features/should-not-exist')
|
|
|
|
.send({ name: 'should-not-exist', enabled: false })
|
|
|
|
.set('Content-Type', 'application/json')
|
|
|
|
.expect(404)
|
|
|
|
.then(destroy);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
test.serial('can change status of feature toggle that does exist', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.put('/api/admin/features/featureY')
|
|
|
|
.send({
|
|
|
|
name: 'featureY',
|
|
|
|
enabled: true,
|
|
|
|
strategies: [{ name: 'default' }],
|
|
|
|
})
|
|
|
|
.set('Content-Type', 'application/json')
|
|
|
|
.expect(200)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('can not toggle of feature that does not exist', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.post('/api/admin/features/should-not-exist/toggle')
|
|
|
|
.set('Content-Type', 'application/json')
|
|
|
|
.expect(404)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('can toggle a feature that does exist', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.post('/api/admin/features/featureY/toggle')
|
|
|
|
.set('Content-Type', 'application/json')
|
|
|
|
.expect(200)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('archives a feature by name', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.delete('/api/admin/features/featureX')
|
|
|
|
.expect(200)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('can not archive unknown feature', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.delete('/api/admin/features/featureUnknown')
|
|
|
|
.expect(404)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('refuses to create a feature with an existing name', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.post('/api/admin/features')
|
|
|
|
.send({ name: 'featureX' })
|
|
|
|
.set('Content-Type', 'application/json')
|
2019-01-02 12:38:58 +01:00
|
|
|
.expect(400)
|
2017-06-28 10:20:22 +02:00
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('refuses to validate a feature with an existing name', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.post('/api/admin/features/validate')
|
|
|
|
.send({ name: 'featureX' })
|
|
|
|
.set('Content-Type', 'application/json')
|
2019-01-02 12:38:58 +01:00
|
|
|
.expect(400)
|
2017-06-28 10:20:22 +02:00
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial(
|
|
|
|
'new strategies api can add two strategies to a feature toggle',
|
|
|
|
async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.put('/api/admin/features/featureY')
|
|
|
|
.send({
|
|
|
|
name: 'featureY',
|
|
|
|
description: 'soon to be the #14 feature',
|
|
|
|
enabled: false,
|
|
|
|
strategies: [
|
|
|
|
{
|
|
|
|
name: 'baz',
|
|
|
|
parameters: { foo: 'bar' },
|
|
|
|
},
|
|
|
|
],
|
|
|
|
})
|
|
|
|
.set('Content-Type', 'application/json')
|
|
|
|
.expect(200)
|
|
|
|
.then(destroy);
|
|
|
|
}
|
|
|
|
);
|
2017-12-18 09:08:04 +01:00
|
|
|
|
|
|
|
test.serial('should not be possible to create archived toggle', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { request, destroy } = await setupApp('feature_api_serial');
|
|
|
|
return request
|
|
|
|
.post('/api/admin/features')
|
|
|
|
.send({
|
|
|
|
name: 'featureArchivedX',
|
|
|
|
enabled: false,
|
|
|
|
strategies: [{ name: 'default' }],
|
|
|
|
})
|
|
|
|
.set('Content-Type', 'application/json')
|
2019-01-02 12:38:58 +01:00
|
|
|
.expect(400)
|
2017-12-18 09:08:04 +01:00
|
|
|
.then(destroy);
|
|
|
|
});
|