11

私は次のものを持っていますtestrunner.html

<html>
  <head>
    <title>Specs</title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <link rel="stylesheet" href="/content/css/mocha.css" />
    <script>
        function assert(expr, msg) {
            if (!expr) throw new Error(msg || 'failed');
        }
    </script>

    <script src="/client/lib/require.js" type="text/javascript" data-main="/client/specs/_runner.js"></script>

  </head>
  <body>
    <div id="mocha"></div>
  </body>
</html>

この_runner.jsように見えます:

// Configure RequireJS
require.config({
    baseUrl: '/client',
    urlArgs: "v=" + (new Date()).getTime()
});

// Require libraries
require(['require', 'lib/chai', 'lib/mocha'], function (require, chai) {

    // Chai
    assert = chai.assert;
    should = chai.should();
    expect = chai.expect;

    // Mocha
    mocha.setup('bdd');


    // Require base tests before starting
    require(['specs/stringcalculator.specs'], function (person) {
        mocha.setup({ globals: ['hasCert'] });
        // Start runner
        if (window.mochaPhantomJS) {
            mochaPhantomJS.run();
        }
        else { mocha.run(); }
    });

});

これStringCalculator.specs.jsはこれです:

define(['app/model/StringCalculator'], function () {

    describe("StringCalculator", function () {

        describe("when an empty string is passed in", function () {
            it("returns 0", function () {
                var result = StringCalculator.add("");
                assert(result === 0);
            });
        });

        describe("when a number is passed in", function () {
            it("returns the number", function () {
                var result = StringCalculator.add("2");
                assert(result === 2);
            });
        });

        describe("when string is passed in", function () {
            it("returns NaN", function () {
                var result = StringCalculator.add("a");
                assert(isNaN(result));
            });
        });

        describe("when '1,2' is passed in", function () {
            it("returns 3", function () {
                var result = StringCalculator.add("1,2");
                assert(result === 3);
            });
        });
    });
});

そしてこれはStringCalculator.jsそれ自体です(モカサンプルから):

define([], function() {
    window.StringCalculator = StringCalculator = {
        add: function(inputString) {
            if (inputString === '') {
                return 0;
            }

            var result = 0;
            var inputStrings = inputString.split(',');

            for (var i = 0; i < inputStrings.length; i++) {
                result += parseInt(inputStrings[i]);
            }

            return result;
        }
    }
});

を呼び出すブラウザで仕様を実行するとtestrunner.html、すべてが期待どおりに機能します。OS Xで実行mocha-phantomjs client/specs/testrunner.htmlすると、次のエラーが発生します。

Failed to start mocha: Init timeout

ここで何が欠けているのでしょうか?

mocha-phantomjs http://httpjs.herokuapp.com同じエラーで失敗するものも試しました。

更新:電話mocha-phantomjs http://localhost:81/client/specs/testrunner.htmlをかけていると、コンソールに次のエラーも表示されます。

RangeError: Maximum call stack size exceeded.

http://localhost:81/client/lib/chai.js?v=123423553533535:2601
Failed to start mocha: Init timeout
4

3 に答える 3

9

npmパッケージを実行しているときに同じFailed to start mochaエラーが発生していました。ここで解決策を見つけました。mocha-phantomjsgrunt-mocha-phantomjs

参考のためにここで繰り返します:

mocha-phantomjsで実行するには、次のように変更します

mocha.run();

if (mochaPhantomJS) {
  mochaPhantomJS.run();
}
else {
  mocha.run();
}
于 2013-08-06T21:12:32.407 に答える
1

このファイルはそれを使用する方法を示しています。

そして私にとって、NodeJS0.10.xはそれで動作しないようです。NodeJS 0.8.8に切り替えた後、すべてが期待どおりに機能します。

mocha-phantomjsとPhantomJSの現在のバージョンを使用すると、すべてが正常に機能するようになりました。

于 2013-04-06T09:20:57.327 に答える
0

この情報をありがとう、私は上記を試しましたが、「mochaPhantomJSは未定義です」と言ってブラウザで失敗しました。以下のように簡単に調整すると、うまく機能します。

if(typeof(mochaPhantomJS)!=="undefined")
{
  mochaPhantomJS.run();
}
else
{
  mocha.run();
}
于 2015-05-11T20:39:23.890 に答える