目次
設定スクリプト
ホームページ ウェブフロントエンド jsチュートリアル テスト環境をセットアップするにはどうすればよいですか? Angular テスト ツールセットの概要

テスト環境をセットアップするにはどうすればよいですか? Angular テスト ツールセットの概要

Aug 22, 2020 am 11:16 AM
angular 単体テスト

テスト環境をセットアップするにはどうすればよいですか? Angular テスト ツールセットの概要

この記事では、テスト環境と Angular テスト ツール セットを構築する方法について説明します。

テスト環境

ほとんどのプロジェクトは Angular Cli を使用して作成されているため、必要な npm パッケージはデフォルトで統合されています。 ; もちろん、自作または公式 Web サイトのクイックスタートを使用する場合は、自分でインストールする必要がありますが、コア データはすべて同じです。 [関連チュートリアルの推奨事項: angular チュートリアル]

Angular 単体テストは、独立した個別のテストと Angular テスト ツールセットの 2 つのカテゴリに分類できます。

Pipe と Service は、new インスタンス クラスのみが必要であり、いかなる方法でも Angular コンポーネントと対話できないため、独立したテスト に適しています。

その反対は、Angular テスト ツールセットです。

テスト フレームワークの紹介

Jasmine

Jasmine テスト フレームワークは、テスト スクリプト セットを作成するためのツールを提供します、非常に優れたセマンティクスにより、テスト コードが段落を読んでいるように見えます。

Karma

テスト スクリプトがあり、ブラウザで実行できるようにこれらのスクリプトを管理するには Karma が必要です。

Npm パッケージ

いじる必要がある場合、最も簡単な方法は、Angular Cli を使用して新しいプロジェクトを作成し、次のように、Npm パッケージを作業中のプロジェクトにコピーします。

    "jasmine-core": "~2.5.2",
    "jasmine-spec-reporter": "~3.2.0",
    "karma": "~1.4.1",
    "karma-chrome-launcher": "~2.1.1",
    "karma-cli": "~1.0.1",
    "karma-jasmine": "~1.1.0",
    "karma-jasmine-html-reporter": "^0.2.2",
    "karma-coverage-istanbul-reporter": "^0.2.0"
ログイン後にコピー

次に、私たちにとって最も重要なことは、構成スクリプト部分に注目することです。

設定スクリプト

私たちの中心はカルマ ランナーを実行させることであり、Jasmine の場合はテスト スクリプトを書くときに使用されるため、当面は過度に心配する必要はありません。

ルート ディレクトリに karma.conf.js ファイルを作成する必要があります。これは、いくつかの規則と同等です。ファイルの目的は、どのプラグインを有効にする必要があるか、どのテスト スクリプトをロードするか、どのテスト ブラウザ環境が必要か、テスト レポートの通知方法、ログなどを Karma に通知することです。

karma.conf.js

以下は、Angular Cli によってデフォルトで提供される Karma 設定ファイルです:

// Karma configuration file, see link for more information
// https://karma-runner.github.io/0.13/config/configuration-file.html

module.exports = function(config) {
    config.set({
        // 基础路径(适用file、exclude属性)
        basePath: '',
        // 测试框架,@angular/cli 指Angular测试工具集
        frameworks: ['jasmine', '@angular/cli'],
        // 加载插件清单
        plugins: [
            require('karma-jasmine'),
            require('karma-chrome-launcher'),
            require('karma-jasmine-html-reporter'),
            require('karma-coverage-istanbul-reporter'),
            require('@angular/cli/plugins/karma')
        ],
        client: {
            // 当测试运行完成后是否清除上文
            clearContext: false // leave Jasmine Spec Runner output visible in browser
        },
        // 哪些文件需要被浏览器加载,后面会专门介绍  `test.ts`
        files: [
            { pattern: './src/test.ts', watched: false }
        ],
        // 允许文件到达浏览器之前进行一些预处理操作
        // 非常丰富的预处理器:https://www.npmjs.com/browse/keyword/karma-preprocessor
        preprocessors: {
            './src/test.ts': ['@angular/cli']
        },
        // 指定请求文件MIME类型
        mime: {
            'text/x-typescript': ['ts', 'tsx']
        },
        // 插件【karma-coverage-istanbul-reporter】的配置项
        coverageIstanbulReporter: {
            // 覆盖率报告方式
            reports: ['html', 'lcovonly'],
            fixWebpackSourcePaths: true
        },
        // 指定angular cli环境
        angularCli: {
            environment: 'dev'
        },
        // 测试结果报告方式
        reporters: config.angularCli && config.angularCli.codeCoverage ?
            ['progress', 'coverage-istanbul'] :
            ['progress', 'kjhtml'],
        port: 9876,
        colors: true,
        // 日志等级
        logLevel: config.LOG_INFO,
        // 是否监听测试文件
        autoWatch: true,
        // 测试浏览器列表
        browsers: ['Chrome'],
        // 持续集成模式,true:表示浏览器执行测试后退出
        singleRun: false
    });
};
ログイン後にコピー

上記の設定は基本的に満たすことができます。私たちのニーズ ; Karma は市場のすべてのブラウザをサポートしているため、通常、変更する必要があるのはテスト ブラウザのリストです。さらに、Travis CI 継続的インテグレーションを使用する場合、Chrome ブラウザーで無効なサンドボックス環境を開始すると、多くのことが節約されます。

        customLaunchers: {
            Chrome_travis_ci: {
                base: 'Chrome',
                flags: ['--no-sandbox']
            }
        }
ログイン後にコピー

karma 構成ファイルに関するすべての情報については、公式 Web サイトのドキュメントに参加してください。

test.ts

karma.conf.js を作成するとき、ブラウザによってロードされるファイルが を指すように構成しました。 /src/test.ts ファイル。この関数は Karma の開始をガイドするもので、コードは非常に単純です:

// This file is required by karma.conf.js and loads recursively all the .spec and framework files

import 'zone.js/dist/long-stack-trace-zone';
import 'zone.js/dist/proxy.js';
import 'zone.js/dist/sync-test';
import 'zone.js/dist/jasmine-patch';
import 'zone.js/dist/async-test';
import 'zone.js/dist/fake-async-test';
import { getTestBed } from '@angular/core/testing';
import {
  BrowserDynamicTestingModule,
  platformBrowserDynamicTesting
} from '@angular/platform-browser-dynamic/testing';

// Unfortunately there's no typing for the `__karma__` variable. Just declare it as any.
declare var __karma__: any;
declare var require: any;

// Prevent Karma from running prematurely.
__karma__.loaded = function () {};

// First, initialize the Angular testing environment.
getTestBed().initTestEnvironment(
  BrowserDynamicTestingModule,
  platformBrowserDynamicTesting()
);
// Then we find all the tests.
// 所有.spec.ts文件
const context = require.context('./', true, /\.spec\.ts$/);
// And load the modules.
context.keys().map(context);
// Finally, start Karma to run the tests.
__karma__.start();
ログイン後にコピー

すべての準備ができたら、karma を開始してみます。テスト コードがなくても実行できます。

Angular Cl の場合は、ng testnode "./node_modules/karma-cli/bin/karma" start

最後に、ブラウザを開きます:

http://localhost : 9876 では、テストレポートを表示できます。

簡単な例

環境がセットアップされたので、簡単な例を書いて試してみましょう。

./src/demo.spec.ts ファイルを作成します。接尾辞 .spec.ts は規則なので、それに従ってください。

describe('demo test', () => {
    it('should be true', () => {
        expect(true).toBe(true);
    })
});
ログイン後にコピー

ng test を実行すると、コンソール:

Chrome 58.0.3029 (Windows 10 0.0.0): Executed 1 of 1 SUCCESS (0.031 secs / 0.002 secs)
ログイン後にコピー

またはブラウザ:

1 spec, 0 failures
demo test
  true is true
ログイン後にコピー
が表示されます。すべて、私たちは Angular 単体テストの世界に入りました。

Angular Testing Toolset

Pipe や Service などの通常のクラスは、単純な

new を通じてインスタンスを作成するだけで済みます。命令やコンポーネントを使用するには、特定の環境が必要です。これは Angular のモジュール概念によるもので、コンポーネントを実行するには、まず @NgModule 定義が必要です。

このツール セットには多くの情報が含まれていないため、簡単に使いこなすことができます。以下に、最も一般的に使用されるもののいくつかを簡単に説明します。

TestBed

TestBed は、 @NgModule テスト環境モジュール。もちろん、このモジュールでは、TestBed.createComponent を使用して、ターゲット コンポーネントをテストするためのテスト コンポーネントを作成する必要もあります。

非同期

非同期は Angular のどこにでもあり、非同期テストではツールセット

asyncfakeAsync を使用してエレガントな記述が可能です。テスト コードは同期しているように見えます。

ツール セットにはさらに多くのツールがあり、そのすべてについては [Angular 単体テスト - コンポーネントおよび命令単体テスト]() で 1 つずつ説明します。

コーディングを楽しんでください!

以上がテスト環境をセットアップするにはどうすればよいですか? Angular テスト ツールセットの概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Java のインターフェースと抽象クラスの単体テストの実践 Java のインターフェースと抽象クラスの単体テストの実践 May 02, 2024 am 10:39 AM

Java のインターフェースと抽象クラスの単体テストの実践

PHP単体テストツールの長所と短所の分析 PHP単体テストツールの長所と短所の分析 May 06, 2024 pm 10:51 PM

PHP単体テストツールの長所と短所の分析

golangの機能テストにおける単体テストと結合テストの違いは何ですか? golangの機能テストにおける単体テストと結合テストの違いは何ですか? Apr 27, 2024 am 08:30 AM

golangの機能テストにおける単体テストと結合テストの違いは何ですか?

Go 言語でのパフォーマンス テストと単体テストの違い Go 言語でのパフォーマンス テストと単体テストの違い May 08, 2024 pm 03:09 PM

Go 言語でのパフォーマンス テストと単体テストの違い

Golang 単体テストでテーブル駆動テスト手法を使用するにはどうすればよいですか? Golang 単体テストでテーブル駆動テスト手法を使用するにはどうすればよいですか? Jun 01, 2024 am 09:48 AM

Golang 単体テストでテーブル駆動テスト手法を使用するにはどうすればよいですか?

PHP 単体テスト: コード カバレッジを高めるためのヒント PHP 単体テスト: コード カバレッジを高めるためのヒント Jun 01, 2024 pm 06:39 PM

PHP 単体テスト: コード カバレッジを高めるためのヒント

PHP 単体テスト: 効果的なテスト ケースを設計する方法 PHP 単体テスト: 効果的なテスト ケースを設計する方法 Jun 03, 2024 pm 03:34 PM

PHP 単体テスト: 効果的なテスト ケースを設計する方法

PHP 単体テストと継続的デリバリーの統合 PHP 単体テストと継続的デリバリーの統合 May 06, 2024 pm 06:45 PM

PHP 単体テストと継続的デリバリーの統合

See all articles