mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-26 00:02:35 -04:00 
			
		
		
		
	Chore: add coverage for frontend download content-disposition parsing
This commit is contained in:
		
							parent
							
								
									43b2527275
								
							
						
					
					
						commit
						2ee1d7540e
					
				| @ -1,5 +1,10 @@ | |||||||
| import { DatePipe } from '@angular/common' | import { DatePipe } from '@angular/common' | ||||||
| import { provideHttpClient, withInterceptorsFromDi } from '@angular/common/http' | import { | ||||||
|  |   HttpHeaders, | ||||||
|  |   HttpResponse, | ||||||
|  |   provideHttpClient, | ||||||
|  |   withInterceptorsFromDi, | ||||||
|  | } from '@angular/common/http' | ||||||
| import { | import { | ||||||
|   HttpTestingController, |   HttpTestingController, | ||||||
|   provideHttpClientTesting, |   provideHttpClientTesting, | ||||||
| @ -1331,6 +1336,34 @@ describe('DocumentDetailComponent', () => { | |||||||
|     expect(urlRevokeSpy).toHaveBeenCalled() |     expect(urlRevokeSpy).toHaveBeenCalled() | ||||||
|   }) |   }) | ||||||
| 
 | 
 | ||||||
|  |   it('should download a file with the correct filename', () => { | ||||||
|  |     const mockBlob = new Blob(['test content'], { type: 'text/plain' }) | ||||||
|  |     const mockResponse = new HttpResponse({ | ||||||
|  |       body: mockBlob, | ||||||
|  |       headers: new HttpHeaders({ | ||||||
|  |         'Content-Disposition': 'attachment; filename="test-file.txt"', | ||||||
|  |       }), | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  |     const downloadUrl = 'http://example.com/download' | ||||||
|  |     component.documentId = 123 | ||||||
|  |     jest.spyOn(documentService, 'getDownloadUrl').mockReturnValue(downloadUrl) | ||||||
|  | 
 | ||||||
|  |     const createSpy = jest.spyOn(document, 'createElement') | ||||||
|  |     const anchor: HTMLAnchorElement = {} as HTMLAnchorElement | ||||||
|  |     createSpy.mockReturnValueOnce(anchor) | ||||||
|  | 
 | ||||||
|  |     component.download(false) | ||||||
|  | 
 | ||||||
|  |     httpTestingController | ||||||
|  |       .expectOne(downloadUrl) | ||||||
|  |       .flush(mockBlob, { headers: mockResponse.headers }) | ||||||
|  | 
 | ||||||
|  |     expect(createSpy).toHaveBeenCalledWith('a') | ||||||
|  |     expect(anchor.download).toBe('test-file.txt') | ||||||
|  |     createSpy.mockClear() | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|   it('should get email enabled status from settings', () => { |   it('should get email enabled status from settings', () => { | ||||||
|     jest.spyOn(settingsService, 'get').mockReturnValue(true) |     jest.spyOn(settingsService, 'get').mockReturnValue(true) | ||||||
|     expect(component.emailEnabled).toBeTruthy() |     expect(component.emailEnabled).toBeTruthy() | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user