mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-26 00:14:40 -04:00 
			
		
		
		
	fix(server): include trashed assets in forced thumbnail generation (#10389)
* fix(server): include trashed assets in forced thumbnail generation * deleted -> trashed
This commit is contained in:
		
							parent
							
								
									83a851b556
								
							
						
					
					
						commit
						010eb1e0d6
					
				| @ -107,6 +107,31 @@ describe(MediaService.name, () => { | ||||
|       ]); | ||||
|     }); | ||||
| 
 | ||||
|     it('should queue trashed assets when force is true', async () => { | ||||
|       assetMock.getAll.mockResolvedValue({ | ||||
|         items: [assetStub.trashed], | ||||
|         hasNextPage: false, | ||||
|       }); | ||||
|       personMock.getAll.mockResolvedValue({ | ||||
|         items: [], | ||||
|         hasNextPage: false, | ||||
|       }); | ||||
| 
 | ||||
|       await sut.handleQueueGenerateThumbnails({ force: true }); | ||||
| 
 | ||||
|       expect(assetMock.getAll).toHaveBeenCalledWith( | ||||
|         { skip: 0, take: 1000 }, | ||||
|         expect.objectContaining({ withDeleted: true }), | ||||
|       ); | ||||
|       expect(assetMock.getWithout).not.toHaveBeenCalled(); | ||||
|       expect(jobMock.queueAll).toHaveBeenCalledWith([ | ||||
|         { | ||||
|           name: JobName.GENERATE_PREVIEW, | ||||
|           data: { id: assetStub.trashed.id }, | ||||
|         }, | ||||
|       ]); | ||||
|     }); | ||||
| 
 | ||||
|     it('should queue all people with missing thumbnail path', async () => { | ||||
|       assetMock.getWithout.mockResolvedValue({ | ||||
|         items: [assetStub.image], | ||||
|  | ||||
| @ -70,7 +70,7 @@ export class MediaService { | ||||
|   async handleQueueGenerateThumbnails({ force }: IBaseJob): Promise<JobStatus> { | ||||
|     const assetPagination = usePagination(JOBS_ASSET_PAGINATION_SIZE, (pagination) => { | ||||
|       return force | ||||
|         ? this.assetRepository.getAll(pagination, { isVisible: true }) | ||||
|         ? this.assetRepository.getAll(pagination, { isVisible: true, withDeleted: true }) | ||||
|         : this.assetRepository.getWithout(pagination, WithoutProperty.THUMBNAIL); | ||||
|     }); | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										40
									
								
								server/test/fixtures/asset.stub.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										40
									
								
								server/test/fixtures/asset.stub.ts
									
									
									
									
										vendored
									
									
								
							| @ -209,6 +209,46 @@ export const assetStub = { | ||||
|     duplicateId: null, | ||||
|   }), | ||||
| 
 | ||||
|   trashed: Object.freeze<AssetEntity>({ | ||||
|     id: 'asset-id', | ||||
|     deviceAssetId: 'device-asset-id', | ||||
|     fileModifiedAt: new Date('2023-02-23T05:06:29.716Z'), | ||||
|     fileCreatedAt: new Date('2023-02-23T05:06:29.716Z'), | ||||
|     owner: userStub.user1, | ||||
|     ownerId: 'user-id', | ||||
|     deviceId: 'device-id', | ||||
|     originalPath: '/original/path.jpg', | ||||
|     previewPath: '/uploads/user-id/thumbs/path.jpg', | ||||
|     checksum: Buffer.from('file hash', 'utf8'), | ||||
|     type: AssetType.IMAGE, | ||||
|     thumbnailPath: '/uploads/user-id/webp/path.ext', | ||||
|     thumbhash: Buffer.from('blablabla', 'base64'), | ||||
|     encodedVideoPath: null, | ||||
|     createdAt: new Date('2023-02-23T05:06:29.716Z'), | ||||
|     updatedAt: new Date('2023-02-23T05:06:29.716Z'), | ||||
|     deletedAt: new Date('2023-02-24T05:06:29.716Z'), | ||||
|     localDateTime: new Date('2023-02-23T05:06:29.716Z'), | ||||
|     isFavorite: false, | ||||
|     isArchived: false, | ||||
|     duration: null, | ||||
|     isVisible: true, | ||||
|     isExternal: false, | ||||
|     livePhotoVideo: null, | ||||
|     livePhotoVideoId: null, | ||||
|     isOffline: false, | ||||
|     tags: [], | ||||
|     sharedLinks: [], | ||||
|     originalFileName: 'asset-id.jpg', | ||||
|     faces: [], | ||||
|     sidecarPath: null, | ||||
|     exifInfo: { | ||||
|       fileSizeInByte: 5000, | ||||
|       exifImageHeight: 3840, | ||||
|       exifImageWidth: 2160, | ||||
|     } as ExifEntity, | ||||
|     duplicateId: null, | ||||
|   }), | ||||
| 
 | ||||
|   external: Object.freeze<AssetEntity>({ | ||||
|     id: 'asset-id', | ||||
|     deviceAssetId: 'device-asset-id', | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user