如何从代码覆盖率数字中排除 browserify 生成的代码?
Posted
技术标签:
【中文标题】如何从代码覆盖率数字中排除 browserify 生成的代码?【英文标题】:How can I exclude browserify generated code from code coverage numbers? 【发布时间】:2016-10-15 15:07:37 【问题描述】:我使用 browserify 将我们所有的 Angular js 代码捆绑到一个文件中。我们使用 karma + jasmine 对这个文件 app.js 进行单元测试。作为 browserify 打包的一部分,它会在文件的开头注入一行代码:
(function e(t,n,r)function s(o,u)if(!n[o])if(!t[o])var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",fvar l=n[o]=exports:;t[o][0].call(l.exports,function(e)var n=t[o][1][e];return s(n?n:e),l,l.exports,e,t,n,r)return n[o].exportsvar i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s)(1:[function(require,module,exports)
我尝试在该行上方放置/*instanbul ignore next*/
,但会导致整个文件被忽略。这一行正在扼杀我的分支机构覆盖率。有没有办法忽略这个生成的代码?
【问题讨论】:
【参考方案1】:最好在打包过程之前为每个文件编写单元测试。如果您有许多文件,将难以模拟依赖项并跟踪它们。而且我们在伊斯坦布尔只有几种选择。而你想要做的是跳过函数定义标题。无法仅忽略该特定行。但是你可以通过将单元测试分成不同的文件来解决这个问题。这是首选且易于测试。
【讨论】:
以上是关于如何从代码覆盖率数字中排除 browserify 生成的代码?的主要内容,如果未能解决你的问题,请参考以下文章
Angular 1.x Browserify Jasmine 如何设置代码覆盖测试?