詳解如何在項(xiàng)目中使用jest測(cè)試react native組件
目前Javascript的測(cè)試工具很多,但是針對(duì)React的測(cè)試策略,F(xiàn)acebook推出的ReactJs標(biāo)配測(cè)試工具是Jest.Jest的官網(wǎng)地址:https://facebook.github.io/jest/。我們可以看到Jest官網(wǎng)宣稱的是:Painless JavaScript Testing。是Facebook用于測(cè)試服務(wù)和React應(yīng)用程序的JavaScript單元測(cè)試框架。
所謂單元測(cè)試也就是對(duì)每個(gè)單元進(jìn)行測(cè)試,通俗的將一般針對(duì)的是函數(shù),類或單個(gè)組件,不涉及系統(tǒng)和集成。單元測(cè)試是軟件測(cè)試的基礎(chǔ)測(cè)試。Jest主要有以下特點(diǎn):
- 適應(yīng)性:Jest是模塊化、可擴(kuò)展和可配置的。
- 沙箱和快速:Jest虛擬化了JavaScript的環(huán)境,能模擬瀏覽器,并且并行執(zhí)行
- 快照測(cè)試:Jest能夠?qū)eact 樹進(jìn)行快照或別的序列化數(shù)值快速編寫測(cè)試,提供快速更新的用戶體驗(yàn)。
- 支持異步代碼測(cè)試:支持promises和async/await
- 自動(dòng)生成靜態(tài)分析結(jié)果:不僅顯示測(cè)試用例執(zhí)行結(jié)果,也顯示語(yǔ)句、分支、函數(shù)等覆蓋率。
為什么要使用單元測(cè)試工具
我們?cè)陂_發(fā)過程中,不使用測(cè)試工具依然可以自己寫代碼進(jìn)行單元測(cè)試,但是我們的代碼存在著相互調(diào)用關(guān)系,在測(cè)試過程中我們又希望使單元相對(duì)獨(dú)立而又能正常運(yùn)行,就需要我們對(duì)被測(cè)函數(shù)的依賴函數(shù)和環(huán)境進(jìn)行mock,并且在測(cè)試數(shù)據(jù)輸入、測(cè)試執(zhí)行和測(cè)試結(jié)果檢查方面存在很多相似性,測(cè)試工具正是為我們?cè)谶@些方面提供了方便。
準(zhǔn)備階段
需要一個(gè)rn項(xiàng)目,這里演示的是我個(gè)人的項(xiàng)目ReactNative-ReduxSaga-TODO
安裝jest
如果你是用react-native init命令行創(chuàng)建的rn項(xiàng)目,并且你的rn版本在0.38以上,則無需安裝了。不太清楚的話就看一下
package.json文件中是否包含以下代碼:
// package.json "scripts": { "test": "jest" }, "jest": { "preset": "react-native" }
如果沒有就安裝一下npm i jest --save-dev,并把上述代碼添加到package.json文件的對(duì)應(yīng)位置。
以上步驟完成后,簡(jiǎn)單運(yùn)行npm run test測(cè)試一下jest是否配置成功。但我們沒有寫測(cè)試用例,終端會(huì)打印no tests found。這時(shí)就配置完成了。
快照測(cè)試
寫一個(gè)組件
import React from 'react'; import { Text, View, } from 'react-native'; import PropTypes from 'prop-types'; const PostArea = ({ title, text, color }) => ( <View style={{ backgroundColor: '#ddd', height: 100 }}> <Text style={{ fontSize: 30 }}>{title}</Text> <Text style={{ fontSize: 15, color }}>{text}</Text> </View> ); export default PostArea;
在項(xiàng)目根目錄下找到__test__文件夾,現(xiàn)在,讓我們使用React的測(cè)試渲染器和Jest的快照功能來與組件進(jìn)行交互,并捕獲呈現(xiàn)的輸出并創(chuàng)建一個(gè)快照文件。
// PostArea_test.js import 'react-native'; import React from 'react'; import PostArea from '../js/Twitter/PostArea'; import renderer from 'react-test-renderer'; test('renders correctly', () => { const tree = renderer.create(<PostArea title="title" text="text" color="red" />).toJSON(); expect(tree).toMatchSnapshot(); });
然后在終端運(yùn)行npm run test或jest。將會(huì)輸出:
PASS __tests__\PostArea_test.js (6.657s)
√ renders correctly (5553ms)› 1 snapshot written.
Snapshot Summary
› 1 snapshot written in 1 test suite.Test Suites: 1 passed, 1 total
Tests: 1 passed, 1 total
Snapshots: 1 added, 1 total
Time: 8.198s
Ran all test suites.
同時(shí),在test文件夾下會(huì)輸出一個(gè)文件,即為生成的快照。
// Jest Snapshot v1, https://goo.gl/fbAQLP exports[`renders correctly 1`] = ` <View style={ Object { "backgroundColor": "#ddd", "height": 100, } } > <Text accessible={true} allowFontScaling={true} disabled={false} ellipsizeMode="tail" style={ Object { "fontSize": 30, } } > title </Text> <Text accessible={true} allowFontScaling={true} disabled={false} ellipsizeMode="tail" style={ Object { "color": "red", "fontSize": 15, } } > text </Text> </View> `;
修改源文件
在下一次運(yùn)行測(cè)試的時(shí)候,呈現(xiàn)的輸出將與之前創(chuàng)建的快照進(jìn)行比較??煺諔?yīng)該和代碼一起提交。當(dāng)快照測(cè)試失敗的時(shí)候,就需要檢查是否有意或無意的更改。如果是和預(yù)期中的變化一樣,調(diào)用jest -u來覆蓋當(dāng)前的快照。
我們來更改一下原來的代碼:把第二行<Text>的字號(hào)改為14.
<Text style={{ fontSize: 14, color }}>{text}</Text>
這時(shí),我們?cè)龠\(yùn)行jest。這時(shí)終端將會(huì)拋出錯(cuò)誤,并指出了錯(cuò)誤位置
因?yàn)檫@段代碼是我們有意改的,這時(shí)運(yùn)行jest -u,快照被覆蓋。再執(zhí)行jest則不會(huì)報(bào)錯(cuò)了~
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
react后臺(tái)系統(tǒng)最佳實(shí)踐示例詳解
這篇文章主要為大家介紹了react后臺(tái)系統(tǒng)最佳實(shí)踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01react router4+redux實(shí)現(xiàn)路由權(quán)限控制的方法
本篇文章主要介紹了react router4+redux實(shí)現(xiàn)路由權(quán)限控制的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05react+antd select下拉框?qū)崿F(xiàn)模糊搜索匹配的示例代碼
我們?cè)陂_發(fā)過程中,經(jīng)常會(huì)出現(xiàn)下拉框數(shù)據(jù)很多得情況,本文主要介紹了react+antd select下拉框?qū)崿F(xiàn)模糊搜索匹配的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01淺談React?Refs?使用場(chǎng)景及核心要點(diǎn)
本文主要介紹了React?Refs?使用場(chǎng)景及核心要點(diǎn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06React配置多個(gè)代理實(shí)現(xiàn)數(shù)據(jù)請(qǐng)求返回問題
這篇文章主要介紹了React之配置多個(gè)代理實(shí)現(xiàn)數(shù)據(jù)請(qǐng)求返回問題,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08詳解react native頁(yè)面間傳遞數(shù)據(jù)的幾種方式
這篇文章主要介紹了詳解react native頁(yè)面間傳遞數(shù)據(jù)的幾種方式,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11使用 React Router Dom 實(shí)現(xiàn)路由導(dǎo)航的詳細(xì)過程
React Router Dom 是 React 應(yīng)用程序中用于處理路由的常用庫(kù),它提供了一系列組件和 API 來管理應(yīng)用程序的路由,這篇文章主要介紹了使用 React Router Dom 實(shí)現(xiàn)路由導(dǎo)航,需要的朋友可以參考下2024-03-03