mirror of
https://github.com/immich-app/immich.git
synced 2025-01-01 08:31:59 +00:00
fix(server): skip smtp validation when there are no changes (#10991)
* fix(server): skip smtp validation when there are no changes * rename test
This commit is contained in:
parent
9d8b755c07
commit
cf77487c00
2 changed files with 123 additions and 2 deletions
117
server/src/services/notification.service.spec.ts
Normal file
117
server/src/services/notification.service.spec.ts
Normal file
|
@ -0,0 +1,117 @@
|
||||||
|
import { defaults, SystemConfig } from 'src/config';
|
||||||
|
import { IAlbumRepository } from 'src/interfaces/album.interface';
|
||||||
|
import { IAssetRepository } from 'src/interfaces/asset.interface';
|
||||||
|
import { IJobRepository } from 'src/interfaces/job.interface';
|
||||||
|
import { ILoggerRepository } from 'src/interfaces/logger.interface';
|
||||||
|
import { INotificationRepository } from 'src/interfaces/notification.interface';
|
||||||
|
import { ISystemMetadataRepository } from 'src/interfaces/system-metadata.interface';
|
||||||
|
import { IUserRepository } from 'src/interfaces/user.interface';
|
||||||
|
import { NotificationService } from 'src/services/notification.service';
|
||||||
|
import { newAlbumRepositoryMock } from 'test/repositories/album.repository.mock';
|
||||||
|
import { newAssetRepositoryMock } from 'test/repositories/asset.repository.mock';
|
||||||
|
import { newJobRepositoryMock } from 'test/repositories/job.repository.mock';
|
||||||
|
import { newLoggerRepositoryMock } from 'test/repositories/logger.repository.mock';
|
||||||
|
import { newNotificationRepositoryMock } from 'test/repositories/notification.repository.mock';
|
||||||
|
import { newSystemMetadataRepositoryMock } from 'test/repositories/system-metadata.repository.mock';
|
||||||
|
import { newUserRepositoryMock } from 'test/repositories/user.repository.mock';
|
||||||
|
import { Mocked } from 'vitest';
|
||||||
|
|
||||||
|
const configs = {
|
||||||
|
smtpDisabled: Object.freeze<SystemConfig>({
|
||||||
|
...defaults,
|
||||||
|
notifications: {
|
||||||
|
smtp: {
|
||||||
|
...defaults.notifications.smtp,
|
||||||
|
enabled: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
smtpEnabled: Object.freeze<SystemConfig>({
|
||||||
|
...defaults,
|
||||||
|
notifications: {
|
||||||
|
smtp: {
|
||||||
|
...defaults.notifications.smtp,
|
||||||
|
enabled: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
smtpTransport: Object.freeze<SystemConfig>({
|
||||||
|
...defaults,
|
||||||
|
notifications: {
|
||||||
|
smtp: {
|
||||||
|
...defaults.notifications.smtp,
|
||||||
|
enabled: true,
|
||||||
|
transport: {
|
||||||
|
ignoreCert: false,
|
||||||
|
host: 'localhost',
|
||||||
|
port: 587,
|
||||||
|
username: 'test',
|
||||||
|
password: 'test',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
};
|
||||||
|
|
||||||
|
describe(NotificationService.name, () => {
|
||||||
|
let sut: NotificationService;
|
||||||
|
let systemMock: Mocked<ISystemMetadataRepository>;
|
||||||
|
let notificationMock: Mocked<INotificationRepository>;
|
||||||
|
let userMock: Mocked<IUserRepository>;
|
||||||
|
let jobMock: Mocked<IJobRepository>;
|
||||||
|
let loggerMock: Mocked<ILoggerRepository>;
|
||||||
|
let assetMock: Mocked<IAssetRepository>;
|
||||||
|
let albumMock: Mocked<IAlbumRepository>;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
systemMock = newSystemMetadataRepositoryMock();
|
||||||
|
notificationMock = newNotificationRepositoryMock();
|
||||||
|
userMock = newUserRepositoryMock();
|
||||||
|
jobMock = newJobRepositoryMock();
|
||||||
|
loggerMock = newLoggerRepositoryMock();
|
||||||
|
assetMock = newAssetRepositoryMock();
|
||||||
|
albumMock = newAlbumRepositoryMock();
|
||||||
|
|
||||||
|
sut = new NotificationService(systemMock, notificationMock, userMock, jobMock, loggerMock, assetMock, albumMock);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should work', () => {
|
||||||
|
expect(sut).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('onConfigValidateEvent', () => {
|
||||||
|
it('validates smtp config when enabling smtp', async () => {
|
||||||
|
const oldConfig = configs.smtpDisabled;
|
||||||
|
const newConfig = configs.smtpEnabled;
|
||||||
|
|
||||||
|
notificationMock.verifySmtp.mockResolvedValue(true);
|
||||||
|
await expect(sut.onConfigValidateEvent({ oldConfig, newConfig })).resolves.not.toThrow();
|
||||||
|
expect(notificationMock.verifySmtp).toHaveBeenCalledWith(newConfig.notifications.smtp.transport);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('validates smtp config when transport changes', async () => {
|
||||||
|
const oldConfig = configs.smtpEnabled;
|
||||||
|
const newConfig = configs.smtpTransport;
|
||||||
|
|
||||||
|
notificationMock.verifySmtp.mockResolvedValue(true);
|
||||||
|
await expect(sut.onConfigValidateEvent({ oldConfig, newConfig })).resolves.not.toThrow();
|
||||||
|
expect(notificationMock.verifySmtp).toHaveBeenCalledWith(newConfig.notifications.smtp.transport);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('skips smtp validation when there are no changes', async () => {
|
||||||
|
const oldConfig = { ...configs.smtpEnabled };
|
||||||
|
const newConfig = { ...configs.smtpEnabled };
|
||||||
|
|
||||||
|
await expect(sut.onConfigValidateEvent({ oldConfig, newConfig })).resolves.not.toThrow();
|
||||||
|
expect(notificationMock.verifySmtp).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('skips smtp validation when smtp is disabled', async () => {
|
||||||
|
const oldConfig = { ...configs.smtpEnabled };
|
||||||
|
const newConfig = { ...configs.smtpDisabled };
|
||||||
|
|
||||||
|
await expect(sut.onConfigValidateEvent({ oldConfig, newConfig })).resolves.not.toThrow();
|
||||||
|
expect(notificationMock.verifySmtp).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
|
@ -1,4 +1,5 @@
|
||||||
import { HttpException, HttpStatus, Inject, Injectable } from '@nestjs/common';
|
import { HttpException, HttpStatus, Inject, Injectable } from '@nestjs/common';
|
||||||
|
import { isEqual } from 'lodash';
|
||||||
import { DEFAULT_EXTERNAL_DOMAIN } from 'src/constants';
|
import { DEFAULT_EXTERNAL_DOMAIN } from 'src/constants';
|
||||||
import { SystemConfigCore } from 'src/cores/system-config.core';
|
import { SystemConfigCore } from 'src/cores/system-config.core';
|
||||||
import { SystemConfigSmtpDto } from 'src/dtos/system-config.dto';
|
import { SystemConfigSmtpDto } from 'src/dtos/system-config.dto';
|
||||||
|
@ -44,9 +45,12 @@ export class NotificationService implements OnEvents {
|
||||||
this.configCore = SystemConfigCore.create(systemMetadataRepository, logger);
|
this.configCore = SystemConfigCore.create(systemMetadataRepository, logger);
|
||||||
}
|
}
|
||||||
|
|
||||||
async onConfigValidateEvent({ newConfig }: SystemConfigUpdateEvent) {
|
async onConfigValidateEvent({ oldConfig, newConfig }: SystemConfigUpdateEvent) {
|
||||||
try {
|
try {
|
||||||
if (newConfig.notifications.smtp.enabled) {
|
if (
|
||||||
|
newConfig.notifications.smtp.enabled &&
|
||||||
|
!isEqual(oldConfig.notifications.smtp, newConfig.notifications.smtp)
|
||||||
|
) {
|
||||||
await this.notificationRepository.verifySmtp(newConfig.notifications.smtp.transport);
|
await this.notificationRepository.verifySmtp(newConfig.notifications.smtp.transport);
|
||||||
}
|
}
|
||||||
} catch (error: Error | any) {
|
} catch (error: Error | any) {
|
||||||
|
|
Loading…
Reference in a new issue