本页面描述了一些最有用的 Angular 测试特性。
Angular 测试实用工具包括 TestBed
、ComponentFixture
以及一些控制测试环境的函数。TestBed
和 ComponentFixture
类是单独介绍的。
下面是一些独立函数的摘要,以使用频率排序:
函数 |
详情 |
---|---|
waitForAsync |
在一个特殊的async 测试区域中运行测试( |
fakeAsync |
在一个特殊的fakeAsync 测试区域中运行测试( |
tick |
通过在 fakeAsync 测试区域中刷新定时器和微任务(micro-task)队列来仿真时间的流逝以及异步活动的完成。
接受一个可选参数,它可以把虚拟时钟往前推进特定的微秒数。清除调度到那个时间帧中的异步活动。 |
inject |
从当前的 TestBed 注入器中把一个或多个服务注入到一个测试函数中。它不能用于注入组件自身提供的服务。 |
discardPeriodicTasks |
当 fakeAsync 测试程序以正在运行的计时器事件任务(排队中的 setTimeOut 和 setInterval 的回调)结束时,测试会失败,并显示一条明确的错误信息。 一般来讲,测试程序应该以无排队任务结束。当待执行计时器任务存在时,调用 discardPeriodicTasks 来触发任务队列,防止该错误发生。 |
flushMicrotasks |
当 一般来说,测试应该等待微任务结束。当待执行微任务存在时,调用 |
ComponentFixtureAutoDetect |
一个服务提供者令牌,用于开启自动变更检测。 |
getTestBed |
获取当前 TestBed 实例。通常用不上,因为 TestBed 的静态类方法已经够用。TestBed 实例有一些很少需要用到的方法,它们没有对应的静态方法。 |
TestBed
类是 Angular 测试工具的主要类之一。它的 API 很庞大,可能有点过于复杂,直到你一点一点的探索它们。
传给 configureTestingModule
的模块定义是 @NgModule
元数据属性的子集。
type TestModuleMetadata = {
providers?: any[];
declarations?: any[];
imports?: any[];
schemas?: Array;
};
每一个重载方法接受一个 MetadataOverride
,这里 T
是适合这个方法的元数据类型,也就是 @NgModule
、@Component
、@Directive
或者 @Pipe
的参数。
type MetadataOverride = {
add?: Partial;
remove?: Partial;
set?: Partial;
};
TestBed
的 API 包含了一系列静态类方法,它们更新或者引用全局的 TestBed
实例。
在内部,所有静态方法在 getTestBed()
函数返回的当前运行时间的 TestBed
实例上都有对应的方法。
在 BeforeEach()
内调用 TestBed
方法,以确保在运行每个单独测试时,都有崭新的开始。
这里列出了最重要的静态方法,以使用频率排序。
方法 |
详情 |
---|---|
configureTestingModule |
测试垫片( |
compileComponents |
在配置好测试模块之后,异步编译它。如果测试模块中的任何一个组件具有 |
createComponent |
基于当前 |
overrideModule |
替换指定的 |
overrideComponent |
替换指定组件类的元数据,该组件类可能嵌套在一个很深的内部模块中。 |
overrideDirective |
替换指定指令类的元数据,该指令可能嵌套在一个很深的内部模块中。 |
overridePipe |
替换指定管道类的元数据,该管道可能嵌套在一个很深的内部模块中。 |
inject |
从当前
调用了 |
initTestEnvironment |
为整套测试的运行初始化测试环境。 |
resetTestEnvironment |
重设初始测试环境,包括默认测试模块在内。 |
少数 TestBed
实例方法没有对应的静态方法。它们很少被使用。
TestBed.createComponent
会创建一个组件 T
的实例,并为该组件返回一个强类型的 ComponentFixture
。
ComponentFixture
的属性和方法提供了对组件、它的 DOM 和它的 Angular 环境方面的访问。
下面是对测试最重要的属性,以使用频率排序。
属性 |
详情 |
---|---|
componentInstance |
被 |
debugElement |
与组件根元素关联的 |
nativeElement |
组件的原生根 DOM 元素。 |
changeDetectorRef |
组件的 |
fixture 方法使 Angular 对组件树执行某些任务。在触发 Angular 行为来模拟的用户行为时,调用这些方法。
下面是对测试最有用的方法。
方法 |
详情 |
---|---|
detectChanges |
为组件触发一轮变化检查。 |
autoDetectChanges |
如果你希望这个夹具自动检测变更,就把这个设置为 |
checkNoChanges |
运行一次变更检测来确认没有待处理的变化。如果有未处理的变化,它将抛出一个错误。 |
isStable |
如果 fixture 当前是稳定的,则返回 |
whenStable |
返回一个承诺,在 fixture 稳定时解析。 |
destroy |
触发组件的销毁。 |
DebugElement
提供了对组件的 DOM 的访问。
fixture.debugElement
返回测试根组件的 DebugElement
,通过它你可以访问(查询)fixture 的整个元素和组件子树。
下面是 DebugElement
最有用的成员,以使用频率排序。
成员 |
详情 |
---|---|
nativeElement |
与浏览器中 DOM 元素对应(WebWorkers 时,值为 null)。 |
query |
调用 |
queryAll |
调用 |
injector |
宿主依赖注入器。比如,根元素的组件实例注入器。 |
componentInstance |
元素自己的组件实例(如果有)。 |
context |
为元素提供父级上下文的对象。通常是控制该元素的祖级组件实例。 |
children |
|
parent |
|
name |
元素的标签名字,如果它是一个元素的话。 |
triggerEventHandler |
如果在该元素的 |
listeners |
元素的 |
providerTokens |
组件注入器的查询令牌。包括组件自己的令牌和组件的 |
source |
source 是在源组件模板中查询这个元素的处所。 |
references |
与模板本地变量(比如 |
DebugElement.query(predicate)
和 DebugElement.queryAll(predicate)
方法接受一个条件方法,它过滤源元素的子树,返回匹配的 DebugElement
。
这个条件方法是任何接受一个 DebugElement
并返回真值的方法。下面的例子查询所有拥有名为 content
的模块本地变量的所有 DebugElement
:
// Filter for DebugElements with a #content reference
const contentRefs = el.queryAll( de => de.references['content']);
Angular 的 By
类为常用条件方法提供了三个静态方法:
静态方法 |
详情 |
---|---|
By.all |
返回所有元素 |
By.css(selector) |
返回符合 CSS 选择器的元素 |
By.directive(directive) |
返回 Angular 能匹配一个指令类实例的所有元素 |
// Can find DebugElement either by css selector or by directive
const h2 = fixture.debugElement.query(By.css('h2'));
const directive = fixture.debugElement.query(By.directive(HighlightDirective));
网站标题:创新互联Angular教程:Angular测试工具API
转载注明:http://www.csdahua.cn/qtweb/news23/461073.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网