加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angular – 确保在测试中填充ngrx存储

发布时间:2020-12-17 17:00:10 所属栏目:安全 来源:网络整理
导读:我有一个功能 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'] c
我有一个功能

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','')
  })
}

我几乎100%覆盖了这个函数,唯一缺少的是data.filter回调

enter image description here

有谁知道如何测试这个?使用的测试库是Jasmine,应用程序是使用Angular构建的.这是我目前的测试,它让我达到目前的覆盖水平(欢迎任何其他评论):

it('should click the CSV link',() => {
  spyOn(comp.csvDownloadLink.nativeElement,'click')

  comp.ngOnInit()
  comp.handleCSV()

  expect(comp.csvDownloadLink.nativeElement.click).toHaveBeenCalledTimes(1)
})

编辑

好的,所以我发现问题的原因并不是没有调用data.filter回调,而是数据数组本身是空的!例如,通过始终确保数据数组中包含某些内容,可以涵盖回调:

enter image description here

现在显然我不希望在我的代码中使用if语句,所以我想我的问题变成了这个 – 为了测试的目的,我怎么能始终确保storeData $中有一些东西.现在这已经改变了问题的范围,现在它是一个ngrx测试问题. ngOnInit()函数触发异步填充storeData $的操作,但显然在测试中没有发生这种情况.那么如何激活ngOnInit()函数,并确保reducer已经返回,并且当我调用handleCSV()时将填充storeData $?

解决方法

storeData $不包含’数据’. storeData $将随着时间的推移发出值,通过订阅它,您可以在它们到达时处理这些值.在您的情况下,您只处理到达的第一个值(使用take(1)函数).

处理每个新值的箭头函数确实有一些逻辑.在我看来,你应该将这个箭头函数提取到一个可以单独测试的命名函数.这样您就可以测试逻辑而无需担心storeData $.

handleCSV () {
  this.storeData$.take(1).subscribe(this.onNewStoreData);
}

onNewStoreData(s) {
    const data = s.data
    const fields = ['reference','')
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读