mirror of
https://github.com/immich-app/immich.git
synced 2026-06-23 21:03:00 +08:00
Some checks failed
CodeQL / Analyze (javascript) (push) Has been cancelled
CodeQL / Analyze (python) (push) Has been cancelled
Docker / pre-job (push) Has been cancelled
Docs build / pre-job (push) Has been cancelled
Zizmor / Zizmor (push) Has been cancelled
Manage release PR / bump (push) Has been cancelled
Static Code Analysis / pre-job (push) Has been cancelled
Test / pre-job (push) Has been cancelled
Test / ShellCheck (push) Has been cancelled
Test / OpenAPI Clients (push) Has been cancelled
Test / SQL Schema Checks (push) Has been cancelled
Docker / Re-Tag ML () (push) Has been cancelled
Docker / Re-Tag ML (-armnn) (push) Has been cancelled
Docker / Re-Tag ML (-cuda) (push) Has been cancelled
Docker / Re-Tag ML (-openvino) (push) Has been cancelled
Docker / Re-Tag ML (-rknn) (push) Has been cancelled
Docker / Re-Tag ML (-rocm) (push) Has been cancelled
Docker / Re-Tag Server () (push) Has been cancelled
Docker / Build and Push ML (armnn, linux/arm64, -armnn) (push) Has been cancelled
Docker / Build and Push ML (cpu) (push) Has been cancelled
Docker / Build and Push ML (cuda, linux/amd64, -cuda) (push) Has been cancelled
Docker / Build and Push ML (openvino, linux/amd64, -openvino) (push) Has been cancelled
Docker / Build and Push ML (rknn, linux/arm64, -rknn) (push) Has been cancelled
Docker / Build and Push ML (rocm, linux/amd64, {"linux/amd64": "mich"}, -rocm) (push) Has been cancelled
Docker / Build and Push Server (push) Has been cancelled
Docker / Docker Build & Push Server Success (push) Has been cancelled
Docker / Docker Build & Push ML Success (push) Has been cancelled
Docs build / Docs Build (push) Has been cancelled
Static Code Analysis / Run Dart Code Analysis (push) Has been cancelled
Test / Test & Lint Server (push) Has been cancelled
Test / Unit Test CLI (push) Has been cancelled
Test / Unit Test CLI (Windows) (push) Has been cancelled
Test / Lint Web (push) Has been cancelled
Test / Test Web (push) Has been cancelled
Test / Test i18n (push) Has been cancelled
Test / End-to-End Lint (push) Has been cancelled
Test / Medium Tests (Server) (push) Has been cancelled
Test / End-to-End Tests (Server & CLI) (ubuntu-24.04-arm) (push) Has been cancelled
Test / End-to-End Tests (Server & CLI) (ubuntu-latest) (push) Has been cancelled
Test / End-to-End Tests (Web) (ubuntu-24.04-arm) (push) Has been cancelled
Test / End-to-End Tests (Web) (ubuntu-latest) (push) Has been cancelled
Test / End-to-End Tests Success (push) Has been cancelled
Test / Unit Test Mobile (push) Has been cancelled
Test / Unit Test ML (push) Has been cancelled
Test / .github Files Formatting (push) Has been cancelled
103 lines
4.2 KiB
TypeScript
103 lines
4.2 KiB
TypeScript
import _ from 'lodash';
|
|
import { defaults } from 'src/config';
|
|
import { SystemConfigController } from 'src/controllers/system-config.controller';
|
|
import { StorageTemplateService } from 'src/services/storage-template.service';
|
|
import { SystemConfigService } from 'src/services/system-config.service';
|
|
import request from 'supertest';
|
|
import { errorDto } from 'test/medium/responses';
|
|
import { ControllerContext, controllerSetup, mockBaseService } from 'test/utils';
|
|
|
|
describe(SystemConfigController.name, () => {
|
|
let ctx: ControllerContext;
|
|
const systemConfigService = mockBaseService(SystemConfigService);
|
|
const templateService = mockBaseService(StorageTemplateService);
|
|
|
|
beforeAll(async () => {
|
|
ctx = await controllerSetup(SystemConfigController, [
|
|
{ provide: SystemConfigService, useValue: systemConfigService },
|
|
{ provide: StorageTemplateService, useValue: templateService },
|
|
]);
|
|
return () => ctx.close();
|
|
});
|
|
|
|
beforeEach(() => {
|
|
systemConfigService.resetAllMocks();
|
|
templateService.resetAllMocks();
|
|
ctx.reset();
|
|
});
|
|
|
|
describe('GET /system-config', () => {
|
|
it('should be an authenticated route', async () => {
|
|
await request(ctx.getHttpServer()).get('/system-config');
|
|
expect(ctx.authenticate).toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
describe('GET /system-config/defaults', () => {
|
|
it('should be an authenticated route', async () => {
|
|
await request(ctx.getHttpServer()).get('/system-config/defaults');
|
|
expect(ctx.authenticate).toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
describe('PUT /system-config', () => {
|
|
it('should be an authenticated route', async () => {
|
|
await request(ctx.getHttpServer()).put('/system-config');
|
|
expect(ctx.authenticate).toHaveBeenCalled();
|
|
});
|
|
|
|
describe('nightlyTasks', () => {
|
|
it('should validate nightly jobs start time', async () => {
|
|
const config = _.cloneDeep(defaults);
|
|
config.nightlyTasks.startTime = 'invalid';
|
|
const { status, body } = await request(ctx.getHttpServer()).put('/system-config').send(config);
|
|
expect(status).toBe(400);
|
|
expect(body).toEqual(errorDto.badRequest(['nightlyTasks.startTime must be in HH:mm format']));
|
|
});
|
|
|
|
it('should accept a valid time', async () => {
|
|
const config = _.cloneDeep(defaults);
|
|
config.nightlyTasks.startTime = '05:05';
|
|
const { status } = await request(ctx.getHttpServer()).put('/system-config').send(config);
|
|
expect(status).toBe(200);
|
|
});
|
|
|
|
it('should validate a boolean field', async () => {
|
|
const config = _.cloneDeep(defaults);
|
|
(config.nightlyTasks.databaseCleanup as any) = 'invalid';
|
|
const { status, body } = await request(ctx.getHttpServer()).put('/system-config').send(config);
|
|
expect(status).toBe(400);
|
|
expect(body).toEqual(errorDto.badRequest(['nightlyTasks.databaseCleanup must be a boolean value']));
|
|
});
|
|
});
|
|
|
|
describe('image', () => {
|
|
it('should accept config without optional progressive property', async () => {
|
|
const config = _.cloneDeep(defaults);
|
|
delete config.image.thumbnail.progressive;
|
|
delete config.image.preview.progressive;
|
|
delete config.image.fullsize.progressive;
|
|
const { status } = await request(ctx.getHttpServer()).put('/system-config').send(config);
|
|
expect(status).toBe(200);
|
|
});
|
|
|
|
it('should accept config with progressive set to true', async () => {
|
|
const config = _.cloneDeep(defaults);
|
|
config.image.thumbnail.progressive = true;
|
|
config.image.preview.progressive = true;
|
|
config.image.fullsize.progressive = true;
|
|
const { status } = await request(ctx.getHttpServer()).put('/system-config').send(config);
|
|
expect(status).toBe(200);
|
|
});
|
|
|
|
it('should reject invalid progressive value', async () => {
|
|
const config = _.cloneDeep(defaults);
|
|
(config.image.thumbnail.progressive as any) = 'invalid';
|
|
const { status, body } = await request(ctx.getHttpServer()).put('/system-config').send(config);
|
|
expect(status).toBe(400);
|
|
expect(body).toEqual(errorDto.badRequest(['image.thumbnail.progressive must be a boolean value']));
|
|
});
|
|
});
|
|
});
|
|
});
|