mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-26 00:14:40 -04: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
					
				
							
								
								
									
										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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user