mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2024-12-23 14:11:47 +00:00
8693edbf6a
Previous versions of HedgeDoc suffered from the problem that changing the media backend required manipulation of the media links in all created notes. We discussed in #3704 that it's favourable to have an endpoint that redirects to the image's original URL. When changing the media backend, the link stays the same but just the redirect changes. Signed-off-by: Erik Michelson <github@erik.michelson.eu>
134 lines
4.4 KiB
TypeScript
134 lines
4.4 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: 2022 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
import { promises as fs } from 'fs';
|
|
import request from 'supertest';
|
|
|
|
import { NotInDBError } from '../../src/errors/errors';
|
|
import { Note } from '../../src/notes/note.entity';
|
|
import { UserLoginInfoDto } from '../../src/users/user-info.dto';
|
|
import { User } from '../../src/users/user.entity';
|
|
import { TestSetup, TestSetupBuilder } from '../test-setup';
|
|
|
|
describe('Me', () => {
|
|
let testSetup: TestSetup;
|
|
|
|
let uploadPath: string;
|
|
let user: User;
|
|
let content: string;
|
|
let note1: Note;
|
|
let alias2: string;
|
|
let note2: Note;
|
|
let agent: request.SuperAgentTest;
|
|
|
|
beforeAll(async () => {
|
|
testSetup = await TestSetupBuilder.create().build();
|
|
|
|
uploadPath =
|
|
testSetup.configService.get('mediaConfig').backend.filesystem.uploadPath;
|
|
const username = 'hardcoded';
|
|
const password = 'AHardcodedStrongP@ssword123';
|
|
await testSetup.app.init();
|
|
|
|
user = await testSetup.userService.createUser(username, 'Testy');
|
|
await testSetup.identityService.createLocalIdentity(user, password);
|
|
|
|
content = 'This is a test note.';
|
|
alias2 = 'note2';
|
|
note1 = await testSetup.notesService.createNote(content, user);
|
|
note2 = await testSetup.notesService.createNote(content, user, alias2);
|
|
agent = request.agent(testSetup.app.getHttpServer());
|
|
await agent
|
|
.post('/api/private/auth/local/login')
|
|
.send({ username: username, password: password })
|
|
.expect(201);
|
|
});
|
|
|
|
afterAll(async () => {
|
|
await testSetup.cleanup();
|
|
});
|
|
|
|
it('GET /me', async () => {
|
|
const userInfo = testSetup.userService.toUserLoginInfoDto(user, 'local');
|
|
const response = await agent
|
|
.get('/api/private/me')
|
|
.expect('Content-Type', /json/)
|
|
.expect(200);
|
|
const gotUser = response.body as UserLoginInfoDto;
|
|
expect(gotUser).toEqual(userInfo);
|
|
});
|
|
|
|
it('GET /me/media', async () => {
|
|
const responseBefore = await agent
|
|
.get('/api/private/me/media/')
|
|
.expect('Content-Type', /json/)
|
|
.expect(200);
|
|
expect(responseBefore.body).toHaveLength(0);
|
|
|
|
const testImage = await fs.readFile('test/public-api/fixtures/test.png');
|
|
const imageIds = [];
|
|
imageIds.push(
|
|
(await testSetup.mediaService.saveFile(testImage, user, note1)).id,
|
|
);
|
|
imageIds.push(
|
|
(await testSetup.mediaService.saveFile(testImage, user, note1)).id,
|
|
);
|
|
imageIds.push(
|
|
(await testSetup.mediaService.saveFile(testImage, user, note2)).id,
|
|
);
|
|
imageIds.push(
|
|
(await testSetup.mediaService.saveFile(testImage, user, note2)).id,
|
|
);
|
|
|
|
const response = await agent
|
|
.get('/api/private/me/media/')
|
|
.expect('Content-Type', /json/)
|
|
.expect(200);
|
|
expect(response.body).toHaveLength(4);
|
|
expect(imageIds).toContain(response.body[0].id);
|
|
expect(imageIds).toContain(response.body[1].id);
|
|
expect(imageIds).toContain(response.body[2].id);
|
|
expect(imageIds).toContain(response.body[3].id);
|
|
const mediaUploads = await testSetup.mediaService.listUploadsByUser(user);
|
|
for (const upload of mediaUploads) {
|
|
await testSetup.mediaService.deleteFile(upload);
|
|
}
|
|
await fs.rmdir(uploadPath);
|
|
});
|
|
|
|
it('POST /me/profile', async () => {
|
|
const newDisplayName = 'Another name';
|
|
expect(user.displayName).not.toEqual(newDisplayName);
|
|
await agent
|
|
.post('/api/private/me/profile')
|
|
.send({
|
|
displayName: newDisplayName,
|
|
})
|
|
.expect(201);
|
|
const dbUser = await testSetup.userService.getUserByUsername('hardcoded');
|
|
expect(dbUser.displayName).toEqual(newDisplayName);
|
|
});
|
|
|
|
it('DELETE /me', async () => {
|
|
const testImage = await fs.readFile('test/public-api/fixtures/test.png');
|
|
const upload = await testSetup.mediaService.saveFile(
|
|
testImage,
|
|
user,
|
|
note1,
|
|
);
|
|
const dbUser = await testSetup.userService.getUserByUsername('hardcoded');
|
|
expect(dbUser).toBeInstanceOf(User);
|
|
const mediaUploads = await testSetup.mediaService.listUploadsByUser(dbUser);
|
|
expect(mediaUploads).toHaveLength(1);
|
|
expect(mediaUploads[0].id).toEqual(upload.id);
|
|
await agent.delete('/api/private/me').expect(204);
|
|
await expect(
|
|
testSetup.userService.getUserByUsername('hardcoded'),
|
|
).rejects.toThrow(NotInDBError);
|
|
const mediaUploadsAfter =
|
|
await testSetup.mediaService.listUploadsByNote(note1);
|
|
expect(mediaUploadsAfter).toHaveLength(0);
|
|
});
|
|
});
|