摘要:包包含由團(tuán)隊提供的測試實用程序。將在一個名為的目錄中自動查找整個樹中的測試文件是的帶有下劃線。讓我們?yōu)闀r間軸組件創(chuàng)建第一個測試。其中之一是命令?,F(xiàn)在我們已經(jīng)編寫了第一個測試并確認(rèn)了我們的設(shè)置我們將在明天開始測試我們的時間軸組件。
本文轉(zhuǎn)載自:眾成翻譯
譯者:iOSDevLog
鏈接:http://www.zcfy.cc/article/3807
原文:https://www.fullstackreact.com/30-days-of-react/day-23/
昨天我們檢查了我們在React中寫的不同類型的測試。今天我們親自動手來看看結(jié)果。我們將安裝設(shè)置測試所需的依賴關(guān)系以及寫入我們的第一個斷言。
讓我們把我們的應(yīng)用設(shè)置起來進(jìn)行測試。因為我們將使用幾個不同的庫, 所以我們需要在使用它們之前安裝它們 (當(dāng)然)。
依賴關(guān)系我們將使用下面的npm 庫:
jest/jest-cli是 Facebook 發(fā)布的官方測試框架, 是測試React應(yīng)用的絕佳測試框架。它非??? 提供沙盒測試環(huán)境, 支持快照測試, 等等。
babel-jest/babel-preset-stage-0我們將使用階段 0 (或 ES6-edge 功能) 編寫測試, 因此我們希望確保我們的測試框架能夠讀取和處理我們的測試和源文件中的 ES6。
sinonSinon是一個測試實用程序庫, 它為我們提供了一種編寫間諜(spies)、存根(stubs)和 模擬(mock) 的方法。我們將在需要時討論這些內(nèi)容, 但現(xiàn)在我們將安裝該庫。
react-addons-test-utils/enzymereact-addons-test-utils 包包含由React團(tuán)隊提供的測試實用程序。
Enzyme是由 Airbnb 構(gòu)建/維護(hù)的 更易于使用的JavaScript 測試庫,并且提供了遍歷/操縱響應(yīng)的虛擬 DOM 輸出的非常好的方法。當(dāng)我們開始使用react-addons-test-utils, 我們將過渡到使用Enzyme, 我們更喜歡在我們的測試中使用它。
react-test-rendererreact-test-renderer 庫允許我們使用jest庫中的快照功能??煺帐且环NJest的方式, 可將呈現(xiàn)的輸出從虛擬 DOM 序列化為一個文件, 我們可以從一個測試自動進(jìn)行比較。
redux-mock-storeredux-mock-store庫允許我們輕松地制作一個再現(xiàn)存儲進(jìn)行測試。我們將使用它來測試我們的動作創(chuàng)創(chuàng)建者, 中間件, 和我們的歸并器。
To install all of these libraries, we"ll use the following npm command in the terminal while in the root directory of our projects:要安裝所有這些庫, 我們將在項目的根目錄中使用終端中的npm 命令:
yarn add --dev babel-jest babel-preset-stage-0 enzyme jest-cli react-addons-test-utils react-test-renderer redux-mock-store sinon配置
我們還需要配置我們的安裝程序。首先, 讓我們添加一個 npm 腳本, 它將允許我們使用npm test 命令運行測試。在我們的項目根目錄的package.json 文件, 讓我們添加test 腳本。在package.json文件中查找腳本鍵, 然后添加test 命令, 如下所示:
{ // ... "scripts": { "start": "react-scripts start", "build": "react-scripts build", "eject": "react-scripts eject", "test": "react-scripts test --env=jsdom" }, }編寫測試
讓我們確認(rèn)我們的測試設(shè)置工作正常。Jest將在一個名為__tests__ 的目錄中自動查找整個樹中的測試文件 (是的, 帶有下劃線)。讓我們在我們的src/components/Timeline 目錄中創(chuàng)建我們的第一個__tests__ 目錄, 并創(chuàng)建我們的第一個測試文件:
mkdir src/components/Timeline/__tests__ touch src/components/Timeline/__tests__/Timeline-test.js
Timeline-test.js文件將包括我們的Timeline組件的所有測試 (如文件名所示)。讓我們?yōu)闀r間軸組件創(chuàng)建第一個測試。
我們將使用 Jasmine框架編寫測試。Jasmine提供了一些方法, 我們將使用相當(dāng)多的一些方法。以下兩種方法都接受兩個參數(shù), 第一種是描述字符串, 第二個是要執(zhí)行的函數(shù):
describe()
it()
describe() 函數(shù)為我們提供了一種將測試組合成邏輯包的方法。由于我們正在為我們的Timeline編寫一組測試, 我們將在測試中使用describe() 函數(shù)來指示我們正在測試時間軸。
在src/components/Timeline/__tests__/Timeline-test.js文件中, 讓我們添加描述塊:
describe("Timeline", () => { });
我們可以使用it() 函數(shù)添加第一個測試。it() 函數(shù)是我們將設(shè)定預(yù)期的位置。讓我們用我們的第一個期望, 一個通過和一個失敗來設(shè)置我們的測試, 這樣我們可以看到輸出的差異。
In the same file, let"s add two tests:在同一個文件中, 讓我們添加兩個測試:
describe("Timeline", () => { it("passing test", () => { expect(true).toBeTruthy(); }) it("failing test", () => { expect(false).toBeTruthy(); }) })
我們將看看可能的期望, 我們可以設(shè)定在一個時刻。首先, 讓我們運行我們的測試。
執(zhí)行測試create-react-app 包 使用Jest自動為我們建立了一個質(zhì)量測試環(huán)境,。我們可以使用yarn test或npm test腳本執(zhí)行測試。
在終端中, 讓我們執(zhí)行我們的測試:
yarn test
從這個輸出, 我們可以看到兩個測試, 一個通過測試 (帶有一個綠色的復(fù)選標(biāo)記) 和一個失敗的測試 (還有一個紅色的 x 和失敗的描述)。
讓我們更新第二個測試, 使它通過將期望更改為toBeFalsy():
describe("Timeline", () => { it("passing test", () => { expect(true).toBeTruthy(); }) it("failing test", () => { expect(false).toBeTruthy(); }) })
重新運行測試, 我們可以看到我們有兩個通過測試
`yarn test`期望
在默認(rèn)情況下, Jest在測試中提供了一些全局命令 (即沒必要要求的內(nèi)容)。其中之一是expect() 命令。expect() 命令有幾個期望, 我們可以調(diào)用它, 包括我們已經(jīng)使用的兩個:
toBeTruthy()
toBeFalsy()
toBe()
toEqual()
toBeDefined()
toBeCalled()
etc.
在以下的 jest頁面中可以獲得一整套期望:https://facebook.github.io/jest/docs/api.html#writing-assertions-with-expect.
expect() 函數(shù)采用單個參數(shù): 返回要測試的值函數(shù)的返回值。例如, 我們已經(jīng)寫好的兩個測試通過了true 和false的布爾值。
現(xiàn)在我們已經(jīng)編寫了第一個測試并確認(rèn)了我們的設(shè)置, 我們將在明天開始測試我們的時間軸組件。今天的工作很好, 明天見!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/87163.html
摘要:今天我們將討論創(chuàng)建組件的最終方案,即無狀態(tài)函數(shù)的純組件。今天我們正在研究一種處理提出的復(fù)雜數(shù)據(jù)的方法,稱為體系結(jié)構(gòu)。第天部署介紹今天,我們將探討部署我們的應(yīng)用所涉及的不同部分,以便外界可以使用我們的應(yīng)用。 本文轉(zhuǎn)載自:眾成翻譯譯者:iOSDevLog鏈接:http://www.zcfy.cc/article/3758原文:https://www.fullstackreact.com/3...
摘要:我們的第一個假設(shè)是非常簡單的測試。我們正在測試以確保元素被包裝在類中。在我們編寫的每個測試中我們都需要將應(yīng)用呈現(xiàn)在工作測試文檔中。作為提醒我們可以使用命令或命令來運行測試。 本文轉(zhuǎn)載自:眾成翻譯譯者:iOSDevLog鏈接:http://www.zcfy.cc/article/3804原文:https://www.fullstackreact.com/30-days-of-react/...
摘要:我們將討論三種不同的軟件測試范例單元測試功能測試和集成測試。在中單元測試通常不需要瀏覽器可以快速運行不需要寫入斷言本身通常是簡單而簡潔的。集成測試最后我們將研究的最后一種測試是集成測試。 本文轉(zhuǎn)載自:眾成翻譯譯者:iOSDevLog鏈接:http://www.zcfy.cc/article/3809原文:https://www.fullstackreact.com/30-days-of...
摘要:今天我們將討論創(chuàng)建組件的最終方案,即無狀態(tài)函數(shù)的純組件。為了獲得更多的性能和簡單性,同樣允許我們使用正常的函數(shù)創(chuàng)建純粹的,無狀態(tài)的組件。在中,功能組件被稱為一個參數(shù)的類似于構(gòu)造函數(shù)類,它們是它所調(diào)用的,以及組件樹的當(dāng)前。 本文轉(zhuǎn)載自:眾成翻譯譯者:iOSDevLog鏈接:http://www.zcfy.cc/article/3819原文:https://www.fullstackrea...
摘要:本文轉(zhuǎn)載自眾成翻譯譯者鏈接原文今天,我們將介紹一些可持續(xù)的集成解決方案,為我們提供運行測試以及實施測試我們在云端的應(yīng)用。我們已經(jīng)啟動了一個測試套件但是現(xiàn)在我們要確保它在部署之前完全通過。 本文轉(zhuǎn)載自:眾成翻譯譯者:iOSDevLog鏈接:http://www.zcfy.cc/article/3801原文:https://www.fullstackreact.com/30-days-of...
閱讀 1837·2021-09-28 09:46
閱讀 3154·2019-08-30 14:22
閱讀 1887·2019-08-26 13:36
閱讀 3353·2019-08-26 11:32
閱讀 2102·2019-08-23 16:56
閱讀 1158·2019-08-23 16:09
閱讀 1311·2019-08-23 12:55
閱讀 2158·2019-08-23 11:44