在访问路线后,Ember集成测试挂起

时间:2015-01-08 23:36:50

标签: ember.js ember-cli ember-testing

我正在尝试进行简单的集成测试,我从ember-cli网站上的集成示例开始。现在,当我在浏览器中测试(localhost:4200 / tests)时,以下情况会路由到我期望的位置,但它会挂起并且永远不会成功或失败。

import Ember from "ember";
import { test } from 'ember-qunit';
import startApp from '../helpers/start-app';
var App;

module('Integration - Create Event', {
    setup: function() {
        App = startApp();
    },
    teardown: function() {
        Ember.run(App, App.destroy);
    }
});

test('check customers', function() {
    visit('/new');
    andThen(function() {
        fillIn('input#title', 'The Event Name');
        ok(true);
       // equal(find('.customers input[type="checkbox"]').length, 6, 'Customer checkboxes showing');

    });
});

我在这里做错了吗?或者有不同的方法吗?

ember-cli 0.1.5和ember 1.9.1

编辑:

    ENV.APP.LOG_ACTIVE_GENERATION = true;
    ENV.APP.LOG_TRANSITIONS = true;
    ENV.APP.LOG_TRANSITIONS_INTERNAL = true;
    ENV.APP.LOG_VIEW_LOOKUPS = true;

启用日志记录显示转换已完成,但仍然无法解析或被拒绝。

编辑:

我想我已经把它缩小了。我有一个时钟服务,我注入所有控制器,但当我不注入它时,我的测试通过。我需要时钟服务提供的功能,我如何仍然使用它,但让我的集成测试工作?

// services/clock.js
import Ember from 'ember';

export default Ember.Object.extend({
    pulse: Ember.computed.oneWay('_seconds').readOnly(),
    minutePulse: Ember.computed.oneWay('_minutes').readOnly(),
    tick: function () {
        var clock = this;
        Ember.run.later(function () {
            var seconds = clock.get('_seconds');
            var minutes = clock.get('_minutes');
            if (typeof seconds === 'number') {
                clock.set('_seconds', seconds + 1);
                if(Math.floor((seconds + 1) / 60) > minutes) {
                    clock.set('_minutes', minutes + 1);
                }
            }
        }, 1000);
    }.observes('_seconds').on('init'),
    _seconds: 0,
    _minutes: 0
});

可以在https://github.com/RyanHirsch/ember-test-example找到示例项目。如果我删除run.later,测试将通过。

1 个答案:

答案 0 :(得分:1)

感谢freenode的#emberjs频道中的teddyz帮助我解决这个问题。问题是异步帮助器visit()等待Ember.run.later()完成,但是我有这个结构的方式,在它完成之前触发另一个run.later。所以访问基本上等待了。解决方案似乎是使用带有Ember.run的setTimeout。代码如下。

import Ember from 'ember';

export default Ember.Object.extend({
    pulse: Ember.computed.oneWay('_seconds').readOnly(),
    minutePulse: Ember.computed.oneWay('_minutes').readOnly(),
    tick: function () {
        var clock = this;
        setTimeout(Ember.run.bind(clock, function () {
            var seconds = this.get('_seconds');
            var minutes = this.get('_minutes');
            if (typeof seconds === 'number') {
                this.set('_seconds', seconds + 1);
                if(Math.floor((seconds + 1) / 60) > minutes) {
                    this.set('_minutes', minutes + 1);
                }
            }
        }), clock.get('globalSettings.timeout'));
    }.observes('_seconds').on('init'),
    _seconds: 0,
    _minutes: 0
});

我还在ember论坛(http://discuss.emberjs.com/t/proper-way-to-handler-timers-w-ember-testing/4693/8)上讨论了关于处理计时器和测试的正确方法的globalSettings对象。这将允许在测试期间调整超时(即将它们设置得非常低以测试功能并仍然保持测试执行速度)