5

我正在将大量 QUnit 测试转换为 Jasmine。在 QUnit 中,我习惯于查看所有测试模块的测试总数,显示在顶部。例如:

测试在 157 毫秒内完成。

528 次测试中的 528 次通过,0 次失败。

我认为测试的数量是重要的信息。但是,Jasmine 的示例测试运行程序不显示测试总数。相反,你会得到类似的东西:

通过 106 个规格

这些规范中的每一个都可能包含任意数量的单独测试。是否可以确定已运行的测试总数,以便我可以在我的测试运行器中显示它?我在网上和 Jasmine 文档中查找了信息,但到目前为止还没有找到任何信息。


解决方案

根据@ggozad 的回复,我提出了以下解决方案,该解决方案会打印到控制台。欢迎提出有关如何改进它或如何将结果干净地添加到 Jasmine 的 HTML 输出的建议。

var jasmineEnv = jasmine.getEnv();
var htmlReporter = new jasmine.HtmlReporter();
var reportRunnerResults = htmlReporter.reportRunnerResults;

htmlReporter.reportRunnerResults = function(runner) {
    reportRunnerResults(runner);

    var specs = runner.specs();
    var specResults;
    var assertionCount = {total: 0, passed: 0, failed: 0};

    for (var i = 0; i < specs.length; ++i) {
        if (this.specFilter(specs[i])) {
            specResults = specs[i].results();
            assertionCount.total += specResults.totalCount;
            assertionCount.passed += specResults.passedCount;
            assertionCount.failed += specResults.failedCount;
        }
    }

    if (console && console.log) {
        console.log('Total: ' + assertionCount.total);
        console.log('Passed: ' + assertionCount.passed);
        console.log('Failed: ' + assertionCount.failed);
    }
};

jasmineEnv.addReporter(htmlReporter);
jasmineEnv.specFilter = function(spec) {
    return htmlReporter.specFilter(spec);
};

window.onload = function() {
    jasmineEnv.execute();
};

控制台输出示例:

Total: 67
Passed: 67
Failed: 0 
4

2 回答 2

4

规范是Jasmine 中的测试。在其中,您可以有类似于 其他测试框架中的断言的期望。因此,您看到报告的规格数量是每个调用的总数:it

it('passes some expectations', function () {
  ...
});

通常,您会将几个类似单元的测试组合在一个it.

现在,如果您坚持想了解规范中失败/成功的期望,您总是可以从您的记者那里获得这些信息。例如,如果您设置一个 实例htmlReporter,您可以这样做:

htmlReporter.reportRunnerResults = function (runner) {
...
};

在你的函数中,你可以检查各种各样的东西,这里有一些提示:

  • runner.specs()为您提供所有规格
  • 对于其中的每一个specresults = spec.results()都会为您提供有关您的期望的信息。
  • results.totalCount, results.failedCount,results.passedCount是你正在寻找的;)
于 2012-07-17T18:38:21.913 回答
0

非常有用的信息。您可能希望将其附加到页面而不是将其写入控制台。您可以将控制台脚本替换为...

var d1 = document.createElement("span");
$(d1).css('font-size', '10pt');
$(d1).html(' (Total Expectations: ' + assertionCount.total);
$(d1).append(', Total Expectations Passed: ' + assertionCount.passed);
$(d1).append(', Total Expectations Failed: ' + assertionCount.failed);
$(d1).append(')');
$(".passingAlert").append(d1);
$(".resultsMenu").append(d1);
于 2013-09-16T17:07:47.817 回答