1

我的 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 事件没有触发。

4

1 回答 1

1

这是一个骇人听闻的答案,但我似乎找不到更好的方法。

我认为窗口 onload 在正确连接之前触发(可能是由于前面的 JS 调用中链接脚本的数量)

为了解决这个问题 - 我改变了 JavaScript 如下......

<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();
            //}

        setTimeout(function() {
            jasmineEnv.execute();
        }, 3000);

    })();
  </script>

它不漂亮,但它有效 - 每次

于 2013-08-28T10:43:46.630 回答