mirror of
https://github.com/Unleash/unleash.git
synced 2024-12-22 19:07:54 +01:00
ccaab0c47b
Instead of instructing users to do static calls in to Unleash, she should instead be allwed to specify the log provider as an option to Unleash. This commit introduces the "getLogger" option, a function responsible for creating a logger.
105 lines
3.0 KiB
JavaScript
105 lines
3.0 KiB
JavaScript
'use strict';
|
|
|
|
const test = require('ava');
|
|
const store = require('./../../../test/fixtures/store');
|
|
const permissions = require('../../../test/fixtures/permissions');
|
|
const getLogger = require('../../../test/fixtures/no-logger');
|
|
const supertest = require('supertest');
|
|
const getApp = require('../../app');
|
|
const { UPDATE_FEATURE } = require('../../permissions');
|
|
|
|
const { EventEmitter } = require('events');
|
|
const eventBus = new EventEmitter();
|
|
|
|
function getSetup() {
|
|
const base = `/random${Math.round(Math.random() * 1000)}`;
|
|
const stores = store.createStores();
|
|
const perms = permissions();
|
|
const app = getApp({
|
|
baseUriPath: base,
|
|
stores,
|
|
eventBus,
|
|
extendedPermissions: true,
|
|
preRouterHook: perms.hook,
|
|
getLogger,
|
|
});
|
|
|
|
return {
|
|
base,
|
|
perms,
|
|
archiveStore: stores.featureToggleStore,
|
|
eventStore: stores.eventStore,
|
|
request: supertest(app),
|
|
};
|
|
}
|
|
|
|
test('should get empty getFeatures via admin', t => {
|
|
t.plan(1);
|
|
const { request, base } = getSetup();
|
|
return request
|
|
.get(`${base}/api/admin/archive/features`)
|
|
.expect('Content-Type', /json/)
|
|
.expect(200)
|
|
.expect(res => {
|
|
t.true(res.body.features.length === 0);
|
|
});
|
|
});
|
|
|
|
test('should get archived toggles via admin', t => {
|
|
t.plan(1);
|
|
const { request, base, archiveStore } = getSetup();
|
|
archiveStore.addArchivedFeature({
|
|
name: 'test1',
|
|
strategies: [{ name: 'default' }],
|
|
});
|
|
archiveStore.addArchivedFeature({
|
|
name: 'test2',
|
|
strategies: [{ name: 'default' }],
|
|
});
|
|
return request
|
|
.get(`${base}/api/admin/archive/features`)
|
|
.expect('Content-Type', /json/)
|
|
.expect(200)
|
|
.expect(res => {
|
|
t.true(res.body.features.length === 2);
|
|
});
|
|
});
|
|
|
|
test('should revive toggle', t => {
|
|
t.plan(0);
|
|
const name = 'name1';
|
|
const { request, base, archiveStore, perms } = getSetup();
|
|
perms.withPermissions(UPDATE_FEATURE);
|
|
archiveStore.addArchivedFeature({
|
|
name,
|
|
strategies: [{ name: 'default' }],
|
|
});
|
|
|
|
return request.post(`${base}/api/admin/archive/revive/${name}`).expect(200);
|
|
});
|
|
|
|
test('should create event when reviving toggle', async t => {
|
|
t.plan(4);
|
|
const name = 'name1';
|
|
const { request, base, archiveStore, eventStore, perms } = getSetup();
|
|
perms.withPermissions(UPDATE_FEATURE);
|
|
archiveStore.addArchivedFeature({
|
|
name,
|
|
strategies: [{ name: 'default' }],
|
|
});
|
|
|
|
await request.post(`${base}/api/admin/archive/revive/${name}`);
|
|
|
|
const events = await eventStore.getEvents();
|
|
t.is(events.length, 1);
|
|
t.is(events[0].type, 'feature-revived');
|
|
t.is(events[0].data.name, name);
|
|
t.is(events[0].createdBy, 'unknown');
|
|
});
|
|
|
|
test('should require toggle name when reviving', t => {
|
|
t.plan(0);
|
|
const { request, base } = getSetup();
|
|
return request.post(`${base}/api/admin/archive/revive/`).expect(404);
|
|
});
|