目錄
設定腳本
首頁 web前端 js教程 如何建構測試環境? Angular測試工具集介紹

如何建構測試環境? Angular測試工具集介紹

Aug 22, 2020 am 11:16 AM
angular 單元測試

如何建構測試環境? Angular測試工具集介紹

本文將探討如何建構測試環境、以及Angular測試工具集。

測試環境

絕大部分都是利用Angular Cli來創建項目,因此,預設已經整合我們所需要的npm套件與腳本;當然,如果你是使用自建或官網quickstart 的話,需要自行安裝;但所有核心數據都是一樣的。 【相關教學推薦:angular教學

Angular單元測試我們可以將其分成兩類:獨立單獨測試與Angular測試工具集。

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"
登入後複製

那麼,我們重要還是看設定腳本部分。

設定腳本

我們核心是需要讓karma 運行器運行起來,而對於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 config文件的所有信息,請參與官網文檔

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 Cli那麼 ng test折騰的用node "./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測試工具集

普通類別諸如Pipe或Service,只需要透過簡單的 new 建立實例。而對於指令、元件而言,需要一定的環境。這是因為Angular的模組概念,要想元件能運行,首先得有一個 @NgModule 定義。

工具集的資訊量並不很多,你很容易可以掌握它。下面我簡單說明幾個最常用的:

TestBed

#TestBed 是Angular測試工具集提供的用來建構一個 @NgModule 測試環境模組。當然有了模組,還需要利用 TestBed.createComponent 建立一個用於測試目標元件的測試元件。

非同步

Angular到處都是非同步,而非同步測試可以利用工具集中asyncfakeAsync# 編寫優雅測試代碼看著是同步。

工具集還有更多,這一切我們將在[Angular單元測試-元件與指令單元測試]()逐一說明。

happy coding!

#

以上是如何建構測試環境? Angular測試工具集介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Java 中介面和抽象類別的單元測試實踐 Java 中介面和抽象類別的單元測試實踐 May 02, 2024 am 10:39 AM

針對Java中介面和抽象類別進行單元測試的步驟:介面建立一個測試類別。建立一個模擬類別來實作介面方法。使用Mockito庫模擬介面方法並編寫測試方法。抽象類別建立一個測試類別。建立抽象類別的子類別。編寫測試方法來測試抽象類別的正確性。

PHP 單元測試工具的優缺點分析 PHP 單元測試工具的優缺點分析 May 06, 2024 pm 10:51 PM

PHP單元測試工具分析:PHPUnit:適用於大型項目,提供全面功能,易於安裝,但可能冗長且速度較慢。 PHPUnitWrapper:適合小型項目,易於使用,針對Lumen/Laravel優化,但功能受限,不提供程式碼覆蓋率分析,社群支援有限。

Go語言中的效能測試與單元測試的差異 Go語言中的效能測試與單元測試的差異 May 08, 2024 pm 03:09 PM

效能測試評估應用程式在不同負載下的效能,而單元測試驗證單一程式碼單元的正確性。效能測試著重於測量反應時間和吞吐量,而單元測試則關注函數輸出和程式碼覆蓋率。性能測試透過高負載和並發模擬實際環境,而單元測試在低負載和串行條件下運行。效能測試的目標是識別效能瓶頸和最佳化應用程序,而單元測試的目標是確保程式碼正確性和健全性。

如何在 Golang 單元測試中使用表格驅動的測試方法? 如何在 Golang 單元測試中使用表格驅動的測試方法? Jun 01, 2024 am 09:48 AM

表驅動的測試在Go單元測試中透過表定義輸入和預期輸出簡化了測試案例編寫。語法包括:1.定義一個包含測試案例結構的切片;2.循環遍歷切片並比較結果與預期輸出。在實戰案例中,對字串轉換大寫的函數進行了表格驅動的測試,並使用gotest運行測試,列印通過結果。

單元測試與整合測試在golang函數測試中的差異? 單元測試與整合測試在golang函數測試中的差異? Apr 27, 2024 am 08:30 AM

單元測試和整合測試是兩種不同的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