目次
設定スクリプト
ホームページ ウェブフロントエンド 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 までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++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 でインターフェイスと抽象クラスを単体テストする手順: インターフェイスのテスト クラスを作成します。インターフェイス メソッドを実装するためのモック クラスを作成します。 Mockito ライブラリを使用して、インターフェイス メソッドをモックし、テスト メソッドを作成します。抽象クラスはテストクラスを作成します。抽象クラスのサブクラスを作成します。抽象クラスの正確性をテストするテスト メソッドを作成します。

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

パフォーマンス テストでは、さまざまな負荷の下でアプリケーションのパフォーマンスを評価します。一方、単体テストでは、単一のコード単位の正確性を検証します。パフォーマンス テストは応答時間とスループットの測定に重点を置き、単体テストは関数の出力とコード カバレッジに重点を置きます。パフォーマンス テストは高負荷と同時実行性のある現実の環境をシミュレートしますが、単体テストは低負荷とシリアル条件で実行されます。パフォーマンス テストの目標は、パフォーマンスのボトルネックを特定し、アプリケーションを最適化することですが、単体テストの目標は、コードの正確さと堅牢性を確認することです。

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

PHP 単体テスト ツール分析: PHPUnit: 大規模プロジェクトに適しており、包括的な機能を提供し、インストールが簡単ですが、冗長で遅い場合があります。 PHPUnitWrapper: 小規模プロジェクトに適しており、使いやすく、Lumen/Laravel に最適化されていますが、機能が限られており、コード カバレッジ分析は提供されず、コミュニティ サポートも限られています。

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

テーブル駆動テストは、テーブルを通じて入力と予想される出力を定義することにより、Go 単体テストでのテスト ケースの作成を簡素化します。構文には次のものが含まれます。 1. テスト ケース構造を含むスライスを定義します。 2. スライスをループし、結果を予想される出力と比較します。実際のケースでは、文字列を大文字に変換する関数に対してテーブル駆動テストが実行され、getest を使用してテストが実行され、合格結果が出力されました。

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

単体テストと統合テストは 2 つの異なるタイプの Go 関数テストであり、それぞれ単一関数または複数関数の相互作用と統合を検証するために使用されます。単体テストは特定の関数の基本機能のみをテストしますが、統合テストは複数の関数間の相互作用とアプリケーションの他の部分との統合をテストします。

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

効果的な単体テスト ケースを設計するには、原子的、簡潔、反復可能、明確という原則を遵守することが重要です。手順には、テストするコードの決定、テスト シナリオの特定、アサーションの作成、テスト メソッドの記述が含まれます。実際のケースでは、max() 関数のテスト ケースの作成を示し、特定のテスト シナリオとアサーションの重要性を強調しています。これらの原則と手順に従うことで、コードの品質と安定性を向上させることができます。

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

PHP 単体テストでコード カバレッジを改善する方法: PHPUnit の --coverage-html オプションを使用してカバレッジ レポートを生成します。 setAccessible メソッドを使用して、プライベート メソッドとプロパティをオーバーライドします。アサーションを使用してブール条件をオーバーライドします。コードレビューツールを使用して、コードカバレッジに関する追加の洞察を取得します。

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

概要: PHPUnit 単体テスト フレームワークと CI/CD パイプラインを統合することで、PHP コードの品質を向上させ、ソフトウェアの配信を高速化できます。 PHPUnit を使用すると、コンポーネントの機能を検証するためのテスト ケースを作成でき、GitLabCI や GitHubActions などの CI/CD ツールでこれらのテストを自動的に実行できます。例: テスト ケースを使用して認証コントローラーを検証し、ログイン機能が期待どおりに動作することを確認します。

See all articles