mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-25 07:49:06 -04:00 
			
		
		
		
	toasts component testing conditional import of angular setup-jest for vscode-jest support Update jest.config.js Create open-documents.service.spec.ts Add unit tests for all REST services settings service test Remove component from settings service test Create permissions.service.spec.ts upload documents service tests Update package.json Create toast.service.spec.ts Tasks service test Statistics widget component tests Update permissions.service.ts Create app.component.spec.ts settings component testing tasks component unit testing Management list component generic tests Some management component tests document notes component unit tests Create document-list.component.spec.ts Create save-view-config-dialog.component.spec.ts Create filter-editor.component.spec.ts small and large document cards unit testing Create bulk-editor.component.spec.ts document detail unit tests saving work on documentdetail component spec Create document-asn.component.spec.ts dashboard & widgets unit testing Fix ResizeObserver mock common component unit tests fix some merge errors Update app-frame.component.spec.ts Create page-header.component.spec.ts input component unit tests FilterableDropdownComponent unit testing and found minor errors update taskservice unit tests Edit dialogs unit tests Create date-dropdown.component.spec.ts Remove selectors from guard tests confirm dialog component tests app frame component test Miscellaneous component tests Update document-list-view.service.spec.ts directives unit tests Remove unused resizeobserver mock guard unit tests Update query-params.spec.ts try to fix flaky playwright filter rules utils & testing Interceptor unit tests Pipes unit testing Utils unit tests Update upload-documents.service.spec.ts consumer status service tests Update setup-jest.ts Create document-list-view.service.spec.ts Update app-routing.module.ts
		
			
				
	
	
		
			183 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			183 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { HttpClientTestingModule } from '@angular/common/http/testing'
 | |
| import {
 | |
|   ComponentFixture,
 | |
|   TestBed,
 | |
|   discardPeriodicTasks,
 | |
|   fakeAsync,
 | |
|   tick,
 | |
| } from '@angular/core/testing'
 | |
| import { By } from '@angular/platform-browser'
 | |
| import { Router } from '@angular/router'
 | |
| import { RouterTestingModule } from '@angular/router/testing'
 | |
| import { NgxFileDropModule } from 'ngx-file-drop'
 | |
| import { TourService, TourNgBootstrapModule } from 'ngx-ui-tour-ng-bootstrap'
 | |
| import { Subject } from 'rxjs'
 | |
| import { routes } from './app-routing.module'
 | |
| import { AppComponent } from './app.component'
 | |
| import { ToastsComponent } from './components/common/toasts/toasts.component'
 | |
| import {
 | |
|   ConsumerStatusService,
 | |
|   FileStatus,
 | |
| } from './services/consumer-status.service'
 | |
| import { PermissionsService } from './services/permissions.service'
 | |
| import { ToastService, Toast } from './services/toast.service'
 | |
| import { UploadDocumentsService } from './services/upload-documents.service'
 | |
| import { SettingsService } from './services/settings.service'
 | |
| 
 | |
| describe('AppComponent', () => {
 | |
|   let component: AppComponent
 | |
|   let fixture: ComponentFixture<AppComponent>
 | |
|   let tourService: TourService
 | |
|   let consumerStatusService: ConsumerStatusService
 | |
|   let permissionsService: PermissionsService
 | |
|   let toastService: ToastService
 | |
|   let router: Router
 | |
|   let settingsService: SettingsService
 | |
|   let uploadDocumentsService: UploadDocumentsService
 | |
| 
 | |
|   beforeEach(async () => {
 | |
|     TestBed.configureTestingModule({
 | |
|       declarations: [AppComponent, ToastsComponent],
 | |
|       providers: [],
 | |
|       imports: [
 | |
|         HttpClientTestingModule,
 | |
|         TourNgBootstrapModule,
 | |
|         RouterTestingModule.withRoutes(routes),
 | |
|         NgxFileDropModule,
 | |
|       ],
 | |
|     }).compileComponents()
 | |
| 
 | |
|     tourService = TestBed.inject(TourService)
 | |
|     consumerStatusService = TestBed.inject(ConsumerStatusService)
 | |
|     permissionsService = TestBed.inject(PermissionsService)
 | |
|     settingsService = TestBed.inject(SettingsService)
 | |
|     toastService = TestBed.inject(ToastService)
 | |
|     router = TestBed.inject(Router)
 | |
|     uploadDocumentsService = TestBed.inject(UploadDocumentsService)
 | |
|     fixture = TestBed.createComponent(AppComponent)
 | |
|     component = fixture.componentInstance
 | |
|   })
 | |
| 
 | |
|   it('should initialize the tour service & toggle class on body for styling', fakeAsync(() => {
 | |
|     jest.spyOn(console, 'warn').mockImplementation(() => {})
 | |
|     fixture.detectChanges()
 | |
|     const tourSpy = jest.spyOn(tourService, 'initialize')
 | |
|     component.ngOnInit()
 | |
|     expect(tourSpy).toHaveBeenCalled()
 | |
|     tourService.start()
 | |
|     expect(document.body.classList).toContain('tour-active')
 | |
|     tourService.end()
 | |
|     tick(500)
 | |
|     expect(document.body.classList).not.toContain('tour-active')
 | |
|   }))
 | |
| 
 | |
|   it('should display toast on document consumed with link if user has access', () => {
 | |
|     jest.spyOn(permissionsService, 'currentUserCan').mockReturnValue(true)
 | |
|     let toast: Toast
 | |
|     toastService.getToasts().subscribe((toasts) => (toast = toasts[0]))
 | |
|     const toastSpy = jest.spyOn(toastService, 'show')
 | |
|     const fileStatusSubject = new Subject<FileStatus>()
 | |
|     jest
 | |
|       .spyOn(consumerStatusService, 'onDocumentConsumptionFinished')
 | |
|       .mockReturnValue(fileStatusSubject)
 | |
|     component.ngOnInit()
 | |
|     fileStatusSubject.next(new FileStatus())
 | |
|     expect(toastSpy).toHaveBeenCalled()
 | |
|     expect(toast.action).not.toBeUndefined()
 | |
|   })
 | |
| 
 | |
|   it('should display toast on document consumed without link if user does not have access', () => {
 | |
|     jest.spyOn(permissionsService, 'currentUserCan').mockReturnValue(false)
 | |
|     let toast: Toast
 | |
|     toastService.getToasts().subscribe((toasts) => (toast = toasts[0]))
 | |
|     const toastSpy = jest.spyOn(toastService, 'show')
 | |
|     const fileStatusSubject = new Subject<FileStatus>()
 | |
|     jest
 | |
|       .spyOn(consumerStatusService, 'onDocumentConsumptionFinished')
 | |
|       .mockReturnValue(fileStatusSubject)
 | |
|     component.ngOnInit()
 | |
|     fileStatusSubject.next(new FileStatus())
 | |
|     expect(toastSpy).toHaveBeenCalled()
 | |
|     expect(toast.action).toBeUndefined()
 | |
|   })
 | |
| 
 | |
|   it('should display toast on document added', () => {
 | |
|     jest.spyOn(permissionsService, 'currentUserCan').mockReturnValue(true)
 | |
|     const toastSpy = jest.spyOn(toastService, 'show')
 | |
|     const fileStatusSubject = new Subject<FileStatus>()
 | |
|     jest
 | |
|       .spyOn(consumerStatusService, 'onDocumentDetected')
 | |
|       .mockReturnValue(fileStatusSubject)
 | |
|     component.ngOnInit()
 | |
|     fileStatusSubject.next(new FileStatus())
 | |
|     expect(toastSpy).toHaveBeenCalled()
 | |
|   })
 | |
| 
 | |
|   it('should suppress dashboard notifications if set', () => {
 | |
|     jest.spyOn(permissionsService, 'currentUserCan').mockReturnValue(true)
 | |
|     jest.spyOn(settingsService, 'get').mockReturnValue(true)
 | |
|     jest.spyOn(router, 'url', 'get').mockReturnValue('/dashboard')
 | |
|     const toastSpy = jest.spyOn(toastService, 'show')
 | |
|     const fileStatusSubject = new Subject<FileStatus>()
 | |
|     jest
 | |
|       .spyOn(consumerStatusService, 'onDocumentDetected')
 | |
|       .mockReturnValue(fileStatusSubject)
 | |
|     component.ngOnInit()
 | |
|     fileStatusSubject.next(new FileStatus())
 | |
|     expect(toastSpy).not.toHaveBeenCalled()
 | |
|   })
 | |
| 
 | |
|   it('should display toast on document failed', () => {
 | |
|     jest.spyOn(permissionsService, 'currentUserCan').mockReturnValue(true)
 | |
|     const toastSpy = jest.spyOn(toastService, 'showError')
 | |
|     const fileStatusSubject = new Subject<FileStatus>()
 | |
|     jest
 | |
|       .spyOn(consumerStatusService, 'onDocumentConsumptionFailed')
 | |
|       .mockReturnValue(fileStatusSubject)
 | |
|     component.ngOnInit()
 | |
|     fileStatusSubject.next(new FileStatus())
 | |
|     expect(toastSpy).toHaveBeenCalled()
 | |
|   })
 | |
| 
 | |
|   it('should disable drag-drop if on dashboard', () => {
 | |
|     jest.spyOn(permissionsService, 'currentUserCan').mockReturnValue(true)
 | |
|     jest.spyOn(router, 'url', 'get').mockReturnValueOnce('/dashboard')
 | |
|     expect(component.dragDropEnabled).toBeFalsy()
 | |
|     jest.spyOn(router, 'url', 'get').mockReturnValueOnce('/documents')
 | |
|     expect(component.dragDropEnabled).toBeTruthy()
 | |
|   })
 | |
| 
 | |
|   it('should enable drag-drop if user has permissions', () => {
 | |
|     jest.spyOn(permissionsService, 'currentUserCan').mockReturnValue(true)
 | |
|     expect(component.dragDropEnabled).toBeTruthy()
 | |
|   })
 | |
| 
 | |
|   it('should disable drag-drop if user does not have permissions', () => {
 | |
|     jest.spyOn(permissionsService, 'currentUserCan').mockReturnValue(false)
 | |
|     expect(component.dragDropEnabled).toBeFalsy()
 | |
|   })
 | |
| 
 | |
|   it('should support drag drop', fakeAsync(() => {
 | |
|     expect(component.fileIsOver).toBeFalsy()
 | |
|     component.fileOver()
 | |
|     tick(1)
 | |
|     fixture.detectChanges()
 | |
|     expect(component.fileIsOver).toBeTruthy()
 | |
|     const dropzone = fixture.debugElement.query(
 | |
|       By.css('.global-dropzone-overlay')
 | |
|     )
 | |
|     expect(dropzone).not.toBeNull()
 | |
|     component.fileLeave()
 | |
|     tick(700)
 | |
|     fixture.detectChanges()
 | |
|     expect(dropzone.classes['hide']).toBeTruthy()
 | |
|     // drop
 | |
|     const toastSpy = jest.spyOn(toastService, 'show')
 | |
|     const uploadSpy = jest.spyOn(uploadDocumentsService, 'uploadFiles')
 | |
|     component.dropped([])
 | |
|     tick(3000)
 | |
|     expect(toastSpy).toHaveBeenCalled()
 | |
|     expect(uploadSpy).toHaveBeenCalled()
 | |
|   }))
 | |
| })
 |