mirror of
https://github.com/Unleash/unleash.git
synced 2024-10-18 20:09:08 +02:00
240c6a77a1
feat: options are now typed - This makes it easier to know what to send to unleash.start / unleash.create - Using a Partial to instantiate the config, then melding it with defaults to get a config object with all fields set either to their defaults or to whatever is passed in. Co-authored-by: Fredrik Strand Oseberg <fredrik.no@gmail.com> Co-authored-by: Ivar Conradi Østhus <ivarconr@gmail.com>
174 lines
4.7 KiB
JavaScript
174 lines
4.7 KiB
JavaScript
'use strict';
|
|
|
|
const test = require('ava');
|
|
const supertest = require('supertest');
|
|
const { EventEmitter } = require('events');
|
|
const store = require('../../../test/fixtures/store');
|
|
const permissions = require('../../../test/fixtures/permissions');
|
|
const getApp = require('../../app');
|
|
const { createTestConfig } = require('../../../test/config/test-config');
|
|
const { createServices } = require('../../services');
|
|
|
|
const eventBus = new EventEmitter();
|
|
|
|
function getSetup() {
|
|
const stores = store.createStores();
|
|
const perms = permissions();
|
|
const config = createTestConfig({
|
|
preRouterHook: perms.hook,
|
|
});
|
|
const services = createServices(stores, config);
|
|
const app = getApp(config, stores, services, eventBus);
|
|
|
|
return {
|
|
request: supertest(app),
|
|
stores,
|
|
perms,
|
|
};
|
|
}
|
|
|
|
test('should return seen toggles even when there is nothing', t => {
|
|
t.plan(1);
|
|
const { request } = getSetup();
|
|
return request
|
|
.get('/api/admin/metrics/seen-toggles')
|
|
.expect(200)
|
|
.expect(res => {
|
|
t.true(res.body.length === 0);
|
|
});
|
|
});
|
|
|
|
test('should return list of seen-toggles per app', t => {
|
|
t.plan(3);
|
|
const { request, stores } = getSetup();
|
|
const appName = 'asd!23';
|
|
stores.clientMetricsStore.emit('metrics', {
|
|
appName,
|
|
instanceId: 'instanceId',
|
|
bucket: {
|
|
start: new Date(),
|
|
stop: new Date(),
|
|
toggles: {
|
|
toggleX: { yes: 123, no: 0 },
|
|
toggleY: { yes: 123, no: 0 },
|
|
},
|
|
},
|
|
});
|
|
|
|
return request
|
|
.get('/api/admin/metrics/seen-toggles')
|
|
.expect(200)
|
|
.expect(res => {
|
|
const seenAppsWithToggles = res.body;
|
|
t.true(seenAppsWithToggles.length === 1);
|
|
t.true(seenAppsWithToggles[0].appName === appName);
|
|
t.true(seenAppsWithToggles[0].seenToggles.length === 2);
|
|
});
|
|
});
|
|
|
|
test('should return feature-toggles metrics even when there is nothing', t => {
|
|
t.plan(0);
|
|
const { request } = getSetup();
|
|
return request.get('/api/admin/metrics/feature-toggles').expect(200);
|
|
});
|
|
|
|
test('should return metrics for all toggles', t => {
|
|
t.plan(2);
|
|
const { request, stores } = getSetup();
|
|
const appName = 'asd!23';
|
|
stores.clientMetricsStore.emit('metrics', {
|
|
appName,
|
|
instanceId: 'instanceId',
|
|
bucket: {
|
|
start: new Date(),
|
|
stop: new Date(),
|
|
toggles: {
|
|
toggleX: { yes: 123, no: 0 },
|
|
toggleY: { yes: 123, no: 0 },
|
|
},
|
|
},
|
|
});
|
|
|
|
return request
|
|
.get('/api/admin/metrics/feature-toggles')
|
|
.expect(200)
|
|
.expect(res => {
|
|
const metrics = res.body;
|
|
t.true(metrics.lastHour !== undefined);
|
|
t.true(metrics.lastMinute !== undefined);
|
|
});
|
|
});
|
|
|
|
test('should return empty list of client applications', t => {
|
|
t.plan(1);
|
|
const { request } = getSetup();
|
|
|
|
return request
|
|
.get('/api/admin/metrics/applications')
|
|
.expect(200)
|
|
.expect(res => {
|
|
t.true(res.body.applications.length === 0);
|
|
});
|
|
});
|
|
|
|
test('should return applications', t => {
|
|
t.plan(2);
|
|
const { request, stores } = getSetup();
|
|
const appName = '123!23';
|
|
|
|
stores.clientApplicationsStore.upsert({ appName });
|
|
|
|
return request
|
|
.get('/api/admin/metrics/applications/')
|
|
.expect(200)
|
|
.expect(res => {
|
|
const metrics = res.body;
|
|
t.true(metrics.applications.length === 1);
|
|
t.true(metrics.applications[0].appName === appName);
|
|
});
|
|
});
|
|
|
|
test('should store application', t => {
|
|
t.plan(0);
|
|
const { request } = getSetup();
|
|
const appName = '123!23';
|
|
|
|
return request
|
|
.post(`/api/admin/metrics/applications/${appName}`)
|
|
.send({ appName, strategies: ['default'] })
|
|
.expect(202);
|
|
});
|
|
|
|
test('should store application details wihtout strategies', t => {
|
|
t.plan(0);
|
|
const { request } = getSetup();
|
|
const appName = '123!23';
|
|
|
|
return request
|
|
.post(`/api/admin/metrics/applications/${appName}`)
|
|
.send({ appName, url: 'htto://asd.com' })
|
|
.expect(202);
|
|
});
|
|
|
|
test('should accept a delete call to unknown application', t => {
|
|
t.plan(0);
|
|
const { request } = getSetup();
|
|
const appName = 'unknown';
|
|
|
|
return request
|
|
.delete(`/api/admin/metrics/applications/${appName}`)
|
|
.expect(200);
|
|
});
|
|
|
|
test('should delete application', t => {
|
|
t.plan(0);
|
|
const { request, stores } = getSetup();
|
|
const appName = 'deletable-test';
|
|
|
|
stores.clientApplicationsStore.upsert({ appName });
|
|
|
|
return request
|
|
.delete(`/api/admin/metrics/applications/${appName}`)
|
|
.expect(200);
|
|
});
|