1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00
unleash.unleash/packages/unleash-api/test/specHelper.js
Ivar 096c86d58b Add support for aggregate_strategies in the API.
This commit changes the features-tables:
- drop columns 'strategy' and 'parameters'
- add column 'strategies' of type json.
- migrates existing strategy-mappings in to the new format.

The idea is that the 'strategies' column should contain a json-array
of strategy-configuration for the toggle:

```
[{
 "name" : "strategy1",
 "parameters": { "name": "vale" }
}]

```

To make sure to not break exiting clients the api is extended with a
mapping layer (adding old fields to the json-respons, and mapping
to the new format on create/update a feature toggle.

this commit is first step in solving #102
2016-09-06 21:31:28 +02:00

133 lines
3.4 KiB
JavaScript

'use strict';
process.env.NODE_ENV = 'test';
const BPromise = require('bluebird');
let request = require('supertest');
const databaseUri = require('./databaseConfig').getDatabaseUri();
const knex = require('../lib/db/dbPool')(databaseUri);
const eventDb = require('../lib/db/event')(knex);
const EventStore = require('../lib/eventStore');
const eventStore = new EventStore(eventDb);
const featureDb = require('../lib/db/feature')(knex, eventStore);
const strategyDb = require('../lib/db/strategy')(knex, eventStore);
const app = require('../app')({
baseUriPath: '',
db: knex,
eventDb,
eventStore,
featureDb,
strategyDb,
});
BPromise.promisifyAll(request);
request = request(app);
function createStrategies () {
return BPromise.map([
{
name: 'default',
description: 'Default on or off Strategy.',
parametersTemplate: {},
},
{
name: 'usersWithEmail',
description: 'Active for users defined in the comma-separated emails-parameter.',
parametersTemplate: {
emails: 'String',
},
},
], strategy => strategyDb._createStrategy(strategy));
}
function createFeatures () {
return BPromise.map([
{
name: 'featureX',
description: 'the #1 feature',
enabled: true,
strategies: [{ name: 'default', parameters: {} }],
},
{
name: 'featureY',
description: 'soon to be the #1 feature',
enabled: false,
strategies: [{
name: 'baz',
parameters: {
foo: 'bar',
},
}],
},
{
name: 'featureZ',
description: 'terrible feature',
enabled: true,
strategies: [{
name: 'baz',
parameters: {
foo: 'rab',
},
}],
},
{
name: 'featureArchivedX',
description: 'the #1 feature',
enabled: true,
archived: true,
strategies: [{ name: 'default', parameters: {} }],
},
{
name: 'featureArchivedY',
description: 'soon to be the #1 feature',
enabled: false,
archived: true,
strategies: [{
name: 'baz',
parameters: {
foo: 'bar',
},
}],
},
{
name: 'featureArchivedZ',
description: 'terrible feature',
enabled: true,
archived: true,
strategies: [{
name: 'baz',
parameters: {
foo: 'rab',
},
}],
},
], feature => featureDb._createFeature(feature));
}
function destroyStrategies () {
return knex('strategies').del();
}
function destroyFeatures () {
return knex('features').del();
}
function resetDatabase () {
return BPromise.all([destroyStrategies(), destroyFeatures()]);
}
function setupDatabase () {
return BPromise.all([createStrategies(), createFeatures()]);
}
module.exports = {
request,
db: {
reset: resetDatabase,
setup: setupDatabase,
resetAndSetup () {
return resetDatabase().then(setupDatabase);
},
},
};