Blanket.js覆盖动态加载的脚本文件

时间:2014-11-05 14:42:03

标签: javascript blanket.js

我正在使用Blanket.js来测试代码覆盖率(使用Jasmine,尽管我认为这并不重要)。我有一些脚本只能根据需要加载。这些是使用jQuery的$ .getScript()函数加载的。如何让Blanket.js报告动态加载脚本的覆盖范围?

我尝试通过添加一个带有src的脚本标记到头部的末尾来加载脚本(例如,$('<script/>', {src: (javascript path), 'data-cover': 'data-cover'}).appendTo('head');)。

我没有看到在blanket.js源代码中添加脚本的任何明显功能。

1 个答案:

答案 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);
        });
   });
}

我不知道是否有更简单的方法可以做到这一点,但它确实有效。

相关问题