目前Javascript的測試工具很多,但是針對React的測試策略,Facebook推出的ReactJs標配測試工具是Jest.Jest的官網地址:https://facebook.github.io/jest/。我們可以看到Jest官網宣稱的是:Painless JavaScript Testing。是Facebook用于測試服務和React應用程序的JavaScript單元測試框架。
所謂單元測試也就是對每個單元進行測試,通俗的將一般針對的是函數,類或單個組件,不涉及系統和集成。單元測試是軟件測試的基礎測試。Jest主要有以下特點:
為什么要使用單元測試工具
我們在開發過程中,不使用測試工具依然可以自己寫代碼進行單元測試,但是我們的代碼存在著相互調用關系,在測試過程中我們又希望使單元相對獨立而又能正常運行,就需要我們對被測函數的依賴函數和環境進行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.jsimport '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/fbAQLPexports[`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>`;
修改源文件
在下一次運行測試的時候,呈現的輸出將與之前創建的快照進行比較??煺諔摵痛a一起提交。當快照測試失敗的時候,就需要檢查是否有意或無意的更改。如果是和預期中的變化一樣,調用jest -u來覆蓋當前的快照。
我們來更改一下原來的代碼:把第二行<Text>的字號改為14.
<Text style={{ fontSize: 14, color }}>{text}</Text>
這時,我們再運行jest。這時終端將會拋出錯誤,并指出了錯誤位置
因為這段代碼是我們有意改的,這時運行jest -u,快照被覆蓋。再執行jest則不會報錯了~
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答