Angular CLI 生成的“spec.ts”文件有啥用?
Posted
技术标签:
【中文标题】Angular CLI 生成的“spec.ts”文件有啥用?【英文标题】:What are the "spec.ts" files generated by Angular CLI for?Angular CLI 生成的“spec.ts”文件有什么用? 【发布时间】:2016-09-26 22:25:34 【问题描述】:我是 Angular 2(以及一般的 Angular...)的新手,我发现它非常吸引人。我正在使用Angular CLI 来生成和服务项目。它似乎运作良好 - 尽管对于我的小型学习项目,它产生的结果超出了我的需要 - 但这是意料之中的。
我注意到它会为项目中的每个 Angular 元素(组件、服务、管道等)生成 spec.ts
。我四处搜索,但没有找到这些文件的用途的解释。
这些构建文件在使用tsc
时通常是隐藏的吗?我想知道是因为我想更改我创建的名称很差的 Component
的名称,并发现这些 spec.ts
文件中也引用了该名称。
import
beforeEach,
beforeEachProviders,
describe,
expect,
it,
inject,
from '@angular/core/testing';
import ComponentFixture, TestComponentBuilder from '@angular/compiler/testing';
import Component from '@angular/core';
import By from '@angular/platform-browser';
import PovLevelComponent from './pov-level.component';
describe('Component: PovLevel', () =>
let builder: TestComponentBuilder;
beforeEachProviders(() => [PovLevelComponent]);
beforeEach(inject([TestComponentBuilder], function (tcb: TestComponentBuilder)
builder = tcb;
));
it('should inject the component', inject([PovLevelComponent],
(component: PovLevelComponent) =>
expect(component).toBeTruthy();
));
it('should create the component', inject([], () =>
return builder.createAsync(PovLevelComponentTestController)
.then((fixture: ComponentFixture<any>) =>
let query = fixture.debugElement.query(By.directive(PovLevelComponent));
expect(query).toBeTruthy();
expect(query.componentInstance).toBeTruthy();
);
));
);
@Component(
selector: 'test',
template: `
<app-pov-level></app-pov-level>
`,
directives: [PovLevelComponent]
)
class PovLevelComponentTestController
【问题讨论】:
【参考方案1】:规范文件是源文件的单元测试。 Angular 应用程序的约定是每个 .ts 文件都有一个 .spec.ts 文件。当您使用 ng test
命令时,它们通过 Karma 测试运行程序 (https://karma-runner.github.io/) 使用 Jasmine javascript 测试框架运行。
您可以使用它进行进一步阅读:
https://angular.io/guide/testing
【讨论】:
谢谢,我自己也在想这个。假设我不想运行任何测试,我可以安全地删除 .spec 文件吗? (还有测试文件夹和文件,例如 e2e 文件夹?) 我也觉得这个问题需要更多的回答。我们可以完全忽略这些文件并继续我们的工作吗? 正如 awiseman 所说,规范文件确实用于测试您的应用程序。如果您不想使用测试文件,您可以简单地删除或忽略它们。您的项目将在没有规范文件的情况下继续运行。 当您使用 CLI 生成新组件时,您可以添加--spec=false
以排除规范文件的生成。生成新组件的完整命令是:ng g component comp-name --spec=false
。更多信息在这里:github.com/angular/angular-cli/wiki/generate-component
这可以通过修改angular-cli.json
来禁用: "defaults": "component": "spec": false
【参考方案2】:
如果您使用“ng new”生成新的 Angular 项目,您可以跳过 spec.ts 文件的生成。为此,您应该应用 --skip-tests 选项。
ng new ng-app-name --skip-tests
【讨论】:
项目生成后可以设置这个选项吗? @HughHughTeotl 是的,用于未来的服务生成,而不是已经生成的服务。如前所述:如果您不打算进行测试,您可以手动删除 spec.ts 文件。【参考方案3】:.spec.ts 文件用于单个组件的单元测试。
您可以通过ng test
运行 Karma 任务运行程序。为了查看特定组件的单元测试用例的代码覆盖率,请运行ng test --code-coverage
【讨论】:
【参考方案4】:.spec.ts
文件用于您的应用程序的unit testing
。
如果您不想生成它,只需在创建新的Component
时使用--spec=false
。像这样
ng generate component --spec=false mycomponentName
【讨论】:
以上是关于Angular CLI 生成的“spec.ts”文件有啥用?的主要内容,如果未能解决你的问题,请参考以下文章
如何在angular-cli项目中运行单个.spec.ts文件?
*.directive.spec.ts 中的错误 TS2554
如何对 *.spec.ts 文件使用不同的 tslint.json