我正在使用Blanket.js来测试代码覆盖率(使用Jasmine,尽管我认为这并不重要)。我有一些脚本只能根据需要加载。这些是使用jQuery的$ .getScript()函数加载的。如何让Blanket.js报告动态加载脚本的覆盖范围?
我尝试通过添加一个带有src的脚本标记到头部的末尾来加载脚本(例如,$('<script/>', {src: (javascript path), 'data-cover': 'data-cover'}).appendTo('head');
)。
我没有看到在blanket.js源代码中添加脚本的任何明显功能。
答案 0 :(得分:1)
要回答我自己的问题,这是一个能够做我想要的功能:
function addCoveredScript(url) {
$('<script/>', {src: url}).appendTo('head');
blanket.utils.cache[url] = {};
blanket.utils.attachScript({url:url}, function (content) {
blanket.instrument({inputFile: content, inputFileName: url},
function (instrumented) {
blanket.utils.cache[url].loaded = true;
blanket.utils.blanketEval(instrumented);
blanket.requiringFile(url, true);
});
});
}
我不知道是否有更简单的方法可以做到这一点,但它确实有效。