這篇文章主要介紹了怎樣在項目中使用jest測試react native組件,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
走過十載,我們已為眾多企業(yè)及政府機關(guān)提供專業(yè)的互聯(lián)網(wǎng)服務(wù)。我們不只是一家專業(yè)網(wǎng)站建設(shè)公司;我們對營銷、技術(shù)、服務(wù)都有自己獨特見解,創(chuàng)新互聯(lián)采取“創(chuàng)意+綜合+營銷”一體化的方式為您提供更專業(yè)的服務(wù)!創(chuàng)新互聯(lián)經(jīng)歷的每一步也許不一定是最完美的,但每一步都有值得深思的意義。目前Javascript的測試工具很多,但是針對React的測試策略,F(xiàn)acebook推出的ReactJs標(biāo)配測試工具是Jest.Jest的官網(wǎng)地址:https://facebook.github.io/jest/。我們可以看到Jest官網(wǎng)宣稱的是:Painless JavaScript Testing。是Facebook用于測試服務(wù)和React應(yīng)用程序的JavaScript單元測試框架。
所謂單元測試也就是對每個單元進行測試,通俗的將一般針對的是函數(shù),類或單個組件,不涉及系統(tǒng)和集成。單元測試是軟件測試的基礎(chǔ)測試。Jest主要有以下特點:
適應(yīng)性:Jest是模塊化、可擴展和可配置的。
沙箱和快速:Jest虛擬化了JavaScript的環(huán)境,能模擬瀏覽器,并且并行執(zhí)行
快照測試:Jest能夠?qū)eact 樹進行快照或別的序列化數(shù)值快速編寫測試,提供快速更新的用戶體驗。
支持異步代碼測試:支持promises和async/await
自動生成靜態(tài)分析結(jié)果:不僅顯示測試用例執(zhí)行結(jié)果,也顯示語句、分支、函數(shù)等覆蓋率。
為什么要使用單元測試工具
我們在開發(fā)過程中,不使用測試工具依然可以自己寫代碼進行單元測試,但是我們的代碼存在著相互調(diào)用關(guān)系,在測試過程中我們又希望使單元相對獨立而又能正常運行,就需要我們對被測函數(shù)的依賴函數(shù)和環(huán)境進行mock,并且在測試數(shù)據(jù)輸入、測試執(zhí)行和測試結(jié)果檢查方面存在很多相似性,測試工具正是為我們在這些方面提供了方便。
準(zhǔn)備階段
需要一個rn項目,這里演示的是我個人的項目ReactNative-ReduxSaga-TODO
安裝jest
如果你是用react-native init命令行創(chuàng)建的rn項目,并且你的rn版本在0.38以上,則無需安裝了。不太清楚的話就看一下
package.json文件中是否包含以下代碼:
// package.json "scripts": { "test": "jest" }, "jest": { "preset": "react-native" }
如果沒有就安裝一下npm i jest --save-dev,并把上述代碼添加到package.json文件的對應(yīng)位置。
以上步驟完成后,簡單運行npm run test測試一下jest是否配置成功。但我們沒有寫測試用例,終端會打印no tests found。這時就配置完成了。
快照測試
寫一個組件
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;
在項目根目錄下找到__test__文件夾,現(xiàn)在,讓我們使用React的測試渲染器和Jest的快照功能來與組件進行交互,并捕獲呈現(xiàn)的輸出并創(chuàng)建一個快照文件。
// 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(); });
然后在終端運行npm run test或jest。將會輸出:
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.
同時,在test文件夾下會輸出一個文件,即為生成的快照。
// 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> `;
修改源文件
在下一次運行測試的時候,呈現(xiàn)的輸出將與之前創(chuàng)建的快照進行比較??煺諔?yīng)該和代碼一起提交。當(dāng)快照測試失敗的時候,就需要檢查是否有意或無意的更改。如果是和預(yù)期中的變化一樣,調(diào)用jest -u來覆蓋當(dāng)前的快照。
我們來更改一下原來的代碼:把第二行<Text>的字號改為14.
<Text style={{ fontSize: 14, color }}>{text}</Text>
這時,我們再運行jest。這時終端將會拋出錯誤,并指出了錯誤位置
感謝你能夠認真閱讀完這篇文章,希望小編分享的“怎樣在項目中使用jest測試react native組件”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
名稱欄目:怎樣在項目中使用jest測試reactnative組件-創(chuàng)新互聯(lián)
分享地址:http://www.rwnh.cn/article4/epeoe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、面包屑導(dǎo)航、網(wǎng)頁設(shè)計公司、企業(yè)建站、企業(yè)網(wǎng)站制作、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容