在TypeScript項目中進(jìn)行BDD測試
什么是BDD?
BDD(Behavior-Driven Design)是軟件團(tuán)隊的一種工作方式,通過以下方式縮小業(yè)務(wù)人員和技術(shù)人員之間的差距:
- 鼓勵跨角色協(xié)作,建立對待解決問題的共同理解
- 以快速、小迭代的方式工作,以增加反饋和價值流
- 生成系統(tǒng)文檔,自動對照系統(tǒng)行為進(jìn)行檢查
我們通過將協(xié)作工作的重點(diǎn)放在具體的、真實的例子上來實現(xiàn)這一點(diǎn),這些例子說明了我們希望系統(tǒng)如何運(yùn)行。我們用這些例子來指導(dǎo)我們在持續(xù)合作的過程中從概念到實施。
Gherkin語法
BDD特性(Feature)描述采用Gherkin語法。Gherkin使用一組特殊的關(guān)鍵字為可執(zhí)行規(guī)范提供結(jié)構(gòu)和意義。每個關(guān)鍵詞都被翻譯成多種語言;在本參考資料中,我們將使用英語。
Cucumber是流行的BDD測試框架,支持各種平臺,其文檔中的大多數(shù)行都以一個關(guān)鍵字開頭。
注釋僅允許出現(xiàn)在新行的開頭,即要素文件中的任何位置。它們以零個或多個空格開頭,后跟散列符號(#)和一些文本。(Cucumber目前不支持區(qū)塊注釋。)
空格或制表符可用于縮進(jìn)。建議的縮進(jìn)級別為兩個空格。下面是一個例子:
Feature: Guess the word
# The first example has two steps
Scenario: Maker starts a game
When the Maker starts a game
Then the Maker waits for a Breaker to join
# The second example has three steps
Scenario: Breaker joins a game
Given the Maker has started a game with the word "silky"
When the Breaker joins the Maker's game
Then the Breaker must guess a word with 5 characters
Gherkin語法具體可以參考Gherkin Reference - Cucumber Documentation
給TypeScript項目配置BDD測試框架Cucumber.js
通過命令yarn add -D @cucumber/cucumber chai 安裝BDD測試框架Cucumber.js和斷言(Assert)框架chai。
創(chuàng)建目錄features,在目錄下創(chuàng)建文件bank-account.feature,內(nèi)容如下:
# features/bank-account.feature
Feature: Bank Account
Scenario: Stores money
Given A bank account with starting balance of $100
When $100 is deposited
Then The bank account balance should be $200
此文檔描述了存款場景,銀行存款賬戶有100美金,存入100美金,則賬戶應(yīng)該有200美金。
創(chuàng)建step-definitions\bank-account.steps.ts
const { Given, Then, When} = require( '@cucumber/cucumber');
const { assert } = require( 'chai');
let accountBalance = 0;
Given('A bank account with starting balance of ${int}', function(amount) {
accountBalance = amount;
});
When('${int} is deposited', function (amount) {
accountBalance = Number(accountBalance) + Number(amount);
});
Then('The bank account balance should be ${int}', function(expectedAmount) {
assert.equal(accountBalance, expectedAmount);
});
我們需要創(chuàng)建與之對應(yīng)的測試代碼,代碼將通過類型與特性文件中輸入和輸出驗證進(jìn)行映射,其中Given對應(yīng)的方法將獲得100美金初始賬戶金額的映射,傳給accountBalance。在When對應(yīng)的方法中,amount測試會獲得存入100美金的金額映射。最后,在Then對應(yīng)的方法中expectedAmount會映射到200美金,用來驗證最后是否與accountBalance相等,如果相等斷言正常返回,否則BDD判斷測試Case失敗。
我們可以通過命令
yarn cucumber-js features\**\*.feature -r step-definitions\**\*.js
運(yùn)行測試。
要想完成自動化配置,可以在工程根目錄下創(chuàng)建文件cucumber.js,內(nèi)容如下:
// cucumber.js
let common = [
'features/**/*.feature', // Specify our feature files
'--require step-definitions/**/*.js', // Load step definitions
'--format progress-bar', // Load custom formatter
].join(' ');
module.exports = {
default: common
};
再次執(zhí)行命令yarn cucumber-js,通過cucumber.js文件中的配置項,會自動找到feature文件和步驟定義腳本文件,完成BDD測試工作。
參考:
BDD Testing & Collaboration Tools for Teams | Cucumber
以上就是在TypeScript項目中進(jìn)行BDD測試的詳細(xì)內(nèi)容,更多關(guān)于TypeScript項目BDD測試的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JavaScript實現(xiàn)創(chuàng)建自定義對象的常用方式總結(jié)
這篇文章主要介紹了JavaScript實現(xiàn)創(chuàng)建自定義對象的常用方式,結(jié)合實例形式總結(jié)分析了JavaScript工廠模式、構(gòu)造函數(shù)模式、原型模式、組合模式等常用的自定義對象創(chuàng)建模式操作與使用技巧,需要的朋友可以參考下2018-07-07
js代碼運(yùn)行報錯Warning:To?load?an?ES?module,?set?"type&q
最近在學(xué)習(xí)ES6的過程中,和運(yùn)行javascript文件時進(jìn)行了報錯,下面這篇文章主要給大家介紹了關(guān)于js代碼運(yùn)行報錯Warning:To?load?an?ES?module,?set?"type":"module"in?the?package.json?or?use?the?.mjs的相關(guān)資料,需要的朋友可以參考下2023-04-04
詳解JS事件循環(huán)及宏任務(wù)微任務(wù)的原理
在js中,我們一般將所有的任務(wù)都分成兩類,一種是同步任務(wù),另外一種是異步任務(wù)。而在異步任務(wù)中,又有著更加細(xì)致的分類,那就是微任務(wù)和宏任務(wù)。本文將詳細(xì)講解這二者的原理與使用,需要的可以參考一下2022-05-05
淺析JavaScript函數(shù)的調(diào)用模式
這篇文章主要為大家詳細(xì)介紹了JavaScript函數(shù)的調(diào)用模式,包括方法調(diào)用模式,構(gòu)造器調(diào)用模式,apply/call調(diào)用模式,感興趣的小伙伴們可以參考一下2016-08-08
利用JS響應(yīng)式修改vue實現(xiàn)頁面的input值
這篇文章主要給大家介紹了關(guān)于如何利用JS響應(yīng)式修改vue實現(xiàn)頁面的input值,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用JS具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
javascript parseInt與Number函數(shù)的區(qū)別
在js中,如果你使用parseInt("08"),一般都會認(rèn)為會返回8,然而實際上返回了0.但是用Number("08")返回的才是8.2010-01-01
JS實現(xiàn)獲取數(shù)組中最大值或最小值功能示例
這篇文章主要介紹了JS實現(xiàn)獲取數(shù)組中最大值或最小值功能,結(jié)合實例形式總結(jié)分析了javascript獲取數(shù)組最大值與最小值的三種常見操作技巧,需要的朋友可以參考下2019-03-03
JavaScript中String和StringBuffer的速度之爭
很多Javascript書籍中都是類比于Java說String在頻繁的和大量的字符串連接方面的效率是不如StringBuffer的。2010-04-04

