我的 Jasmine 测试套件中现在只有 400 多个测试,但我似乎有一个小问题。specrunner 似乎只运行了五分之一,而且它的成功似乎很随机。当它“需要”时,一切都会正常工作。如果它没有“占用”,那么页面就坐在那里没有错误或任何东西,它只是旋转了一段时间然后呈现一个空屏幕。
我在 Firefox 和 Chrome 中都看到了相同的行为。
有没有其他人遇到过类似的问题,并且可能表明问题可能是什么。
这个问题似乎越来越严重,所以我想知道它是否与页面大小有关。我的 SpecRunner 页面是一个 RAZOR 脚本,看起来像这样......
@using SiansPlan.Authentication
@using SiansPlan.Spa
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Jasmine Spec Runner for SiansPlan SPA</title>
<link rel="stylesheet" type="text/css" href="Content/jasmine.css">
<script type="text/javascript" src="scripts/lib/jasmine.js"></script>
<script type="text/javascript" src="scripts/lib/jasmine-html.js"></script>
<script type="text/javascript" src="scripts/lib/jasmine-jquery.js"></script>
<script src="~/scripts/lib/handlebars.js"></script>
<script data-main="scripts/test/main.js" src="scripts/lib/require.js"></script>
<script type="text/javascript">
require(["../lib/domReady"
@foreach (var file in Html.PathContentFromRoot("scripts/test/spec", Server))
{
<text>,"spec/@file"</text>
}
], function () {
var jasmineEnv = jasmine.getEnv();
jasmineEnv.updateInterval = 1000;
var htmlReporter = new jasmine.HtmlReporter();
jasmineEnv.addReporter(htmlReporter);
jasmineEnv.specFilter = function (spec) {
return htmlReporter.specFilter(spec);
};
var currentWindowOnload = window.onload;
window.onload = function () {
if (currentWindowOnload) {
currentWindowOnload();
}
execJasmine();
};
function execJasmine() {
jasmineEnv.execute();
}
})();
</script>
</head>
<body>
<div style="display:none;">
@* Key platform variables. *@
<span id="requestSource">website</span>
<span id="apiKey">@ApiKeyManager.Instance.GetKey("website")</span>
</div>
</body>
</html>
如果还有什么我可以提供的可能有帮助的,请告诉我。
更新:这已经完全停止了 - 我已经追踪到 window.onload 事件没有触发。