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
2020-06-17 08:03:02 +02:00

102 lines
2.1 KiB
JavaScript

'use strict';
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 settingStore = {
get: () => {
Promise.resolve('secret');
},
};
const serverImpl = proxyquire('./server-impl', {
'./app': getApp,
'./metrics': {
startMonitoring(o) {
return o;
},
},
'./db': {
createStores() {
return {
eventStore,
settingStore,
};
},
},
'./options': {
createOptions(o) {
return o;
},
},
'../migrator': function() {
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);
});
test('should auto-create server on start()', async t => {
const { server } = await serverImpl.start({
port: 0,
getLogger,
start: true,
});
t.false(typeof server === 'undefined');
});
test('should not create a server using create()', async t => {
const { server } = await serverImpl.create({
port: 0,
getLogger,
});
t.true(typeof server === 'undefined');
});