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

Angular中的单元测试

如何对 *.spec.ts 文件使用不同的 tslint.json

无法绑定到“ngModel”,因为它不是“输入”的已知属性。测试.spec.ts

Angular 2单元测试:自定义管道错误找不到管道