国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

mocha、chai、sinon和istanbul實現100%單元測試覆蓋率

Yuanf / 3516人閱讀

摘要:加上測試覆蓋率檢查,就能夠提供足夠的信息,來斷言代碼的行為是否符合期望。測試的相關技術是程序的代碼覆蓋率工具,以土耳其最大城市伊斯坦布爾命名。

敏捷軟件開發中,最重要實踐的就是測試驅動開發,在單元測試層面,我們試著實現一個重要的指標就是測試覆蓋率。測試覆蓋率衡量我們的代碼是否已經全部被測試到了。

但是指標本身不是目的,借助測試覆蓋率檢查,我們希望發現那些未被測試覆蓋的代碼,從而去思考如何測試那些代碼的邏輯,進而更好的設計重構代碼,讓代碼有更高的質量[[1]](https://martinfowler.com/blik...。

談到測試,正好最近在看《數學之美》,書中談到的關于信息的一段話。我們要把代碼的行為從不確定性,變成確定性,也是一樣。從黑盒變成白盒,沒有什么神奇的力量,唯有提供足夠的信息,而測試中的斷言就是信息,測試覆蓋率也是信息,測試覆蓋率可以認為是一種間接的信息,可以消除一部分不確定性,而充分的斷言,則提供了更直接的信息。加上測試覆蓋率檢查,就能夠提供足夠的信息,來斷言代碼的行為是否符合期望。

測試的相關技術

IstanbulJavaScript程序的代碼覆蓋率工具,以土耳其最大城市伊斯坦布爾命名。Istanbul會對代碼進行轉換,生成語法樹,然后在相應位置注入統計代碼,執行之后根據注入的全局變量的值,統計代碼執行的次數;在對代碼的轉換完成之后,Istanbul會調用test runner,例如mocha,執行轉換之后的代碼的測試,生成測試報告。

Mocha是一種測試框架,也就是運行測試的工具,類似Jasmine、Karma和Ava。跟JUnit的注解一樣,mocha作為執行器,用descibeit方法,來定義test suit,為不同的測試分組。mocha本身并不提供assert斷言,所以要提供更加有表現力的斷言,可以搭配chai使用,當然也可以使用nodejs提供的assert模塊

在我們的代碼中,總會有一些復雜的邏輯或者依賴io、網絡的異步代碼,用直接的方法難以測試,這時可以通過sinon簡化復雜代碼的測試。Sinon通過創建Test Double也就是測試替身,將我們代碼中依賴的一些函數或者類,替換成測試替身,而我們可以對測試替身的行為進行設置,模擬我們的代碼需要的結果,從而讓難以測試的代碼邏輯被執行。

為nodejs項目配置測試環境 1 安裝相應的依賴包

mocha和istanbul可以全局安裝,也可以只在當前項目安裝。

npm install --save-dev mocha chai sinon istanbul

安裝完成之后,在package.json文件的scripts下,添加執行測試和測試覆蓋率檢查的命令

{
  ...
  "scripts":{
    "coverage": "istanbul cover _mocha -- -R spec --timeout 5000 --recursive",
    "coverage:check": "istanbul check-coverage",
  }
  ...
}

運行npm run coveragenpm run coverage:check,就可以生成測試報告,前者生成測試報告,后者則是檢查測試覆蓋率是否達到要求。

2 配置Istanbul

istanbul相關的執行參數,可以在命令行下執行時傳遞參數來制定,也可以在yaml格式的.istanbul.yml文件中配置。簡單貼出一些重要的配置項

instrumentation:
  root: .   # 執行的根目錄
  extensions:
    - .js   # 檢查覆蓋率的文件擴張名
  excludes: ["**/benchmark/**"]

  ... ...

reporting:
  print: summary
  reports: [lcov, text, html, text-summary] # 生成報告的格式
  dir: ./coverage   # 生成報告保存的目錄
  watermarks:       # 在不同覆蓋率下會顯示使用不同顏色
    statements: [80, 95]
    ... ...
check:
  global:
    statements: 100
    branches: 100
    lines: 100
    functions: 100

最后的check是項目要通過覆蓋率檢查需要達到的測試覆蓋率,測試覆蓋率包括四個維度,分別是語句覆蓋率、分支覆蓋率、行覆蓋率和函數覆蓋率。如果達不到設定的指標,在執行的時候會報錯,項目的測試就無法通過自動化的持續集成。

編寫測試代碼

敏捷軟件開發中的測試驅動開發,意在通過先寫測試,根據調用者的契約,設計如何實現代碼,從而寫出更加容易測試的代碼,提高代碼的質量。也是我們練習測試的應該考慮的方向。

1 一段簡單的mocha測試代碼

利用chai提供的expect斷言,我們可以用BDD的方式,寫出更加符合代碼預期行為的測試用例。

var chai = require("chai")

chai.should()
var expect = chai.expect
var assert = chai.assert

describe("basic test", function () {
  describe("simple", function () {
    it("data check", function () {
      var data = { name: "test" }

      assert.isNotNull(data, "data should not be null")
      expect(data).to.be.an("object")
      expect(data).to.have.all.keys(["name"])
      expect(data).to.deep.include({name: "test"});
    });
  });
});
2 用Sinon模擬文件讀寫
... 同上 ...
var sinon = require("sinon")
var fs = require("fs")

describe("sinon", function () {
  it("should mock readFile", function(done){
    sinon.stub(fs, "readFile").callsFake(function (path, callback) { callback(new Error("read error")) })

    fs.readFile("any file path", function(err,data){
      assert.isNotNull(err)
      done()
    })
    assert(fs.readFile.calledOnce)
  });
});

在mocha測試框架中,如果我們調用的是異步的代碼,那么需要顯示的調用it回調函數的done方法,告訴mocha異步調用什么時候結束。否則的話,測試會掛起,直到設置的超時時間結束。

Sinon將測試替身分為spy、stub和mock,其中:

Spy, 可以提供函數調用的信息,但不會改變函數的行為

Stub, 提供函數的調用信息,并且可以像示例代碼中一樣,讓被stubbed的函數返回任何我們需要的行為。

Mock, 通過組合spies和stubs,使替換一個完整對象更容易。

本文的討論篇幅有限,暫時不詳細介紹各種sinon的使用方法,以后再通過其他文章專門介紹。

持續集成

完成所有代碼之后,我們可以將代碼發布到github,然后使用持續集成工具travis檢查代碼,將生成的測試報告上傳到coverall上,這樣就可以在項目中顯示項目狀態和測試覆蓋率的badges。

具體使用方法,可以參看官方網站,使用coveralls需要在項目中安裝依賴包npm i -D coveralls。并且添加package.json執行腳本istanbul cover ./node_modules/mocha/bin/_mocha --report lcovonly -- -R spec && cat ./coverage/lcov.info | ./node_modules/coveralls/bin/coveralls.js

通常的nodejs項目.travis.yml配置如下:

language: node_js
node_js:
  - "7.6.0"
install:
  - npm install
script:
  - npm test
after_script:
  - npm run coverall

本文涉及到的相關技術可以參看最近的一個項目,該項目完整的使用了文中涉及到的技術。

https://github.com/liuwill/find-ip-location

文/liuwill(簡書作者)
原文鏈接:mocha、chai、sinon和istanbul實現100%單元測試覆蓋率
著作權歸作者所有,轉載請聯系作者獲得授權,并標注“簡書作者”。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/84130.html

相關文章

  • 前端單元測試 實現教程 mocha + mochawesome + istanbul + sinon

    摘要:為什么要寫單元測試減少提高代碼質量,保證你的代碼是可測試的放心重構當你每個方法都寫了單元測試的時候,你每一個改動都會影響相應的單元測試,這樣你不用費盡心思的考慮哪里會有影響,特別是復雜項目或非核心功能不易被測試到,從而導致的產生。 為什么要寫單元測試 減少bug 提高代碼質量,保證你的代碼是可測試的 放心重構 當你每個方法都寫了單元測試的時候,你每一個改動都會影響相應的單元測試,這...

    AaronYuan 評論0 收藏0
  • 如何使用 mocha sinon 集成單元測試--單元測試示例及分析(上)

    摘要:使用集成單元測試上項目地址安裝依賴測試框架可視化報表覆蓋率替換依賴斷言命令命令命令執行單元測試,并打開測試報告頁面和覆蓋率頁面執行生成單元測試覆蓋率并打開執行單個單元測試文 使用 mocha 集成單元測試(上) 項目地址:https://github.com/Jay-tian/j... 安裝依賴 yarn add jquery mocha mochawesome istanbu...

    Caicloud 評論0 收藏0
  • 【Node Hero】9. Node.js 單元測試

    摘要:基本上,測試金字塔描述你應該編寫單元測試集成測試和端到端測試。集成測試要比端到端測試多,單元測試甚至要更多一些。應用程序單元測試編寫單元測試,是為了看看給定的模塊單元是否工作。 本文轉載自:眾成翻譯譯者:網絡埋伏紀事鏈接:http://www.zcfy.cc/article/1754原文:https://blog.risingstack.com/node-hero-node-js-un...

    104828720 評論0 收藏0
  • 前端單元測試初探

    摘要:本文只討論單測的范疇,對集成測試有興趣的話,可以看下的集成測試代碼。前端單測現狀測試本質上就是假定一個輸入,然后判斷得到預期的輸出。 原文發于我的博客:https://github.com/hwen/blogS... 要不要寫單測? 關于這個 cnode 上就有個很有意思的討論 做個調查,你的 Node 應用有寫單測嗎? 看完這個應該會有結論?如果沒有,就回帖跟別人探討下~ 測試 測試...

    isLishude 評論0 收藏0
  • 前端組件的測試

    摘要:的配置文件是為了解析那些需要測試的源文件相關的文件,然后再給的單元測試用例去識別。其作用是僅僅渲染至虛擬節點,不會返回真實的節點,能極大提高測試性能。 為解放勞動力,發展生產力 測試有了這般變化: 鼠標點擊手動測試 -> 用腳本模擬,自動化測試 Vue中的組件測試 需要安裝的包 全局安裝:babel、mocha、karma 其他局部安裝的包在下面的【測試環境搭建】最下方配置文件中給出...

    haobowd 評論0 收藏0

發表評論

0條評論

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