首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >spyOn a Subscription.unsubscribe() -测试角度

spyOn a Subscription.unsubscribe() -测试角度
EN

Stack Overflow用户
提问于 2019-01-08 07:52:16
回答 2查看 3.1K关注 0票数 1

我正在尝试测试是否调用了订阅取消订阅方法,并且得到了一个错误。

我的组件看起来如下:

代码语言:javascript
复制
import { Component, OnInit } from '@angular/core'; import {
 Subscription } from 'rxjs/Subscription'; import { LoaderService } from
 '@core/components/loaders/services/loader.service';

 @Component({   selector: 'loader-mask',   templateUrl:
 './loader-mask.component.html',   styleUrls:
 ['./loader-mask.component.css'] })

 export class LoaderMaskComponent implements OnInit {

  subscription: Subscription;

   ngOnDestroy() {
      this.subscription.unsubscribe();
    } 
    }

我的测试看起来像这样

代码语言:javascript
复制
it('should call unsubscribe() on ngOnDestroy', ()
=> {

 let spy = spyOn(component['subscription'], 'unsubscribe').and.callFake( () => {});
    component.ngOnDestroy();

    expect(spy).toHaveBeenCalled();   });

但我发现了这个错误

代码语言:javascript
复制
Error: <spyOn> : could not find an object to spy upon for unsubscribe()
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-01-08 12:14:03

代码语言:javascript
复制
const spy = spyOn(
  (component as any).subscription,
  'unsubscribe'
).and.callThrough()
component.ngOnDestroy();
expect(spy).toHaveBeenCalled();

试试看,我也遇到了同样的问题,据我所知,我使用了上述方法来解决这个问题。请查证。

票数 1
EN

Stack Overflow用户

发布于 2019-05-02 17:24:31

代码语言:javascript
复制
component.subscription = new Subscription();
const subscription = spyOn(component.subscription, 'unsubscribe');

component.ngOnDestroy();

expect(subscription).toHaveBeenCalledTimes(1);
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54087355

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档