如何在Ember中测试路线的willTransition动作?

Mol*_*far 5 qunit ember.js ember-testing

如何在Ember中测试此代码?一般来说,请向我解释一下这个概念。

// app/routes/products/new.js
import Ember from 'ember';

export default Ember.Route.extend({
  model() {
    return this.store.createRecord('product');
  },
  actions: {
    willTransition() {
      this._super(...arguments);
      this.get('controller.model').rollbackAttributes();
    }
  }
});
Run Code Online (Sandbox Code Playgroud)

我不知道该怎么做。可能是存根模型吗?我发现商店在路线测试中不可用。

在Ruby和RSpec之后,所有这些新的JavaScript世界都使您感到困惑。)但是我还是想学习它。

jet*_*ony 4

在单元测试中,想法是存根所有外部依赖项。在 ember 中你可以这样做:

// tests/unit/products/new/route-test.js
test('it should rollback changes on transition', function(assert) {
  assert.expect(1);
  let route = this.subject({
    controller: Ember.Object.create({
      model: Ember.Object.create({
        rollbackAttributes() {
          assert.ok(true, 'should call rollbackAttributes on a model');
        }
      })
    })
  });
  route.actions.willTransition.call(route);
});
Run Code Online (Sandbox Code Playgroud)

基本上,您将存根控制器和模型传递给this.subject(),然后调用您正在测试的任何函数(在这种情况下,您必须使用 call 或 apply 来调用具有正确范围的操作),然后断言所调用的操作rollbackAttributes()

assert.expect(1);在测试开始时告诉 QUnit 等待 1 个断言。