测试和构建 Angular7 项目


本章将讨论以下主题 -

  • 测试 Angular 7 项目
  • 构建 Angular 7 项目

测试 Angular 7 项目

在项目设置期间,已经安装了测试所需的包。为每个新组件、服务、指令等创建一个.spec.ts文件。我们将使用 jasmine 来编写测试用例。

对于添加到组件、服务、指令或创建的任何其他文件的任何更改,您可以将测试用例包含在相应的 .spec.ts 文件中。因此,大部分单元测试可以在一开始就涵盖在内。

要运行测试用例,使用的命令如下 -

ng test

以下是app.component.ts的 app.component.spec.ts 文件-

import { TestBed, async } from '@angular/core/testing';
import { RouterTestingModule } from '@angular/router/testing';
import { AppComponent } from './app.component';

describe('AppComponent', () => {
   beforeEach(async(() => {
      TestBed.configureTestingModule({
         imports: [
            RouterTestingModule
         ],
         declarations: [
            AppComponent
         ],
      }).compileComponents();
   }));
   it('should create the app', () => {
      const fixture = TestBed.createComponent(AppComponent);
      const app = fixture.debugElement.componentInstance;
      expect(app).toBeTruthy();
   });
   it(`should have as title 'angular7-app'`, () => {
      const fixture = TestBed.createComponent(AppComponent);
      const app = fixture.debugElement.componentInstance;
      expect(app.title).toEqual('angular7-app');
   });
   it('should render title in a h1 tag', () => {
      const fixture = TestBed.createComponent(AppComponent);
      fixture.detectChanges();
      const compiled = fixture.debugElement.nativeElement;
      expect(compiled.querySelector('h1').textContent).toContain(
         'Welcome to angular7-app!');
   })
});

应用程序组件.ts

import { Component } from '@angular/core';
@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'angular7-app';
}

现在让我们运行命令来查看测试用例的运行情况。

吴测试

运行命令

测试用例状态显示在命令行中,如上所示,并且还将在浏览器中打开,如下所示 -

业力

如果出现任何失败,它将显示详细信息如下 -

为此,让我们更改 app.component.spec.ts,如下所示 -

import { TestBed, async } from '@angular/core/testing';
import { RouterTestingModule } from '@angular/router/testing';
import { AppComponent } from './app.component';

describe('AppComponent', () => {
   beforeEach(async(() => {
      TestBed.configureTestingModule({
         imports: [
            RouterTestingModule
         ],
         declarations: [
            AppComponent
         ],
      }).compileComponents();
   }));
   it('should create the app', () => {
      const fixture = TestBed.createComponent(AppComponent);
      const app = fixture.debugElement.componentInstance;
      expect(app).toBeTruthy();
   });
   it(`should have as title 'angular7-app'`, () => {
      const fixture = TestBed.createComponent(AppComponent);
      const app = fixture.debugElement.componentInstance;
      expect(app.title).toEqual('Angular 7'); // change the 
      title from angular7-app to Angular 7
   });
   it('should render title in a h1 tag', () => {
      const fixture = TestBed.createComponent(AppComponent);
      fixture.detectChanges();
      const compiled = fixture.debugElement.nativeElement;
      expect(compiled.querySelector('h1').textContent).toContain(
         'Welcome to angular7-app!');
   });
});

在上面的文件中,测试用例检查标题Angular 7。但在 app.component.ts 中,我们有标题angular7-app ,如下所示 -

import { Component } from '@angular/core';
@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'angular7-app';
}

这里测试用例将失败,下面是命令行和浏览器中显示的详细信息。

在命令行中

以下屏幕显示在命令行中 -

命令行

在浏览器中

浏览器中显示以下屏幕 -

因果报应连接

您的项目的所有失败的测试用例都将显示在命令行和浏览器中,如上所示。

同样,您可以为您的服务、指令和将添加到项目中的新组件编写测试用例。

构建 Angular 7 项目

在 Angular 中完成项目后,我们需要构建它,以便它可以在生产或陈述中使用。

构建的配置,即生产、登台、开发、测试需要在src/environments中定义。

目前,我们在 src/environment 中定义了以下环境 -

环境

您可以根据您的构建将文件添加到 src/environment,即environment.staging.ts、environment.testing.ts 等。

目前我们正在尝试搭建生产环境。文件environment.ts包含默认环境设置和文件详细信息,如下所示 -

export const environment = {
   production: false
};

要构建用于生产的文件,我们需要在environment.ts中设置production: true ,如下所示 -

export const environment = {
   production: true
};

默认环境文件必须导入到组件内部,如下所示 -

应用程序组件.ts

import { Component } from '@angular/core';
import { environment } from './../environments/environment';

@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'angular7-app';
}

我们尝试执行的从默认到生产的环境替换在 angular.json fileReplacements部分中定义,如下所示 -

"production": {
   "fileReplacements": [
      {
         "replace": "src/environments/environment.ts",
         "with": "src/environments/environment.prod.ts"
      }
   ],
}

当构建命令运行时,该文件将替换为src/environments/environment.prod.ts。可以在此处添加额外的配置(例如暂存或测试),如下例所示 -

"configurations": {
   "production": { ... },
   "staging": {
      "fileReplacements": [
         {
            "replace": "src/environments/environment.ts",
            "with": "src/environments/environment.staging.ts"
         }
      ]
   }
}

因此运行构建的命令如下 -

ng build --configuration = production // for production environmnet
ng build --configuration = staging // for stating enviroment

现在让我们运行用于生产的构建命令,该命令将在我们的项目中创建一个 dist 文件夹,其中将包含构建后的最终文件。

吴建

分发文件夹

最终文件构建在 dist/ 文件夹内,该文件夹可以托管在您的生产服务器上。

距离