記錄集成 coveralls 時(shí)遇到的一坑

這兩天想試一下coveralls,遂找了一個(gè)測試比較全的,使用mochaReact + ReduxTodo項(xiàng)目試驗(yàn)了一下,想著在這個(gè)基礎(chǔ)上做一做練習(xí),用用karma、Jest、AVA,結(jié)果剛開始就遇到了一個(gè)坑,折騰了好久才解決。

這個(gè)坑的大概是由于測試文件中使用了ES6語法,使用istanbul cover命令的時(shí)候就會(huì)報(bào)錯(cuò),在網(wǎng)上找了很多方法試驗(yàn),最終是成功的方法記錄如下

1、 安裝必要的包

yarn add cross-env babel-plugin-istanbul nyc --dev

2、 在package.json中添加如下內(nèi)容

{
  …
  "nyc": {
    "require": [
      "babel-register"
    ],
    "reporter": [
      "lcov",
      "text"
    ],
    "include": [
      # 測試文件路徑,如 "test/**/*.spec.js"
    ],
    "sourceMap": false,
    "instrument": false
  }
  …
}

或者新建一個(gè).nycrc文件放入

{
  "require": [
    "babel-register"
  ],
  "reporter": [
    "lcov",
    "text"
  ],
  "include": [
    # 測試文件路徑,如 "test/**/*.spec.js"
  ],
  "sourceMap": false,
  "instrument": false
}

3、 在.babelrcenv中添加

{
  …
  "env": {
    …
    "test": {
      "plugins": [
        [
          "istanbul", {
            "exclude": [
              # 測試文件路徑,如 "**/*.spec.js"
            ]
          }
        ]
      ]
    }
  }
}

4、 在package.jsonscripts中加入

"test:cov": "cross-env NODE_ENV=test nyc --reporter=text --reporter=lcov mocha test/**/*.spec.js"

5、 在終端執(zhí)行yarn test:cov,最終成功效果如下

6、 最后再添加上.travis.yml.coveralls.yml文件,再通過一些配置,就可以有

Coverage Status
Coverage Status
這種徽章了。這里就不再贅述了,可以看下面的參考資料

參考資料

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容