mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
Chore: miscellaneous frontend testing
This commit is contained in:
parent
4c6c976f63
commit
966eb00de0
@ -94,6 +94,10 @@ Object.defineProperty(navigator, 'clipboard', {
|
|||||||
})
|
})
|
||||||
Object.defineProperty(navigator, 'canShare', { value: () => true })
|
Object.defineProperty(navigator, 'canShare', { value: () => true })
|
||||||
Object.defineProperty(window, 'ResizeObserver', { value: mock() })
|
Object.defineProperty(window, 'ResizeObserver', { value: mock() })
|
||||||
|
Object.defineProperty(window, 'location', {
|
||||||
|
configurable: true,
|
||||||
|
value: { reload: jest.fn() },
|
||||||
|
})
|
||||||
|
|
||||||
HTMLCanvasElement.prototype.getContext = <
|
HTMLCanvasElement.prototype.getContext = <
|
||||||
typeof HTMLCanvasElement.prototype.getContext
|
typeof HTMLCanvasElement.prototype.getContext
|
||||||
|
@ -309,10 +309,15 @@ describe('SettingsComponent', () => {
|
|||||||
component.store.getValue()['displayLanguage'] = 'en-US'
|
component.store.getValue()['displayLanguage'] = 'en-US'
|
||||||
component.store.getValue()['updateCheckingEnabled'] = false
|
component.store.getValue()['updateCheckingEnabled'] = false
|
||||||
component.settingsForm.value.displayLanguage = 'en-GB'
|
component.settingsForm.value.displayLanguage = 'en-GB'
|
||||||
component.settingsForm.value.updateCheckingEnabled = true
|
jest.spyOn(settingsService, 'storeSettings').mockReturnValue(of(true))
|
||||||
jest.spyOn(settingsService, 'storeSettings').mockReturnValueOnce(of(true))
|
|
||||||
component.saveSettings()
|
component.saveSettings()
|
||||||
expect(toast.actionName).toEqual('Reload now')
|
expect(toast.actionName).toEqual('Reload now')
|
||||||
|
|
||||||
|
component.settingsForm.value.updateCheckingEnabled = true
|
||||||
|
component.saveSettings()
|
||||||
|
|
||||||
|
expect(toast.actionName).toEqual('Reload now')
|
||||||
|
toast.action()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should allow setting theme color, visually apply change immediately but not save', () => {
|
it('should allow setting theme color, visually apply change immediately but not save', () => {
|
||||||
|
@ -493,12 +493,17 @@ describe('FilterableDropdownComponent & FilterableDropdownSelectionModel', () =>
|
|||||||
expect(changedResult.getExcludedItems()).toEqual(items)
|
expect(changedResult.getExcludedItems()).toEqual(items)
|
||||||
}))
|
}))
|
||||||
|
|
||||||
it('FilterableDropdownSelectionModel should sort items by state', () => {
|
it('selection model should sort items by state', () => {
|
||||||
component.items = items
|
component.items = items.concat([{ id: null, name: 'Null B' }])
|
||||||
component.selectionModel = selectionModel
|
component.selectionModel = selectionModel
|
||||||
selectionModel.toggle(items[1].id)
|
selectionModel.toggle(items[1].id)
|
||||||
selectionModel.apply()
|
selectionModel.apply()
|
||||||
expect(selectionModel.itemsSorted).toEqual([nullItem, items[1], items[0]])
|
expect(selectionModel.itemsSorted).toEqual([
|
||||||
|
nullItem,
|
||||||
|
{ id: null, name: 'Null B' },
|
||||||
|
items[1],
|
||||||
|
items[0],
|
||||||
|
])
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should set support create, keep open model and call createRef method', fakeAsync(() => {
|
it('should set support create, keep open model and call createRef method', fakeAsync(() => {
|
||||||
@ -542,4 +547,34 @@ describe('FilterableDropdownComponent & FilterableDropdownSelectionModel', () =>
|
|||||||
tick(300)
|
tick(300)
|
||||||
expect(createSpy).toHaveBeenCalled()
|
expect(createSpy).toHaveBeenCalled()
|
||||||
}))
|
}))
|
||||||
|
|
||||||
|
it('should exclude item and trigger change event', () => {
|
||||||
|
const id = 1
|
||||||
|
const state = ToggleableItemState.Selected
|
||||||
|
component.selectionModel = selectionModel
|
||||||
|
component.manyToOne = true
|
||||||
|
component.selectionModel.singleSelect = true
|
||||||
|
component.selectionModel.intersection = Intersection.Include
|
||||||
|
component.selectionModel['temporarySelectionStates'].set(id, state)
|
||||||
|
const changedSpy = jest.spyOn(component.selectionModel.changed, 'next')
|
||||||
|
component.selectionModel.exclude(id)
|
||||||
|
expect(component.selectionModel.temporaryLogicalOperator).toBe(
|
||||||
|
LogicalOperator.And
|
||||||
|
)
|
||||||
|
expect(component.selectionModel['temporarySelectionStates'].get(id)).toBe(
|
||||||
|
ToggleableItemState.Excluded
|
||||||
|
)
|
||||||
|
expect(component.selectionModel['temporarySelectionStates'].size).toBe(1)
|
||||||
|
expect(changedSpy).toHaveBeenCalled()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should initialize selection states and apply changes', () => {
|
||||||
|
selectionModel.items = items
|
||||||
|
const map = new Map<number, ToggleableItemState>()
|
||||||
|
map.set(1, ToggleableItemState.Selected)
|
||||||
|
map.set(2, ToggleableItemState.Excluded)
|
||||||
|
selectionModel.init(map)
|
||||||
|
expect(selectionModel.getSelectedItems()).toEqual([items[0]])
|
||||||
|
expect(selectionModel.getExcludedItems()).toEqual([items[1]])
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
@ -275,7 +275,7 @@ export class FilterableDropdownSelectionModel {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
init(map) {
|
init(map: Map<number, ToggleableItemState>) {
|
||||||
this.temporarySelectionStates = map
|
this.temporarySelectionStates = map
|
||||||
this.apply()
|
this.apply()
|
||||||
}
|
}
|
||||||
|
@ -118,4 +118,18 @@ describe('SelectComponent', () => {
|
|||||||
tick(3000)
|
tick(3000)
|
||||||
expect(clearSpy).toHaveBeenCalled()
|
expect(clearSpy).toHaveBeenCalled()
|
||||||
}))
|
}))
|
||||||
|
|
||||||
|
it('should emit filtered documents', () => {
|
||||||
|
component.value = 10
|
||||||
|
component.items = items
|
||||||
|
const emitSpy = jest.spyOn(component.filterDocuments, 'emit')
|
||||||
|
component.onFilterDocuments()
|
||||||
|
expect(emitSpy).toHaveBeenCalledWith([items[2]])
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should return the correct filter button title', () => {
|
||||||
|
component.title = 'Tag'
|
||||||
|
const expectedTitle = `Filter documents with this ${component.title}`
|
||||||
|
expect(component.filterButtonTitle).toEqual(expectedTitle)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
@ -169,4 +169,12 @@ describe('TagsComponent', () => {
|
|||||||
expect(component.getTag(2)).toEqual(tags[1])
|
expect(component.getTag(2)).toEqual(tags[1])
|
||||||
expect(component.getTag(4)).toBeUndefined()
|
expect(component.getTag(4)).toBeUndefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should emit filtered documents', () => {
|
||||||
|
component.value = [10]
|
||||||
|
component.tags = tags
|
||||||
|
const emitSpy = jest.spyOn(component.filterDocuments, 'emit')
|
||||||
|
component.onFilterDocuments()
|
||||||
|
expect(emitSpy).toHaveBeenCalledWith([tags[2]])
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
@ -119,6 +119,8 @@ describe('UploadFileWidgetComponent', () => {
|
|||||||
const processingStatus = new FileStatus()
|
const processingStatus = new FileStatus()
|
||||||
processingStatus.phase = FileStatusPhase.WORKING
|
processingStatus.phase = FileStatusPhase.WORKING
|
||||||
expect(component.getStatusColor(processingStatus)).toEqual('primary')
|
expect(component.getStatusColor(processingStatus)).toEqual('primary')
|
||||||
|
processingStatus.phase = FileStatusPhase.UPLOADING
|
||||||
|
expect(component.getStatusColor(processingStatus)).toEqual('primary')
|
||||||
const failedStatus = new FileStatus()
|
const failedStatus = new FileStatus()
|
||||||
failedStatus.phase = FileStatusPhase.FAILED
|
failedStatus.phase = FileStatusPhase.FAILED
|
||||||
expect(component.getStatusColor(failedStatus)).toEqual('danger')
|
expect(component.getStatusColor(failedStatus)).toEqual('danger')
|
||||||
|
@ -17,6 +17,7 @@ describe('DirtyFormGuard', () => {
|
|||||||
let guard: DirtyFormGuard
|
let guard: DirtyFormGuard
|
||||||
let component: DirtyComponent
|
let component: DirtyComponent
|
||||||
let route: ActivatedRoute
|
let route: ActivatedRoute
|
||||||
|
let modalService: NgbModal
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
TestBed.configureTestingModule({
|
TestBed.configureTestingModule({
|
||||||
@ -37,6 +38,7 @@ describe('DirtyFormGuard', () => {
|
|||||||
|
|
||||||
guard = TestBed.inject(DirtyFormGuard)
|
guard = TestBed.inject(DirtyFormGuard)
|
||||||
route = TestBed.inject(ActivatedRoute)
|
route = TestBed.inject(ActivatedRoute)
|
||||||
|
modalService = TestBed.inject(NgbModal)
|
||||||
const fixture = TestBed.createComponent(GenericDirtyComponent)
|
const fixture = TestBed.createComponent(GenericDirtyComponent)
|
||||||
component = fixture.componentInstance
|
component = fixture.componentInstance
|
||||||
|
|
||||||
@ -57,9 +59,14 @@ describe('DirtyFormGuard', () => {
|
|||||||
component.isDirty$ = true
|
component.isDirty$ = true
|
||||||
const confirmSpy = jest.spyOn(guard, 'confirmChanges')
|
const confirmSpy = jest.spyOn(guard, 'confirmChanges')
|
||||||
const canDeactivate = guard.canDeactivate(component, route.snapshot)
|
const canDeactivate = guard.canDeactivate(component, route.snapshot)
|
||||||
|
let modal
|
||||||
|
modalService.activeInstances.subscribe((instances) => {
|
||||||
|
modal = instances[0]
|
||||||
|
})
|
||||||
canDeactivate.subscribe()
|
canDeactivate.subscribe()
|
||||||
|
|
||||||
expect(canDeactivate).toHaveProperty('source') // Observable
|
expect(canDeactivate).toHaveProperty('source') // Observable
|
||||||
expect(confirmSpy).toHaveBeenCalled()
|
expect(confirmSpy).toHaveBeenCalled()
|
||||||
|
modal.componentInstance.confirmClicked.next()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -108,6 +108,7 @@ describe('OpenDocumentsService', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('should close documents', () => {
|
it('should close documents', () => {
|
||||||
|
openDocumentsService.closeDocument({ id: 999 } as any)
|
||||||
subscriptions.push(
|
subscriptions.push(
|
||||||
openDocumentsService.openDocument(documents[0]).subscribe()
|
openDocumentsService.openDocument(documents[0]).subscribe()
|
||||||
)
|
)
|
||||||
@ -128,15 +129,21 @@ describe('OpenDocumentsService', () => {
|
|||||||
subscriptions.push(
|
subscriptions.push(
|
||||||
openDocumentsService.openDocument(documents[0]).subscribe()
|
openDocumentsService.openDocument(documents[0]).subscribe()
|
||||||
)
|
)
|
||||||
|
openDocumentsService.setDirty({ id: 999 }, true) // coverage
|
||||||
openDocumentsService.setDirty(documents[0], false)
|
openDocumentsService.setDirty(documents[0], false)
|
||||||
expect(openDocumentsService.hasDirty()).toBeFalsy()
|
expect(openDocumentsService.hasDirty()).toBeFalsy()
|
||||||
openDocumentsService.setDirty(documents[0], true)
|
openDocumentsService.setDirty(documents[0], true)
|
||||||
expect(openDocumentsService.hasDirty()).toBeTruthy()
|
expect(openDocumentsService.hasDirty()).toBeTruthy()
|
||||||
|
let openModal
|
||||||
|
modalService.activeInstances.subscribe((instances) => {
|
||||||
|
openModal = instances[0]
|
||||||
|
})
|
||||||
const modalSpy = jest.spyOn(modalService, 'open')
|
const modalSpy = jest.spyOn(modalService, 'open')
|
||||||
subscriptions.push(
|
subscriptions.push(
|
||||||
openDocumentsService.closeDocument(documents[0]).subscribe()
|
openDocumentsService.closeDocument(documents[0]).subscribe()
|
||||||
)
|
)
|
||||||
expect(modalSpy).toHaveBeenCalled()
|
expect(modalSpy).toHaveBeenCalled()
|
||||||
|
openModal.componentInstance.confirmClicked.next()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should allow set dirty status, warn on closeAll', () => {
|
it('should allow set dirty status, warn on closeAll', () => {
|
||||||
@ -148,9 +155,14 @@ describe('OpenDocumentsService', () => {
|
|||||||
)
|
)
|
||||||
openDocumentsService.setDirty(documents[0], true)
|
openDocumentsService.setDirty(documents[0], true)
|
||||||
expect(openDocumentsService.hasDirty()).toBeTruthy()
|
expect(openDocumentsService.hasDirty()).toBeTruthy()
|
||||||
|
let openModal
|
||||||
|
modalService.activeInstances.subscribe((instances) => {
|
||||||
|
openModal = instances[0]
|
||||||
|
})
|
||||||
const modalSpy = jest.spyOn(modalService, 'open')
|
const modalSpy = jest.spyOn(modalService, 'open')
|
||||||
subscriptions.push(openDocumentsService.closeAll().subscribe())
|
subscriptions.push(openDocumentsService.closeAll().subscribe())
|
||||||
expect(modalSpy).toHaveBeenCalled()
|
expect(modalSpy).toHaveBeenCalled()
|
||||||
|
openModal.componentInstance.confirmClicked.next()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should load open documents from localStorage', () => {
|
it('should load open documents from localStorage', () => {
|
||||||
|
@ -58,12 +58,25 @@ describe(`Additional service tests for MailAccountService`, () => {
|
|||||||
it('should support patchMany', () => {
|
it('should support patchMany', () => {
|
||||||
subscription = service.patchMany(mail_accounts).subscribe()
|
subscription = service.patchMany(mail_accounts).subscribe()
|
||||||
mail_accounts.forEach((mail_account) => {
|
mail_accounts.forEach((mail_account) => {
|
||||||
const reqs = httpTestingController.match(
|
const req = httpTestingController.expectOne(
|
||||||
`${environment.apiBaseUrl}${endpoint}/${mail_account.id}/`
|
`${environment.apiBaseUrl}${endpoint}/${mail_account.id}/`
|
||||||
)
|
)
|
||||||
expect(reqs).toHaveLength(1)
|
expect(req.request.method).toEqual('PATCH')
|
||||||
expect(reqs[0].request.method).toEqual('PATCH')
|
req.flush(mail_account)
|
||||||
})
|
})
|
||||||
|
httpTestingController.expectOne(
|
||||||
|
`${environment.apiBaseUrl}${endpoint}/?page=1&page_size=100000`
|
||||||
|
)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should support reload', () => {
|
||||||
|
service['reload']()
|
||||||
|
const req = httpTestingController.expectOne(
|
||||||
|
`${environment.apiBaseUrl}${endpoint}/?page=1&page_size=100000`
|
||||||
|
)
|
||||||
|
expect(req.request.method).toEqual('GET')
|
||||||
|
req.flush({ results: mail_accounts })
|
||||||
|
expect(service.allAccounts).toEqual(mail_accounts)
|
||||||
})
|
})
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
|
@ -76,12 +76,26 @@ describe(`Additional service tests for MailRuleService`, () => {
|
|||||||
it('should support patchMany', () => {
|
it('should support patchMany', () => {
|
||||||
subscription = service.patchMany(mail_rules).subscribe()
|
subscription = service.patchMany(mail_rules).subscribe()
|
||||||
mail_rules.forEach((mail_rule) => {
|
mail_rules.forEach((mail_rule) => {
|
||||||
const reqs = httpTestingController.match(
|
const req = httpTestingController.expectOne(
|
||||||
`${environment.apiBaseUrl}${endpoint}/${mail_rule.id}/`
|
`${environment.apiBaseUrl}${endpoint}/${mail_rule.id}/`
|
||||||
)
|
)
|
||||||
expect(reqs).toHaveLength(1)
|
expect(req.request.method).toEqual('PATCH')
|
||||||
expect(reqs[0].request.method).toEqual('PATCH')
|
req.flush(mail_rule)
|
||||||
})
|
})
|
||||||
|
const reloadReq = httpTestingController.expectOne(
|
||||||
|
`${environment.apiBaseUrl}${endpoint}/?page=1&page_size=100000`
|
||||||
|
)
|
||||||
|
reloadReq.flush({ results: mail_rules })
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should support reload', () => {
|
||||||
|
service['reload']()
|
||||||
|
const req = httpTestingController.expectOne(
|
||||||
|
`${environment.apiBaseUrl}${endpoint}/?page=1&page_size=100000`
|
||||||
|
)
|
||||||
|
expect(req.request.method).toEqual('GET')
|
||||||
|
req.flush({ results: mail_rules })
|
||||||
|
expect(service.allRules).toEqual(mail_rules)
|
||||||
})
|
})
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user