eke*_*l16 5 testing jasmine ngrx angular ngrx-store
我有一个功能
handleCSV () {
this.storeData$.take(1).subscribe(s => {
const data = s.data
const fields = ['reference', 'description', 'val1', 'val2', 'difference']
const fieldNames = ['Reference', 'Description', 'Value 1', 'Value 2', 'Difference']
const exportData = data.filter(dataset => dataset.visible)
const csv = json2csv({ data: exportData, fields: fields, fieldNames: fieldNames })
const csvEnc = encodeURIComponent(csv)
const href = `data:application/octet-stream,${csvEnc}`
this.csvDownloadLink.nativeElement.setAttribute('href', href)
this.csvDownloadLink.nativeElement.click()
this.csvDownloadLink.nativeElement.setAttribute('href', '')
})
}
Run Code Online (Sandbox Code Playgroud)
我几乎 100% 覆盖了这个函数,唯一缺少的是 data.filter 回调
有谁知道如何测试这个?使用的测试库是 Jasmine,整个应用程序是用 Angular 构建的。这是我目前进行的测试,它使我达到了当前的覆盖水平(也欢迎对此发表任何其他评论):
it('should click the CSV link', () => {
spyOn(comp.csvDownloadLink.nativeElement, 'click')
comp.ngOnInit()
comp.handleCSV()
expect(comp.csvDownloadLink.nativeElement.click).toHaveBeenCalledTimes(1)
})
Run Code Online (Sandbox Code Playgroud)
编辑
好的,所以我发现问题的原因不是没有调用 data.filter 回调,而是数据数组本身是空的!例如,通过始终确保数据数组中有内容,回调被覆盖:
现在显然我不希望在我的代码中使用这个 if 语句,所以我想我的问题变成了这个 - 为了测试的目的,我如何始终确保 storeData$ 中有一些东西。现在这已经改变了问题的范围,它现在是一个 ngrx 测试问题。ngOnInit() 函数触发一个异步填充 storeData$ 的操作,但显然这不会在测试中发生。那么如何触发 ngOnInit() 函数,并确保在调用 handleCSV() 时减速器已返回并且 storeData$ 将被填充?
storeData$不“包含”数据。storeData$将随着时间的推移发出值,通过订阅它,您可以在这些值到达时对其进行处理。在您的情况下,您只处理到达的第一个值(使用函数take(1))。
处理每个新值的箭头函数会执行相当多的逻辑。在我看来,您应该将此箭头函数提取到可以单独测试的命名函数中。这样您就可以测试逻辑而不必担心storeData$.
handleCSV () {
this.storeData$.take(1).subscribe(this.onNewStoreData);
}
onNewStoreData(s) {
const data = s.data
const fields = ['reference', 'description', 'val1', 'val2', 'difference']
const fieldNames = ['Reference', 'Description', 'Value 1', 'Value 2', 'Difference']
const exportData = data.filter(dataset => dataset.visible)
const csv = json2csv({ data: exportData, fields: fields, fieldNames: fieldNames })
const csvEnc = encodeURIComponent(csv)
const href = `data:application/octet-stream,${csvEnc}`
this.csvDownloadLink.nativeElement.setAttribute('href', href)
this.csvDownloadLink.nativeElement.click()
this.csvDownloadLink.nativeElement.setAttribute('href', '')
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
209 次 |
| 最近记录: |