3

我第一次尝试学习摩卡测试。我写了一个简单的测试脚本,如:

describe('Analytics Test Suite', function(){
//http://emberjs.com/guides/testing/integration/
before(function() {
    AS.rootElement = '#ember-application-container';
    AS.setupForTesting();
    AS.injectTestHelpers();
    AS.reset();
});

describe('visit analytics index page', function(){
    visit("/analytics").then(function() {
        it('should return -1 when the value is not present', function(){
            expect([1,2,3].indexOf(4)).to.be(-1);
            expect([1,2,3].indexOf(0)).to.be(-1);
        })
    });
})
});

但我得到这个 js 错误:

ReferenceError:访问未定义

但是,如果我将代码修改为:

describe('Analytics Test Suite', function(){

AS.rootElement = '#ember-application-container';
AS.setupForTesting();
AS.injectTestHelpers();
AS.reset();


describe('visit analytics index page', function(){
    visit("/analytics").then(function() {
        it('should return -1 when the value is not present', function(){
            expect([1,2,3].indexOf(4)).to.be(-1);
            expect([1,2,3].indexOf(0)).to.be(-1);
        })
    });
})
});

我收到这些错误: TypeError: app._ container _.lookup(...) is undefined

在第一个场景中,访问函数似乎丢失了,当将初始化代码放在之前的之外时,该函数得到了解决。但后来我得到类型错误,我认为它应该寻找 AS._ container _lookup,但它正在寻找应用程序命名空间。我正在使用 ember 调试版本http://builds.emberjs.com/tags/v1.0.0/ember.js

您的帮助将不胜感激。我还添加了 jsbin http://jsbin.com/ILUbuy/2/

谢谢,迪

更新 我解决了添加此适配器的问题:https ://github.com/teddyzeenny/ember-mocha-adapter

4

1 回答 1

1

我将尝试使用 jsbin 来跟进这篇文章,以提供一个工作示例。当我第一次开始在 Firefox 中测试 ember 应用程序时,我注意到我总是会收到这个错误:

"before each" hook ‣
     router is undefined

但这不会在 chrome 中发生。我的领导刚刚发现我做错了什么或者我错过了什么。基本上 mocha 在执行 mocah.run() 时没有找到应该运行应用程序的 div,所以一个简单的解决方案是:

$(document).ready(function(){
    mocha.run();
});

我得到的另一个错误是:

router.getHandler is not a function

原来这是因为我没有添加 App.reset(); 在我之前的每个钩子里。

在这种情况下,我必须测试一个 div 是否在点击时切换(使用 jquery UI,.tollge('slow'))。问题是测试会成功运行,但随后的测试总是会失败,我永远无法理解为什么会这样。我知道这是由于 jquery UI 的东西,因为如果我直接设置 div 的可见性而不使用花哨的效果,测试就会运行,所以如果你在内部使用 setTimeouts 的地方发生类似的事情,测试它做这样的事情:

 it("some test", function () {
    var context = this;            

    click(toggleButton).then(function () {
        Ember.run.later(context, function () {

        }, 1000);
        wait().then(function () {
            expect(DIV TO BE HIDDEN OR VISIBLE);
        });
    });
});

这个链接也很有帮助:http: //instructure.github.io/blog/2014/01/24/ember-run-loop-and-tdd/

好的,这是一个工作示例: http: //jsbin.com/opuJetOy/1/ 上面的链接在 chrome 中不起作用,似乎 chrome 不喜欢这样的链接:' https://raw.github.com/。 ...',但它适用于 Firefox。

于 2014-02-03T16:02:29.133 回答