2017-11-16 16:45:01 +01:00
|
|
|
'use strict';
|
|
|
|
|
2018-12-17 09:24:49 +01:00
|
|
|
const test = require('ava');
|
2017-11-16 16:45:01 +01:00
|
|
|
const { setupAppWithCustomAuth } = require('./../../helpers/test-helper');
|
|
|
|
const AuthenticationRequired = require('./../../../../lib/authentication-required');
|
|
|
|
const User = require('./../../../../lib/user');
|
|
|
|
|
|
|
|
test.serial('should require authenticated user', async t => {
|
|
|
|
t.plan(0);
|
|
|
|
const preHook = app => {
|
|
|
|
app.use('/api/admin/', (req, res) =>
|
|
|
|
res
|
|
|
|
.status('401')
|
|
|
|
.json(
|
|
|
|
new AuthenticationRequired({
|
|
|
|
path: '/api/admin/login',
|
|
|
|
type: 'custom',
|
|
|
|
message: `You have to identify yourself.`,
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.end()
|
|
|
|
);
|
|
|
|
};
|
|
|
|
const { request, destroy } = await setupAppWithCustomAuth(
|
|
|
|
'feature_api_custom_auth',
|
|
|
|
preHook
|
|
|
|
);
|
|
|
|
return request
|
|
|
|
.get('/api/admin/features')
|
|
|
|
.expect(401)
|
|
|
|
.then(destroy);
|
|
|
|
});
|
|
|
|
|
|
|
|
test.serial('creates new feature toggle with createdBy', async t => {
|
|
|
|
t.plan(1);
|
|
|
|
const user = new User({ email: 'custom-user@mail.com' });
|
|
|
|
|
|
|
|
const preHook = app => {
|
|
|
|
app.use('/api/admin/', (req, res, next) => {
|
|
|
|
req.user = user;
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
const { request, destroy } = await setupAppWithCustomAuth(
|
|
|
|
'feature_api_custom_auth',
|
|
|
|
preHook
|
|
|
|
);
|
|
|
|
|
|
|
|
// create toggle
|
|
|
|
await request.post('/api/admin/features').send({
|
|
|
|
name: 'com.test.Username',
|
|
|
|
enabled: false,
|
|
|
|
strategies: [{ name: 'default' }],
|
|
|
|
});
|
|
|
|
|
|
|
|
await request
|
|
|
|
.get('/api/admin/events')
|
|
|
|
.expect(res => {
|
|
|
|
t.true(res.body.events[0].createdBy === user.email);
|
|
|
|
})
|
|
|
|
.then(destroy);
|
|
|
|
});
|