2016-11-13 15:31:10 +01:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const test = require('ava');
|
2016-11-13 20:33:23 +01:00
|
|
|
const store = require('./fixtures/store');
|
2016-11-13 15:31:10 +01:00
|
|
|
const supertest = require('supertest');
|
|
|
|
const logger = require('../../../lib/logger');
|
2016-11-13 21:07:14 +01:00
|
|
|
const getApp = require('../../../lib/app');
|
2016-11-13 15:31:10 +01:00
|
|
|
|
2016-11-30 23:41:57 +01:00
|
|
|
const { EventEmitter } = require('events');
|
|
|
|
const eventBus = new EventEmitter();
|
|
|
|
|
2016-11-13 15:31:10 +01:00
|
|
|
test.beforeEach(() => {
|
|
|
|
logger.setLevel('FATAL');
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
function getSetup () {
|
|
|
|
const stores = store.createStores();
|
|
|
|
const db = stores.db;
|
2016-11-13 21:07:14 +01:00
|
|
|
const app = getApp({
|
2016-11-13 15:31:10 +01:00
|
|
|
baseUriPath: '',
|
|
|
|
stores,
|
2016-11-30 23:41:57 +01:00
|
|
|
eventBus,
|
2016-11-13 15:31:10 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
return {
|
|
|
|
db,
|
|
|
|
request: supertest(app),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
test('should give 500 when db is failing', t => {
|
|
|
|
const { request, db } = getSetup();
|
|
|
|
db.select = () => ({
|
|
|
|
from: () => Promise.reject(new Error('db error')),
|
|
|
|
});
|
|
|
|
return request
|
|
|
|
.get('/health')
|
|
|
|
.expect(500)
|
|
|
|
.expect((res) => {
|
|
|
|
t.true(res.status === 500);
|
|
|
|
t.true(res.body.health === 'BAD');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should give 200 when db is not failing', () => {
|
|
|
|
const { request } = getSetup();
|
|
|
|
return request
|
|
|
|
.get('/health')
|
|
|
|
.expect(200);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should give health=GOOD when db is not failing', t => {
|
|
|
|
const { request } = getSetup();
|
|
|
|
return request
|
|
|
|
.get('/health')
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
t.true(res.status === 200);
|
|
|
|
t.true(res.body.health === 'GOOD');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|