[英]How to unit test nested subscribe methods in Angular?
MethodToBeTested() {
this.serviceA.methodA1().subscribe((response) => {
if (response.Success) {
this.serviceA.methodA2().subscribe((res) => {
this.serviceB.methodB1();
})
}
});
}
这是场景。
要测试的东西:
serviceA.methodA1().
被称为。 serviceA.methodA2()
serviceA.methodA2()
收到值时是否调用了serviceB.methodB1()
。 首先,一个很容易测试。
let spy = spyOn(serviceA, 'methodA1');
expect(spy).toHaveBeenCalled();
但是一个测试2和3吗?
let spy= spyOn(serviceA, 'methodA1').and.returnValue({subscribe: () => {success:true}});
subject.MethodToBeTested();
这样的东西?
最好不要使用嵌套订阅。
这样的事情可能是解决方案:
let $obs1 = this.serviceA.methodA1().pipe(share());
let $obs2 = $obs1.pipe(switchMap(x => this.serviceA.methodA2()));
$obs1.subsribe(logic1 here...);
$obs2.subsribe(logic2 here...);
好了,所以我知道我要寻找的是callFake
it('should test inside of subscribe', () => {
let spy = spyOn(serviceA, 'methodA1').and.callFake(() => {
return of({ success: true });
});
let spy2 = spyOn(serviceA, 'methodA2').and.callFake(() => {
return of({ success: true });
});
let spy3 = spyOn(serviceB, 'methodB1').and.returnValue(of({ success: true }));
subject.MethodToBeTested();
expect(spy3).toHaveBeenCalled();
});
我了解到returnValue
实际上不会在订阅内部执行,而callFake
将使用您在订阅内部提供的数据。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.