mirror of
https://github.com/immich-app/immich.git
synced 2026-05-13 10:52:16 -04:00
3decc864b5
* refactor(server)!: structured validation error responses * refactor(server): clarify comment on removing duplicate HTTP response fields * enhance validation error tests * make path and message required * fmt * fix e2e test * fmt * feat: enhance error handling in getServerErrorMessage function
42 lines
1.5 KiB
TypeScript
42 lines
1.5 KiB
TypeScript
import { MaintenanceController } from 'src/controllers/maintenance.controller';
|
|
import { MaintenanceAction } from 'src/enum';
|
|
import { MaintenanceService } from 'src/services/maintenance.service';
|
|
import request from 'supertest';
|
|
import { errorDto } from 'test/medium/responses';
|
|
import { ControllerContext, controllerSetup, mockBaseService } from 'test/utils';
|
|
|
|
describe(MaintenanceController.name, () => {
|
|
let ctx: ControllerContext;
|
|
const service = mockBaseService(MaintenanceService);
|
|
|
|
beforeAll(async () => {
|
|
ctx = await controllerSetup(MaintenanceController, [{ provide: MaintenanceService, useValue: service }]);
|
|
return () => ctx.close();
|
|
});
|
|
|
|
beforeEach(() => {
|
|
service.resetAllMocks();
|
|
ctx.reset();
|
|
});
|
|
|
|
describe('POST /admin/maintenance', () => {
|
|
it('should be an authenticated route', async () => {
|
|
await request(ctx.getHttpServer()).post('/admin/maintenance').send();
|
|
expect(ctx.authenticate).toHaveBeenCalled();
|
|
});
|
|
|
|
it('should require a backup file when action is restore', async () => {
|
|
const { status, body } = await request(ctx.getHttpServer()).post('/admin/maintenance').send({
|
|
action: MaintenanceAction.RestoreDatabase,
|
|
});
|
|
expect(status).toBe(400);
|
|
expect(body).toEqual(
|
|
errorDto.validationError([
|
|
{ path: ['restoreBackupFilename'], message: 'Backup filename is required when action is restore_database' },
|
|
]),
|
|
);
|
|
expect(ctx.authenticate).toHaveBeenCalled();
|
|
});
|
|
});
|
|
});
|