Angular单元测试中的.subscribe()
创始人
2024-10-23 22:30:26
0

在进行Angular单元测试中,想要对组件中涉及到的Observable进行测试,而且还需要检测.subscribe()方法的正确性。这时可以采用Angular提供的测试框架中的TestBed来模拟整个组件环境,创建组件的实例,并对其中的Observable进行订阅。以下是代码示例:

1.引入必要的模块和服务

import { TestBed } from '@angular/core/testing'; import { HttpClientTestingModule } from '@angular/common/http/testing'; import { MyService } from './my.service'; import { of } from 'rxjs';

2.创建组件实例

describe('MyComponent', () => { let component: MyComponent; let fixture: ComponentFixture; let myService: MyService;

beforeEach(async(() => { TestBed.configureTestingModule({ declarations: [ MyComponent ], imports: [ HttpClientTestingModule ], providers: [ MyService ] }) .compileComponents(); }));

beforeEach(() => { fixture = TestBed.createComponent(MyComponent); component = fixture.componentInstance; myService = TestBed.get(MyService); });

3.模拟Observable和.subscribe()

it('should call .subscribe() on myObservable', () => { const myObservable = of('test data');

spyOn(myObservable, 'subscribe');

myService.getData().subscribe();

expect(myObservable.subscribe).toHaveBeenCalled(); });

以上代码通过创建组件实例和注入服务来模拟整个组件环境,然后创建myObservable的Observable实例,并使用spyOn方法对其.subscribe方法进行拦截,最后调用getData()方法并订阅myObservable,通过expect方法验证.subscribe()是否得到正确的调用。

相关内容

热门资讯

透视讲解!微乐家乡app下载,... 透视讲解!微乐家乡app下载,wepoker辅助脚本-真是存在有辅助方法(哔哩哔哩)在进入微乐家乡a...
透视好友!哈灵脚本辅助最简单三... 透视好友!哈灵脚本辅助最简单三个步骤,朱雀开心罗松怎么开挂-一贯确实有辅助器(哔哩哔哩)1、哈灵脚本...
透视免费!多乐辅助器使用方法,... 透视免费!多乐辅助器使用方法,多乐跑辅助-原来真的是有辅助器(哔哩哔哩)1、实时多乐辅助器使用方法透...
透视挂!榕城50k辅助,闲逸辅... 透视挂!榕城50k辅助,闲逸辅助软件-都是是真的有辅助脚本(哔哩哔哩)所有人都在同一条线上,像星星一...
日前!逍遥卡五星内购破解,情怀... 日前!逍遥卡五星内购破解,情怀游戏辅助器破解版-其实是有辅助工具(哔哩哔哩)亲,关键说明,情怀游戏辅...
透视了解!四川游戏家园通用辅助... 透视了解!四川游戏家园通用辅助在,九游辅助真的假的-原来存在有辅助脚本(哔哩哔哩)1)四川游戏家园通...
透视规律!雀友会广东潮汕苹果脚... 透视规律!雀友会广东潮汕苹果脚本,创思维激k辅助器视频-一直真的是有辅助方法(哔哩哔哩)1、玩家可以...
现就发布提示!开心联盟辅助器免... 现就发布提示!开心联盟辅助器免费,约战竞技场辅助器-真是是真的有辅助插件(哔哩哔哩)1、用户打开应用...
更值得关注的是!福建天天开心辅... 更值得关注的是!福建天天开心辅助器真的假的,填大坑辅助器视频-果然确实有辅助技巧(哔哩哔哩)1、下载...
透视智能ai!七千在线辅助,免... 透视智能ai!七千在线辅助,免费天天贵阳辅助工具-切实真的有辅助插件(哔哩哔哩)1、该软件可以轻松地...