zsh*_*hnr 2 unit-testing qunit ember.js ember-cli ember-qunit
来自我的controllers/cart.js的代码:
export default Ember.Controller.extend({
cartTotal: Ember.computed('model.@each.subTotal', function() {
return this.model.reduce(function(subTotal, product) {
var total = subTotal + product.get('subTotal');
return total;
}, 0);
})
)};
Run Code Online (Sandbox Code Playgroud)
此计算属性循环遍历模型中的所有元素,添加subTotal属性的所有值,返回a cart total.
购物车,test.js
import { moduleFor, test } from 'ember-qunit';
import Ember from 'ember';
moduleFor('controller:cart', {
// Specify the other units that are required for this test.
// needs: ['controller:foo']
});
test('it exists', function(assert) {
var controller = this.subject();
assert.ok(controller);
});
test('cartTotal function exists', function(assert) {
var controller = this.subject();
assert.equal(controller.get('cartTotal'), 30, 'The cart total function exists');
});
Run Code Online (Sandbox Code Playgroud)
测试失败,TypeError: Cannot read property 'reduce' of null因为它显然没有模型可以循环.
如何模拟cartTotal计算属性的依赖关系以使测试通过?
谢谢!
沿着这些方向可能有什么?
import { moduleFor, test } from 'ember-qunit';
import Ember from 'ember';
var products = [
Ember.Object.create({ name: 'shoe', subTotal: 10 }),
Ember.Object.create({ name: 'shirt', subTotal: 20 })];
var model = Ember.ArrayProxy.create({
content: Ember.A(products)
});
moduleFor('controller:cart', {
beforeEach() {
this.controller = this.subject();
}
});
test('cartTotal', function(assert) {
this.controller.set('model', model);
assert.equal(this.controller.get('cartTotal'), 30, 'The cart total function exists');
});
Run Code Online (Sandbox Code Playgroud)