我有以下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时,会收到以下错误信息:

无法启动mocha:初始化超时

我可能在这里失踪?

我也试过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

解决方法

我得到的一样通过grunt-mocha-phantomjs npm包运行mocha-phantomjs时,无法启动摩卡错误.找到解决方案 here.

重复参考:

要运行mocha-phantomjs,更改

mocha.run();

if (mochaPhantomJS) {
  mochaPhantomJS.run();
}
else {
  mocha.run();
}

javascript – mocha init超时与mocha-phantomjs的更多相关文章

  1. 如何在iOS中为预期的assert / assertionFailure编写单元测试?

    这里的问题是,当someString参数为空字符串时,您可以保证函数不会失败–在您的实际应用程序中.这是因为断言不在发布版本中运行.结果是你可以在开发过程中使用assert作为调试的一种形式,但如果这种情况在现实生活中发生,你应该按顺序处理它,而不是崩溃.因此测试断言“发生”是否真的不是一种有效的单元测试技术,这就是为什么你以这种方式使用它的麻烦.

  2. ios – 核心数据并发调试:假阳性

    如WWDC2014session225(核心数据新增内容)所述,iOS8和OSX优胜美地的核心数据现在支持命令行参数-com.apple.CoreData.ConcurrencyDebug1,以启用检测到违反CoreData的并发合同的断言.在我的实验中,我发现它在iOS8beta1(在设备和模拟器中)都可以工作,但是我似乎发现了一个错误的肯定,即框架是抛出一个多线程违规异常不这样做至少这是我的信

  3. swift 断言(assert)

    和OC断言用法一样,只不过方法名去掉"NS"就可以了.断言可以让你程序在不满足断言条件时崩溃到断言处.当你的程序对参数有严格要求时,可以使用断言对参数进行检查.而且断言可以在release版本中配置去掉.

  4. Swift入门四——可选类型Optionals与断言Assert

    String和Int类型对应的可选类型分别是String?等可选类型的变量值均可以为nil。然而强制解封一个值为nil的可选类型会导致运行时错误。可选绑定Swift是一门简洁的语言,使用强制类型解封来获取可选类型变量里的值过于麻烦,是很多人不愿意使用的。所以在使用隐式可选类型变量时,为了安全起见,还是应该用if语句进行判断。附录查看完整专栏——《Swift轻松入门》

  5. 2.Swift 中的assert

    在Swift中,自带了一个断言的方法,其中的断言可选为带断言信息,有的可选为不带断言信息,下面让我们来看看.下面让我们来看看一个简单的小例子PS:assert分为两个参数,一个是condition,为bool值,为true不会断言,为false就会断言,后面的message是一个可选的错误信息,如果需要的话,就可以使用,不需要的也可以直接不写.再者,我们可以把判断条件放在condition里面去,

  6. Swift可选绑定、断言

    可选绑定可以用在if和while语句中来对可选类型的值进行判断并把值赋给一个常量或者变量。断言可选类型可以让你判断值是否存在,你可以在代码中优雅地处理值缺失的情况。此外,断言允许你附加一条调试信息。然而,在你的应用发布之前,有时候非法条件可能出现,这时使用断言可以快速发现问题。

  7. Swift中assert(断言)的使用

    在Swift中,通过assert实现断言,assert可以帮助开发者比较容易的发现和定位错误一个断言断定条件是true.通过声明一个断言来确保某个必要的条件是满足的,以便继续执行接下来的代码。代码注意点断言可以引发程序终止,并不是被设计用来避免不在发生无效情况的。

  8. Swift 断言 assert

    断言Optionals使得我们可以检测值是否存在。在这些情况下,可以使用触发断言来终止执行并提供调试。断言是在运行时检测条件是否为true,如果为true,就继续往下执行,否则就在这里中断。

  9. swift3 assert断言

    在Swift中,通过assert实现断言,assert可以帮助开发者比较容易的发现和定位错误。一个断言断定条件是true.通过声明一个断言来确保某个必要的条件是满足的,以便继续执行接下来的代码。例:如果断言被触发,将会强制结束程序,并打印相关信息:assertionFailed:number不大于3:file/Users/mac/Desktop/test/test/ViewController.swift,line17注意点:断言可以引发程序终止,并不是被设计用来避免不在发生无效情况的。

  10. 保护 Equatable 的实现

    如果忘记的话,Equatable的一致性就会被打破,这个bug多久会被发现取决于测试的质量——这里编译器无法提供任何帮助。我查看了一些标准库中的Swift类型以及Apple原生框架中的类,这些类型都遵守了Equatable协议,它们与dump的用法配合的很好。结论或许你可以使用linter、静态分析工具、像Sourcery这样的代码生成工具或者其他的什么方法来保护Equatable的实现,避免回顾代码。assertDumpsEqual的功能实现依托于标准库中的assert函数。

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部