gpt4 book ai didi

angular - 如何窥探可观察的属性(property)

转载 作者:行者123 更新时间:2023-12-05 06:57:50 25 4
gpt4 key购买 nike

我想对 Angular 10 组件进行单元测试。在组件的ngOnInit方法中,出现了这段代码:

this.subscriptions.push(
this.myService.getDataSubject.subscribe((results) => {
this.data = results;
}
);

另外,在单元测试中

beforeEach(async(() => {
TestBed.configureTestingModule({
providers: [MyService]
}).compileComponents();
})

我的单元测试包括

beforeEach(() => {
spyOnProperty(myService, 'getDataSubject', 'get').and.returnValue(of(mockData));
}

在服务本身

private dataSubject: BehaviorSubject<any> = new BehaviorSubject({});
getDataSubject = this.dataSubject.asObservable();

单元测试失败。我尝试了多种变体,但无法获得要返回的 mockData 值。在为订阅绑定(bind)到 BehaviorSubject 的属性的组件编写单元测试时,我应该做什么?

最佳答案

改变

beforeEach(() => { spyOnProperty(myService, 'getDataSubject', 'get').and.returnValue(of(mockData)); }

beforeEach(() => {
spyOn(myService, 'getDataSubject').and.callFake(()=>of(MockData));
}

监视函数而不是属性

关于angular - 如何窥探可观察的属性(property),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64797921/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com