Chore: miscellaneous frontend testing

This commit is contained in:
shamoon 2024-02-23 23:36:03 -08:00
parent 4c6c976f63
commit 966eb00de0
11 changed files with 126 additions and 12 deletions

View File

@ -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

View File

@ -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', () => {

View File

@ -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]])
})
}) })

View File

@ -275,7 +275,7 @@ export class FilterableDropdownSelectionModel {
) )
} }
init(map) { init(map: Map<number, ToggleableItemState>) {
this.temporarySelectionStates = map this.temporarySelectionStates = map
this.apply() this.apply()
} }

View File

@ -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)
})
}) })

View File

@ -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]])
})
}) })

View File

@ -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')

View File

@ -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()
}) })
}) })

View File

@ -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', () => {

View File

@ -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(() => {

View File

@ -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(() => {