1
0
mirror of https://github.com/Unleash/unleash.git synced 2024-10-18 20:09:08 +02:00
unleash.unleash/src/lib/server-impl.test.js

127 lines
2.8 KiB
JavaScript
Raw Normal View History

'use strict';
const { EventEmitter } = require('events');
const express = require('express');
const { createTestConfig } = require('../test/config/test-config');
jest.mock(
'./routes',
() =>
class Index {
router() {
return express.Router();
}
},
);
const getApp = require('./app');
const noop = () => {};
const eventStore = new EventEmitter();
const settingStore = {
get: () => {
Promise.resolve('secret');
},
};
jest.mock('./app', () => getApp);
jest.mock('./metrics', () => ({
createMetricsMonitor() {
return {
startMonitoring: noop,
stopMonitoring: noop,
};
},
}));
jest.mock('./db', () => ({
createStores() {
return {
db: { destroy: cb => cb() },
clientInstanceStore: { destroy: noop },
clientMetricsStore: { destroy: noop, on: noop },
eventStore,
settingStore,
};
},
}));
jest.mock(
'../migrator',
() =>
function() {
return Promise.resolve();
},
);
jest.mock(
'./util/version',
() =>
function() {
return 'unleash-test-version';
},
);
const serverImpl = require('./server-impl');
test('should call preHook', async () => {
let called = 0;
const config = createTestConfig({
server: { port: 0 },
preHook: () => {
called++;
},
});
await serverImpl.start(config);
expect(called).toBe(1);
});
test('should call preRouterHook', async () => {
let called = 0;
await serverImpl.start(
createTestConfig({
server: { port: 0 },
preRouterHook: () => {
called++;
},
}),
);
expect(called === 1).toBe(true);
});
test('should call eventHook', async () => {
let called = 0;
const config = createTestConfig({
server: { port: 0 },
eventHook: () => {
called++;
},
});
await serverImpl.start(config);
eventStore.emit('feature-created', {});
expect(called === 1).toBe(true);
});
2020-06-17 08:03:02 +02:00
test('should auto-create server on start()', async () => {
const { server } = await serverImpl.start(
createTestConfig({ server: { port: 0 } }),
);
expect(typeof server === 'undefined').toBe(false);
2020-06-17 08:03:02 +02:00
});
test('should not create a server using create()', async () => {
const config = createTestConfig({ server: { port: 0 } });
const { server } = await serverImpl.create(config);
expect(server).toBeUndefined();
2020-06-17 08:03:02 +02:00
});
test('should shutdown the server when calling stop()', async () => {
const { server, stop } = await serverImpl.start(
createTestConfig({ server: { port: 0 } }),
);
await stop();
expect(server.address()).toBe(null);
});