feat(api/private): add GroupsController

The GroupsController can be used to fetch information about groups.

Signed-off-by: David Mehren <git@herrmehren.de>
This commit is contained in:
David Mehren 2022-02-27 19:02:28 +01:00
parent 0394679134
commit 0be8e4ea55
4 changed files with 102 additions and 1 deletions

View file

@ -0,0 +1,60 @@
/*
* SPDX-FileCopyrightText: 2022 The HedgeDoc developers (see AUTHORS file)
*
* SPDX-License-Identifier: AGPL-3.0-only
*/
import request from 'supertest';
import { LoginDto } from '../../src/identity/local/login.dto';
import { TestSetup, TestSetupBuilder } from '../test-setup';
describe('Groups', () => {
let testSetup: TestSetup;
let testuser1Session: request.SuperAgentTest;
beforeEach(async () => {
testSetup = await TestSetupBuilder.create().withUsers().build();
await testSetup.app.init();
// create a test group
await testSetup.groupService.createGroup('testgroup1', 'testgroup1', false);
// log in to create a session
const loginDto: LoginDto = {
password: 'testuser1',
username: 'testuser1',
};
testuser1Session = request.agent(testSetup.app.getHttpServer());
await testuser1Session
.post('/api/private/auth/local/login')
.set('Content-Type', 'application/json')
.send(JSON.stringify(loginDto))
.expect(201);
});
afterEach(async () => {
await testSetup.app.close();
});
test('details for existing groups can be retrieved', async () => {
const response = await testuser1Session.get(
'/api/private/groups/testgroup1',
);
expect(response.status).toBe(200);
expect(response.body.name).toBe('testgroup1');
});
test('details for non-existing groups cannot be retrieved', async () => {
const response = await testuser1Session.get(
'/api/private/groups/i_dont_exist',
);
expect(response.status).toBe(404);
});
test('API requires authentication', async () => {
const response = await request(testSetup.app.getHttpServer()).get(
'/api/private/groups/testgroup1',
);
expect(response.status).toBe(401);
});
});

View file

@ -27,6 +27,7 @@ import noteConfigMock from '../src/config/mock/note.config.mock';
import { ErrorExceptionMapping } from '../src/errors/error-mapping';
import { FrontendConfigModule } from '../src/frontend-config/frontend-config.module';
import { GroupsModule } from '../src/groups/groups.module';
import { GroupsService } from '../src/groups/groups.service';
import { HistoryModule } from '../src/history/history.module';
import { HistoryService } from '../src/history/history.service';
import { IdentityModule } from '../src/identity/identity.module';
@ -51,6 +52,7 @@ export class TestSetup {
app: NestExpressApplication;
userService: UsersService;
groupService: GroupsService;
configService: ConfigService;
identityService: IdentityService;
notesService: NotesService;
@ -152,6 +154,8 @@ export class TestSetupBuilder {
this.testSetup.userService =
this.testSetup.moduleRef.get<UsersService>(UsersService);
this.testSetup.groupService =
this.testSetup.moduleRef.get<GroupsService>(GroupsService);
this.testSetup.configService =
this.testSetup.moduleRef.get<ConfigService>(ConfigService);
this.testSetup.identityService =