亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

詳解如何在項目中使用jest測試react native組件

2019-11-19 14:22:22
字體:
來源:轉載
供稿:網友

目前Javascript的測試工具很多,但是針對React的測試策略,Facebook推出的ReactJs標配測試工具是Jest.Jest的官網地址:https://facebook.github.io/jest/。我們可以看到Jest官網宣稱的是:Painless JavaScript Testing。是Facebook用于測試服務和React應用程序的JavaScript單元測試框架。

所謂單元測試也就是對每個單元進行測試,通俗的將一般針對的是函數,類或單個組件,不涉及系統和集成。單元測試是軟件測試的基礎測試。Jest主要有以下特點:

  1. 適應性:Jest是模塊化、可擴展和可配置的。
  2. 沙箱和快速:Jest虛擬化了JavaScript的環境,能模擬瀏覽器,并且并行執行
  3. 快照測試:Jest能夠對React 樹進行快照或別的序列化數值快速編寫測試,提供快速更新的用戶體驗。
  4. 支持異步代碼測試:支持promises和async/await
  5. 自動生成靜態分析結果:不僅顯示測試用例執行結果,也顯示語句、分支、函數等覆蓋率。

為什么要使用單元測試工具

我們在開發過程中,不使用測試工具依然可以自己寫代碼進行單元測試,但是我們的代碼存在著相互調用關系,在測試過程中我們又希望使單元相對獨立而又能正常運行,就需要我們對被測函數的依賴函數和環境進行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則不會報錯了~

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品中文久久久久久久| 国产性猛交xxxx免费看久久| 日韩激情av在线免费观看| 91在线观看免费网站| 亚洲国产成人av在线| 国产精品欧美风情| 欧美日本高清一区| 国产日韩欧美一二三区| 欧美一级电影久久| 久久人人爽人人爽爽久久| 亚洲免费视频在线观看| 国产欧美日韩91| 欧美电影第一页| 亚洲成人精品av| 欧美成人在线免费| 精品久久久久久久久久ntr影视| 超薄丝袜一区二区| 欧美成人免费大片| 国产小视频国产精品| 在线观看亚洲视频| 国产亚洲欧美另类中文| 九九久久久久99精品| 66m—66摸成人免费视频| 欧美性xxxxx极品| 欧美另类暴力丝袜| 日韩欧美一区二区在线| 久久久久久97| www.日本久久久久com.| 欧美在线免费观看| 丁香五六月婷婷久久激情| 欧美中文字幕第一页| 人妖精品videosex性欧美| 久久影院免费观看| 久久91精品国产91久久跳| 国产精品第三页| 国产欧美日韩中文字幕| 亚洲精品资源美女情侣酒店| 精品亚洲精品福利线在观看| 国产一区二区三区毛片| 国产精品嫩草影院久久久| 国产剧情日韩欧美| 欧美一级淫片videoshd| 一本色道久久88综合亚洲精品ⅰ| 九九九热精品免费视频观看网站| 在线亚洲午夜片av大片| 亚洲精品有码在线| 91亚洲精华国产精华| 久久99久久久久久久噜噜| 91国产美女在线观看| 久久成人这里只有精品| 日韩欧美在线字幕| 亚洲欧美日韩天堂| 日本一区二三区好的精华液| 亚洲香蕉av在线一区二区三区| 日韩精品黄色网| 欧美日韩视频在线| 欧美精品在线网站| 操人视频在线观看欧美| 91精品国产乱码久久久久久蜜臀| 精品国产一区二区三区久久久| 久久九九国产精品怡红院| 91最新国产视频| 黄色成人在线播放| 97久久久久久| 亚洲国产精品资源| 国产精品久久久久久久av大片| 色综合久久久888| 亚洲第一福利视频| 亚洲成人1234| 亚洲а∨天堂久久精品喷水| 成人免费高清完整版在线观看| 庆余年2免费日韩剧观看大牛| 色婷婷综合成人av| 亚洲丁香久久久| 78m国产成人精品视频| 亚洲第一精品夜夜躁人人爽| 欧美日韩国产一区二区三区| 国产精品视频xxx| 亚洲aaa激情| 日本精品免费一区二区三区| 国产欧美久久一区二区| 中文字幕久久久av一区| 亚洲91精品在线观看| 精品在线欧美视频| 日韩精品999| 久久久亚洲欧洲日产国码aⅴ| 午夜美女久久久久爽久久| 国产日韩中文字幕在线| 少妇精69xxtheporn| 亚洲天堂av在线免费观看| 8x海外华人永久免费日韩内陆视频| 国产精品日韩精品| 在线色欧美三级视频| 日韩中文字幕精品| 国产精品嫩草影院久久久| 理论片在线不卡免费观看| 久久影院中文字幕| 精品国产乱码久久久久久婷婷| 国产亚洲精品成人av久久ww| 欧日韩不卡在线视频| 国内精品久久久久久影视8| 亚洲天堂男人天堂| 激情亚洲一区二区三区四区| 欧美性xxxxxx| 亚洲品质视频自拍网| 久久综合网hezyo| 国产精品久久久久久久久久| 欧美老少配视频| 538国产精品视频一区二区| 96精品久久久久中文字幕| 亚洲国产一区二区三区在线观看| 午夜免费日韩视频| 最近2019中文字幕大全第二页| 久久精品久久久久电影| 美日韩丰满少妇在线观看| 国产精品美女久久久久久免费| 亚洲一区二区三区视频| 欧美视频第一页| 久久亚洲精品国产亚洲老地址| 精品久久中文字幕久久av| 亚洲2020天天堂在线观看| 狠狠做深爱婷婷久久综合一区| www.日韩.com| 久久久精品欧美| 亚洲一区第一页| 亚洲国产成人精品一区二区| 福利一区视频在线观看| 亚洲国产高清福利视频| 亚洲精品美女免费| 91精品国产乱码久久久久久久久| 欧美中文字幕第一页| 91丨九色丨国产在线| 97在线视频一区| 欧美性猛交99久久久久99按摩| 91精品久久久久久久| 国产成人小视频在线观看| 亚洲级视频在线观看免费1级| 国产欧美一区二区| 91亚洲精品久久久久久久久久久久| 久久久久久伊人| 国产成人精品av| 欧美激情免费看| 久久久久久亚洲精品中文字幕| 高清一区二区三区四区五区| 美女久久久久久久| 久久久精品一区| 国产精品国产福利国产秒拍| 日韩精品在线免费观看| www亚洲精品| 日韩网站免费观看高清| 欧美性高潮在线| 欧美黑人狂野猛交老妇| 国产欧美日韩精品在线观看| 国产精品日韩在线一区| 欧美国产第二页| 久久夜色撩人精品| 欧美成人精品一区| 欧美中文字幕在线观看| 97视频网站入口| 精品视频久久久| 97在线视频免费播放| 成人精品视频99在线观看免费| 日韩av观看网址| 米奇精品一区二区三区在线观看|