'use strict';

const test = require('ava');
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);
});