jest測試react native元件的步奏是什麼
這次帶給大家jest測試react native組件的步奏是什麼,jest測試react native組件的注意事項有哪些,下面就是實戰案例,一起來看一下。
目前Javascript的測試工具很多,但針對React的測試策略,Facebook推出的ReactJs標配測試工具是Jest.Jest的官網位址:https://facebook.github.io/jest/。我們可以看到Jest官網宣稱的是:Painless JavaScript Testing。是Facebook用於測試服務和React應用程式的JavaScript單元測試框架。
所謂單元測試也就是對每個單元進行測試,通俗的將一般針對的是函數,類別或單一元件,不涉及系統和整合。單元測試是軟體測試的基礎測試。 Jest主要有以下特點:
適應性:Jest是模組化、可擴充、可設定的。
沙箱與快速:Jest虛擬化了JavaScript的環境,能模擬瀏覽器,並且並行執行
快照測試:Jest能夠對React 樹進行快照或別的序列化數值快速編寫測試,提供快速更新的使用者體驗。
支援非同步程式碼測試:支援promises和async/await
#自動產生靜態分析結果:不僅顯示測試案例執行結果,也顯示語句、分支、函數等覆蓋率。
為什麼要使用單元測試工具
我們在開發過程中,不使用測試工具還是可以自己寫程式碼進行單元測試,但是我們的程式碼存在著相互呼叫關係,在測試過程中我們又希望使單元相對獨立而又能正常運行,就需要我們對被測函數的依賴函數和環境進行mock,並且在測試資料輸入、測試執行和測試結果檢查方面有許多相似性,測試工具正是為我們在這些方面提供了方便。
準備階段
需要一個rn項目,這裡示範的是我個人的專案ReactNative-ReduxSaga-TODO
安裝jest
#如果你是用react-native init命令列創建的rn項目,並且你的rn版本在0.38以上,則無需安裝了。不太清楚的話就看一下
package.json檔案中是否包含以下程式碼:
// package.json "scripts": { "test": "jest" }, "jest": { "preset": "react-native" }
如果沒有就安裝一下npm i jest --save-dev,並且把上述程式碼加入到package.json檔案的對應位置。
以上步驟完成後,簡單執行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資料夾,現在,讓我們使用React的測試渲染器和Jest的快照功能來與元件進行交互,並捕獲呈現的輸出並建立一個快照檔案。
// 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.
Tests: 1 passed, 1 total# 191919191919198191919990919990919909199201990011990201990200007007130700700073073073003073 月 2 s
Test Suites: 1 passed, 1 totalRan 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> `;登入後複製
在下次執行測試的時候,呈現的輸出將與先前建立的快照進行比較。快照應該和程式碼一起提交。當快照測試失敗的時候,就需要檢查是否有意或無意的更改。如果是和預期中的變化一樣,請呼叫jest -u來覆蓋目前的快照。 我們來更改原來的程式碼:把第二行
<Text style={{ fontSize: 14, color }}>{text}</Text>
這時,我們再執行jest。這時終端將會拋出錯誤,並指出了錯誤位置
因為這段程式碼是我們有意改的,這時運行jest -u,快照被覆蓋。再執行jest則不會報錯了~
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
以上是jest測試react native元件的步奏是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

React前後端分離指南:如何實現前後端的解耦和獨立部署,需要具體程式碼範例在當今的Web開發環境中,前後端分離已經成為一種趨勢。透過將前端和後端程式碼分開,可以讓開發工作更加靈活、高效,並且方便進行團隊協作。本文將介紹如何使用React實現前後端分離,從而實現解耦和獨立部署的目標。首先,我們要先理解什麼是前後端分離。傳統的Web開發模式中,前端和後端是耦合在

如何利用React和Flask建構簡單易用的網路應用引言:隨著網路的發展,網路應用的需求也越來越多樣化和複雜化。為了滿足使用者對於易用性和效能的要求,使用現代化的技術堆疊來建立網路應用變得越來越重要。 React和Flask是兩個在前端和後端開發中非常受歡迎的框架,它們可以很好的結合在一起,用來建立簡單易用的網路應用。本文將詳細介紹如何利用React和Flask

如何利用React和RabbitMQ建立可靠的訊息傳遞應用程式引言:現代化的應用程式需要支援可靠的訊息傳遞,以實現即時更新和資料同步等功能。 React是一種流行的JavaScript庫,用於建立使用者介面,而RabbitMQ是一種可靠的訊息傳遞中間件。本文將介紹如何結合React和RabbitMQ建立可靠的訊息傳遞應用,並提供具體的程式碼範例。 RabbitMQ概述:

ReactRouter使用指南:如何實現前端路由控制隨著單頁應用的流行,前端路由成為了一個不可忽視的重要部分。 ReactRouter作為React生態系統中最受歡迎的路由庫,提供了豐富的功能和易用的API,使得前端路由的實作變得非常簡單和靈活。本文將介紹ReactRouter的使用方法,並提供一些具體的程式碼範例。安裝ReactRouter首先,我們需要

如何利用React和ApacheKafka來建立即時資料處理應用介紹:隨著大數據與即時資料處理的興起,建構即時資料處理應用成為了許多開發者的追求。 React作為一個流行的前端框架,與ApacheKafka作為一個高效能的分散式訊息系統的結合,可以幫助我們建立即時資料處理應用。本文將介紹如何利用React和ApacheKafka建構即時資料處理應用,並

PHP、Vue和React:如何選擇最適合的前端框架?隨著互聯網技術的不斷發展,前端框架在Web開發中起著至關重要的作用。 PHP、Vue和React作為三種代表性的前端框架,每一種都具有其獨特的特徵和優勢。在選擇使用哪種前端框架時,開發人員需要根據專案需求、團隊技能和個人偏好做出明智的決策。本文將透過比較PHP、Vue和React這三種前端框架的特徵和使

Java框架與React框架的整合:步驟:設定後端Java框架。建立專案結構。配置建置工具。建立React應用程式。編寫RESTAPI端點。配置通訊機制。實戰案例(SpringBoot+React):Java程式碼:定義RESTfulAPI控制器。 React程式碼:取得並顯示API回傳的資料。

如何利用React開發一個響應式的後台管理系統隨著互聯網的快速發展,越來越多的企業和組織需要一個高效、靈活、易於管理的後台管理系統來處理日常的操作事務。 React作為目前最受歡迎的JavaScript庫之一,提供了一種簡潔、高效和可維護的方式來建立使用者介面。本文將介紹如何利用React開發一個響應式的後台管理系統,並給出具體的程式碼範例。建立React專案首先
