2016-11-13 15:31:10 +01:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const supertest = require('supertest');
|
2020-04-14 22:29:11 +02:00
|
|
|
const { EventEmitter } = require('events');
|
2021-05-28 11:10:24 +02:00
|
|
|
const { createServices } = require('../services');
|
|
|
|
const { createTestConfig } = require('../../test/config/test-config');
|
|
|
|
|
2020-04-14 22:29:11 +02:00
|
|
|
const store = require('../../test/fixtures/store');
|
|
|
|
const getLogger = require('../../test/fixtures/no-logger');
|
2017-06-28 10:20:22 +02:00
|
|
|
const getApp = require('../app');
|
2016-11-13 15:31:10 +01:00
|
|
|
|
2016-11-30 23:41:57 +01:00
|
|
|
const eventBus = new EventEmitter();
|
|
|
|
|
2017-06-28 10:20:22 +02:00
|
|
|
function getSetup() {
|
2016-11-13 15:31:10 +01:00
|
|
|
const stores = store.createStores();
|
2020-04-14 22:29:11 +02:00
|
|
|
const { db } = stores;
|
2021-04-22 10:07:10 +02:00
|
|
|
const config = createTestConfig();
|
2021-05-28 11:10:24 +02:00
|
|
|
const services = createServices(stores, config);
|
|
|
|
const app = getApp(config, stores, services, eventBus);
|
2016-11-13 15:31:10 +01:00
|
|
|
|
|
|
|
return {
|
|
|
|
db,
|
|
|
|
request: supertest(app),
|
2021-05-28 11:10:24 +02:00
|
|
|
destroy: () => {
|
|
|
|
services.versionService.destroy();
|
|
|
|
services.clientMetricsService.destroy();
|
|
|
|
services.apiTokenService.destroy();
|
|
|
|
},
|
2016-11-13 15:31:10 +01:00
|
|
|
};
|
|
|
|
}
|
2021-05-28 11:10:24 +02:00
|
|
|
let request;
|
|
|
|
let db;
|
|
|
|
let destroy;
|
|
|
|
beforeEach(() => {
|
|
|
|
const setup = getSetup();
|
|
|
|
request = setup.request;
|
|
|
|
db = setup.db;
|
|
|
|
destroy = setup.destroy;
|
|
|
|
});
|
2016-11-13 15:31:10 +01:00
|
|
|
|
2021-05-28 11:10:24 +02:00
|
|
|
afterEach(() => {
|
|
|
|
destroy();
|
2021-01-06 13:25:25 +01:00
|
|
|
getLogger.setMuteError(false);
|
|
|
|
});
|
|
|
|
|
2021-05-28 11:10:24 +02:00
|
|
|
test('should give 500 when db is failing', () => {
|
2021-01-06 13:25:25 +01:00
|
|
|
getLogger.setMuteError(true);
|
2021-05-28 11:10:24 +02:00
|
|
|
expect.assertions(2);
|
2021-04-22 10:07:10 +02:00
|
|
|
db.raw = () => Promise.reject(new Error('db error'));
|
2017-11-02 09:23:38 +01:00
|
|
|
return request
|
|
|
|
.get('/health')
|
|
|
|
.expect(500)
|
|
|
|
.expect(res => {
|
2021-05-28 11:10:24 +02:00
|
|
|
expect(res.status).toBe(500);
|
|
|
|
expect(res.body.health).toBe('BAD');
|
2017-11-02 09:23:38 +01:00
|
|
|
});
|
2016-11-13 15:31:10 +01:00
|
|
|
});
|
|
|
|
|
2021-05-28 11:10:24 +02:00
|
|
|
test('should give 200 when db is not failing', () => {
|
|
|
|
expect.assertions(0);
|
2021-04-22 10:07:10 +02:00
|
|
|
db.raw = () => Promise.resolve();
|
2017-06-28 10:20:22 +02:00
|
|
|
return request.get('/health').expect(200);
|
2016-11-13 15:31:10 +01:00
|
|
|
});
|
|
|
|
|
2021-05-28 11:10:24 +02:00
|
|
|
test('should give health=GOOD when db is not failing', () => {
|
|
|
|
expect.assertions(2);
|
2021-04-22 10:07:10 +02:00
|
|
|
db.raw = () => Promise.resolve();
|
2017-11-02 09:23:38 +01:00
|
|
|
return request
|
|
|
|
.get('/health')
|
|
|
|
.expect(200)
|
|
|
|
.expect(res => {
|
2021-05-28 11:10:24 +02:00
|
|
|
expect(res.status).toBe(200);
|
|
|
|
expect(res.body.health).toBe('GOOD');
|
2017-11-02 09:23:38 +01:00
|
|
|
});
|
2016-11-13 15:31:10 +01:00
|
|
|
});
|