1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-01 00:08:27 +01:00
unleash.unleash/src/test/e2e/custom-auth.test.ts
Ivar Conradi Østhus f00eac0881
fix: User audit events (create, update, delete) should include rootRole. (#5399)
Audit events for USER_CREATE, USER_UPDATE and USER_DELETE did not
include the users rootRole.


![image](https://github.com/Unleash/unleash/assets/158948/fcbc1407-e4f0-438f-86cf-7073205cd8c2)

---------

Co-authored-by: Gastón Fournier <gaston@getunleash.io>
2023-11-24 16:06:37 +01:00

51 lines
1.6 KiB
TypeScript

import dbInit from './helpers/database-init';
import { setupAppWithCustomAuth } from './helpers/test-helper';
import { RoleName } from '../../lib/types';
let db;
let stores;
const preHook = (app, config, { userService, accessService }) => {
app.use('/api/admin/', async (req, res, next) => {
const role = await accessService.getPredefinedRole(RoleName.EDITOR);
req.user = await userService.createUser({
email: 'editor2@example.com',
rootRole: role.id,
});
next();
});
};
beforeAll(async () => {
db = await dbInit('custom_auth_serial');
stores = db.stores;
});
afterAll(async () => {
await db.destroy();
});
test('Using custom auth type without defining custom middleware causes default DENY ALL policy to take effect', async () => {
jest.spyOn(global.console, 'error').mockImplementation(() => jest.fn());
const { request, destroy } = await setupAppWithCustomAuth(
stores,
undefined,
);
await request
.get('/api/admin/features')
.expect(401)
.expect((res) => {
expect(res.body.error).toBe(
'You have to configure a custom authentication middleware. Read https://docs.getunleash.io/docs/reference/deploy/configuring-unleash for more details',
);
});
await destroy();
});
test('If actually configuring a custom middleware should configure the middleware', async () => {
expect.assertions(0);
const { request, destroy } = await setupAppWithCustomAuth(stores, preHook);
await request.get('/api/admin/features').expect(200);
await destroy();
});