1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-11 00:08:30 +01:00
unleash.unleash/lib/server-impl.test.js

79 lines
1.5 KiB
JavaScript
Raw Normal View History

'use strict';
2018-12-17 09:24:49 +01:00
const test = require('ava');
const proxyquire = require('proxyquire');
const { EventEmitter } = require('events');
const express = require('express');
const getLogger = require('../test/fixtures/no-logger');
const getApp = proxyquire('./app', {
'./routes': class Index {
router() {
return express.Router();
}
},
});
const eventStore = new EventEmitter();
const serverImpl = proxyquire('./server-impl', {
'./app': getApp,
'./metrics': {
2017-06-28 10:17:14 +02:00
startMonitoring(o) {
return o;
},
},
'./db': {
createStores() {
return {
eventStore,
};
},
},
'./options': {
2017-06-28 10:17:14 +02:00
createOptions(o) {
return o;
},
},
2017-06-28 10:17:14 +02:00
'../migrator'() {
return Promise.resolve();
},
});
test('should call preHook', async t => {
let called = 0;
await serverImpl.start({
port: 0,
getLogger,
preHook: () => {
called++;
},
});
t.true(called === 1);
});
test('should call preRouterHook', async t => {
let called = 0;
await serverImpl.start({
port: 0,
getLogger,
preRouterHook: () => {
called++;
},
});
t.true(called === 1);
});
test('should call eventHook', async t => {
let called = 0;
await serverImpl.start({
port: 0,
getLogger,
eventHook: () => {
called++;
},
});
eventStore.emit('feature-created', {});
t.true(called === 1);
});