我正在尝试进行简单的集成测试,我从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,测试将通过。
答案 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
对象。这将允许在测试期间调整超时(即将它们设置得非常低以测试功能并仍然保持测试执行速度)