mirror of
https://github.com/Unleash/unleash.git
synced 2025-04-06 01:15:28 +02:00
Unit tests for strategy-api
This commit is contained in:
parent
c8a9b39f27
commit
9ed41ef858
@ -1,8 +1,9 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
require('db-migrate-shared').log.setLogLevel('error');
|
||||||
|
|
||||||
const { getInstance } = require('db-migrate');
|
const { getInstance } = require('db-migrate');
|
||||||
const parseDbUrl = require('parse-database-url');
|
const parseDbUrl = require('parse-database-url');
|
||||||
require('db-migrate-shared').log.silence(true);
|
|
||||||
|
|
||||||
function migrateDb ({ databaseUrl, databaseSchema = 'public' }) {
|
function migrateDb ({ databaseUrl, databaseSchema = 'public' }) {
|
||||||
const custom = parseDbUrl(databaseUrl);
|
const custom = parseDbUrl(databaseUrl);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
const NotFoundError = require('../../../../lib/error/notfound-error');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -8,6 +9,14 @@ module.exports = () => {
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
getStrategies: () => Promise.resolve(_strategies),
|
getStrategies: () => Promise.resolve(_strategies),
|
||||||
|
getStrategy: (name) => {
|
||||||
|
const strategy = _strategies.find(s => s.name === name);
|
||||||
|
if (strategy) {
|
||||||
|
return Promise.resolve(strategy);
|
||||||
|
} else {
|
||||||
|
return Promise.reject(new NotFoundError('Not found!'));
|
||||||
|
}
|
||||||
|
},
|
||||||
addStrategy: (strat) => _strategies.push(strat),
|
addStrategy: (strat) => _strategies.push(strat),
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -3,31 +3,78 @@
|
|||||||
const test = require('ava');
|
const test = require('ava');
|
||||||
const store = require('./fixtures/store');
|
const store = require('./fixtures/store');
|
||||||
const supertest = require('supertest');
|
const supertest = require('supertest');
|
||||||
const logger = require('../../../lib/logger');
|
|
||||||
const getApp = require('../../../lib/app');
|
const getApp = require('../../../lib/app');
|
||||||
|
|
||||||
const { EventEmitter } = require('events');
|
const { EventEmitter } = require('events');
|
||||||
const eventBus = new EventEmitter();
|
const eventBus = new EventEmitter();
|
||||||
|
|
||||||
test.beforeEach(() => {
|
function getSetup () {
|
||||||
logger.setLevel('FATAL');
|
const base = `/random${Math.round(Math.random() * 1000)}`;
|
||||||
});
|
|
||||||
|
|
||||||
test('should add version numbers for /stategies', t => {
|
|
||||||
const stores = store.createStores();
|
const stores = store.createStores();
|
||||||
const app = getApp({
|
const app = getApp({
|
||||||
baseUriPath: '',
|
baseUriPath: base,
|
||||||
stores,
|
stores,
|
||||||
eventBus,
|
eventBus,
|
||||||
});
|
});
|
||||||
|
|
||||||
const request = supertest(app);
|
return {
|
||||||
|
base,
|
||||||
|
strategyStore: stores.strategyStore,
|
||||||
|
request: supertest(app),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
test('should add version numbers for /stategies', t => {
|
||||||
|
const { request, base } = getSetup();
|
||||||
|
|
||||||
return request
|
return request
|
||||||
.get('/api/strategies')
|
.get(`${base}/api/strategies`)
|
||||||
.expect('Content-Type', /json/)
|
.expect('Content-Type', /json/)
|
||||||
.expect(200)
|
.expect(200)
|
||||||
.expect((res) => {
|
.expect((res) => {
|
||||||
t.true(res.body.version === 1);
|
t.true(res.body.version === 1);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('should require a name when creating a new stratey', t => {
|
||||||
|
const { request, base } = getSetup();
|
||||||
|
|
||||||
|
return request
|
||||||
|
.post(`${base}/api/strategies`)
|
||||||
|
.send({})
|
||||||
|
.expect(400)
|
||||||
|
.expect((res) => {
|
||||||
|
t.true(res.body.name === 'ValidationError');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should require parameters array when creating a new stratey', t => {
|
||||||
|
const { request, base } = getSetup();
|
||||||
|
|
||||||
|
return request
|
||||||
|
.post(`${base}/api/strategies`)
|
||||||
|
.send({ name: 'TestStrat' })
|
||||||
|
.expect(400)
|
||||||
|
.expect((res) => {
|
||||||
|
t.true(res.body.name === 'ValidationError');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should create a new stratey with empty parameters', () => {
|
||||||
|
const { request, base } = getSetup();
|
||||||
|
|
||||||
|
return request
|
||||||
|
.post(`${base}/api/strategies`)
|
||||||
|
.send({ name: 'TestStrat', parameters: [] })
|
||||||
|
.expect(201);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should not be possible to override name', () => {
|
||||||
|
const { request, base, strategyStore } = getSetup();
|
||||||
|
strategyStore.addStrategy({ name: 'Testing', parameters: [] });
|
||||||
|
|
||||||
|
return request
|
||||||
|
.post(`${base}/api/strategies`)
|
||||||
|
.send({ name: 'Testing', parameters: [] })
|
||||||
|
.expect(403);
|
||||||
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user