2021-04-09 13:46:53 +02:00
|
|
|
'use strict';
|
|
|
|
|
2021-04-22 10:07:10 +02:00
|
|
|
import { createServices } from '../services';
|
|
|
|
import { createTestConfig } from '../../test/config/test-config';
|
|
|
|
|
2021-04-09 13:46:53 +02:00
|
|
|
const test = require('ava');
|
|
|
|
const supertest = require('supertest');
|
|
|
|
const { EventEmitter } = require('events');
|
|
|
|
const store = require('../../test/fixtures/store');
|
|
|
|
const ossAuth = require('./oss-authentication');
|
|
|
|
const getApp = require('../app');
|
|
|
|
const { User } = require('../server-impl');
|
|
|
|
|
|
|
|
const eventBus = new EventEmitter();
|
|
|
|
|
|
|
|
function getSetup(preRouterHook) {
|
|
|
|
const base = `/random${Math.round(Math.random() * 1000)}`;
|
2021-04-22 10:07:10 +02:00
|
|
|
const config = createTestConfig({
|
|
|
|
server: { baseUriPath: base },
|
|
|
|
preRouterHook: _app => {
|
2021-04-09 13:46:53 +02:00
|
|
|
preRouterHook(_app);
|
2021-04-22 10:07:10 +02:00
|
|
|
ossAuth(_app, { server: { baseUriPath: base } });
|
2021-04-09 13:46:53 +02:00
|
|
|
_app.get(`${base}/api/protectedResource`, (req, res) => {
|
|
|
|
res.status(200)
|
|
|
|
.json({ message: 'OK' })
|
|
|
|
.end();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
2021-04-22 10:07:10 +02:00
|
|
|
const stores = store.createStores();
|
|
|
|
const services = createServices(stores, config);
|
|
|
|
const app = getApp(config, stores, services, eventBus);
|
2021-04-09 13:46:53 +02:00
|
|
|
|
|
|
|
return {
|
|
|
|
base,
|
|
|
|
request: supertest(app),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
test('should return 401 when missing user', t => {
|
|
|
|
t.plan(0);
|
|
|
|
const { base, request } = getSetup(() => {});
|
|
|
|
|
|
|
|
return request.get(`${base}/api/protectedResource`).expect(401);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should return 200 when user exists', t => {
|
|
|
|
t.plan(0);
|
|
|
|
const user = new User({ id: 1, email: 'some@mail.com' });
|
|
|
|
const { base, request } = getSetup(app =>
|
|
|
|
app.use((req, res, next) => {
|
|
|
|
req.user = user;
|
|
|
|
next();
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
|
|
|
return request.get(`${base}/api/protectedResource`).expect(200);
|
|
|
|
});
|