成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

前端單元測試初探

isLishude / 1833人閱讀

摘要:本文只討論單測的范疇,對集成測試有興趣的話,可以看下的集成測試代碼。前端單測現(xiàn)狀測試本質(zhì)上就是假定一個輸入,然后判斷得到預期的輸出。

原文發(fā)于我的博客:https://github.com/hwen/blogS...

要不要寫單測?

關(guān)于這個 cnode 上就有個很有意思的討論

做個調(diào)查,你的 Node 應用有寫單測嗎?

看完這個應該會有結(jié)論?如果沒有,就回帖跟別人探討下~

測試

測試有分為

單元測試(單測)

集成測試

系統(tǒng)測試

主要區(qū)別是單測傾向于測試模塊內(nèi)部運行邏輯及功能,集成測試傾向于模塊間互相組合跟調(diào)用的測試。
系統(tǒng)測試(當然你要說,還有自動化測試)是對整個系統(tǒng)的測試,主要由測試人員而非開發(fā)人員負責。

本文只討論單測的范疇,對集成測試有興趣的話,可以看下 Vue 的集成測試代碼。

前端單測現(xiàn)狀

測試本質(zhì)上就是假定一個輸入,然后判斷得到預期的輸出。而前端與后端相比,夾雜著瀏覽器 DOM 操作,異步請求,
瀏覽器兼容性等方面的。要我來說,比后端寫單測要麻煩多了。。。

不過現(xiàn)在前端的單測已經(jīng)發(fā)展得比較完善了,已經(jīng)有一套比較完整的工具鏈,來完成各種需求。

單測工具鏈 框架

目前比較流行的測試框架有:

jasmine: 自帶斷言(assert),mock 功能

mocha:框架不帶斷言和mock功能,需要結(jié)合其他工具。mocha 是 tj 大神寫的(tj 就是那個寫了express、koa、n、co、ejs的人。。。)

用得比較多的就上面兩個,還有一些用得比較少的,比如 Qunit、intern

框架的實現(xiàn)原理其實就是檢測內(nèi)部運行的代碼是否有拋出異常。而斷言庫如果沒有得到預期的輸入時,就會拋出異常,給框架檢測到。

PS.想要學 mocha 和單測寫法,最好的資源就是 express 框架的測試代碼(狼叔推薦,親測很不錯)

斷言庫

chai:目前比較流行的斷言庫,支持 TDD(assert),BDD(expect、should)兩種風格

shouldjs:也是 tj 寫的,說實話我比較喜歡這個,但是有坑。。。后面會說到。。。

expectjs:基本是 shouldjs 的縮水版

assert:node 的核心模塊,node 環(huán)境可以直接使用

mock 庫

sinon.js:只用過這個,其他不大清楚。不過這個是目前最多人用的,基本夠了。支持 spies, stub, fake XMLHttpRequest, Fake server, Fake time,很強大

測試集成工具

karma:Google Angular 團隊寫的,功能很強大,有很多插件

buster.js: 這個支持 node 環(huán)境,但目前還在 beta 版(2017/11/4,版本0.7)。官網(wǎng)

半小時上手單測

(并不是學會,就是這么耿直 _(:з)∠)_,手是誰???)

使用的是:karma + mocha + chai + sinon(如果之前沒了解過這幾個,可以邊寫邊看文檔,這樣學會快很多)

完整的例子可以在這里找到:GitHub 項目
建議把項目 clone 下來自己跑一遍,然后可以自己加一些特效(啊,不對,是代碼才對。。。

測試 DOM

詳細代碼,及配置見 源碼

it("test dom", () => {
  const div = document.getElementById("test")

  const content = div.innerHTML
  content.should.be.equal("here")

  setDivContent()
  const after = div.innerHTML
  after.should.be.equal("hallo world")
})
測試異步請求
it("test async", done => {
  getTopics()
    .then(res => {
      res.success.should.be.equal(true)
      done()
    })
    .catch(err => {
      info(err)
      done(err)
    })

})
調(diào)試技巧 調(diào)試技巧之一:善用 only

當你的單元測試越寫越多時,想測試新寫的單測是否正確時,可以用 mocha 的 only
這樣做的好處有二:第一屏蔽其他測試可以使測試速度變得更快,第二屏蔽其他測試,可以在你新寫的測試錯誤時
確定這個錯誤不是被其他測試所影響導致的。

用法

describe.only("something", function() {
  // 只會跑包在里面的測試
})

或者

it.only("do do", () => {
  // 只會跑這一個測試
})
調(diào)試技巧之二:善用 debug

要開啟 debug 的話,先在 karma.conf.jssingleRun 改成 false
然后,看圖(懶得打字了 (:з)∠)

覆蓋率

生成覆蓋率報告也是相當簡單,不過有個要注意的地方就是
現(xiàn)在前端代碼很多都是經(jīng)過 webpack,babel 編譯的,生成的代碼會多了很多二外的代碼

要解決這個問題使用babel-plugin-istanbul來替代karma-coverage就可以了

    preprocessors: {
      "src/**/*.js": ["webpack", "coverage"],
      "test/*.test.js": ["webpack"]
    }

將 karma-coverage 去掉,變成

    preprocessors: {
      "src/**/*.js": ["webpack"],
      "test/*.test.js": ["webpack"]
    }

然后在 webpack 配置添加 istanbul 插件

  use: {
    loader: "babel-loader",
    options: {
      plugins: ["istanbul"]
    }
  }

最后可以生成覆蓋率報告


另外有很多工具可以對生成的覆蓋率報告進行進一步的分析,比如最常見的
你會在 Github 上經(jīng)常見到的圖標

這個就是利用報告里的lcovonly分析生成的

coverageReporter: {
  dir: "test/coverage/",
  reporters: [
    { type: "html", subdir: "report-html" },
    { type: "lcovonly", subdir: ".", file: "report-lcovonly.txt" },  // 這里,你可以重命名 file
    { type: "text-summary", subdir: ".", file: "text-summary.txt" }
  ]
}
一些坑

測試時如果有涉及瀏覽器事件(addEventListener),記得測試完移除掉,不然會對其他的測試造成影響(afterEach -> removeEventListener)

mocha 里使用箭頭函數(shù)需要注意,因為箭頭函數(shù)的 this 指向是靜態(tài)的,所以 this 并不指向 mocha(沒有 mocha 上下文)

上面有說到,如果測試的是經(jīng)過編譯的代碼,需要進行一些配置,目前的辦法是用babel-plugin-istanbul代替karma-cover來檢測覆蓋率

補充

前面有說到,為什么不用 should.js??
因為如果你用 ES6 的語法寫單測(webpack 編譯),用 import should-sinon 會報錯。。
(是不是因為 tj 大神寫完東西不喜歡維護的習慣導致should.js支持性不好???)

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/89692.html

相關(guān)文章

  • FE.TEST-前端測試初探

    摘要:使用可以快速生成一個項目,其中包含了和以及覆蓋率統(tǒng)計的配置參考一個創(chuàng)建測試腳本的快速方法其他參考資料前端自動化測試概覽測試之使用對項目進行單元測試 showImg(https://segmentfault.com/img/bVbjfXr?w=600&h=317); 前言 測試可以提供快速反饋,根據(jù)測試用例覆蓋代碼,從而提升代碼開發(fā)效率和質(zhì)量。根據(jù)投入產(chǎn)出價值,通常迭代較快的業(yè)務(wù)邏輯不做...

    Travis 評論0 收藏0
  • FE.TEST-前端測試初探

    摘要:使用可以快速生成一個項目,其中包含了和以及覆蓋率統(tǒng)計的配置參考一個創(chuàng)建測試腳本的快速方法其他參考資料前端自動化測試概覽測試之使用對項目進行單元測試 showImg(https://segmentfault.com/img/bVbjfXr?w=600&h=317); 前言 測試可以提供快速反饋,根據(jù)測試用例覆蓋代碼,從而提升代碼開發(fā)效率和質(zhì)量。根據(jù)投入產(chǎn)出價值,通常迭代較快的業(yè)務(wù)邏輯不做...

    張率功 評論0 收藏0
  • 小程序測試方案初探

    摘要:前言年月號微信小程序正式上線,小程序不需要安裝就能使用,依托微信強大的生態(tài)環(huán)境,能做到很多所不能做的事情。當然更希望的是小程序官方能給出相應的單元測試方案吧。 前言 2017年1月9號微信小程序正式上線,小程序不需要安裝就能使用,依托微信強大的生態(tài)環(huán)境,能做到很多H5所不能做的事情。從微信小程序發(fā)布這段時間,陸陸續(xù)續(xù)開發(fā)了不少小程序相關(guān)的項目,總結(jié)了一些通用性的組件,但是對于小程序如何...

    church 評論0 收藏0
  • Mocha測試初探

    摘要:是測試用例,表示一個單獨的測試,是測試的最小單位。第一個參數(shù)是測試用例的名稱加應該等于,第二個參數(shù)是一個實際執(zhí)行的函數(shù)。這里對異步代碼進行測試時需要注意一點,默認一個單元測試最多執(zhí)行超時會報錯。 Mocha簡介: 一個具有豐富特性的javascript 測試框架,支持多種斷言庫,異步代碼測試等,不僅可運行在node.js 環(huán)境中還可以運行在瀏覽器中。 一、安裝 // 全局安裝 npm ...

    Binguner 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<