测试Ember数据 - 在测试运行期间切换到FixtureAdapter

时间:2013-03-20 23:11:25

标签: unit-testing ember.js

我有an ember.js app而我正在设置DS.Store这样的view actual code}:

(function (app) {
    'use strict';

    ...

    var store = DS.Store.extend({
        revision: 12
    });

    app.Store = store;

})(window.Balanced);

现在我有一个qunit测试,在那个测试中,我想将一个默认的RESTAdapter交换为FixtureAdapter,这样我就可以为我的模型设置灯具。我想我需要写something like this,但我不是百分百肯定的:

(function () {
    'use strict';

    var fixtureAdapter;

    module('tests.store.module', {
            setup: function () {
                fixtureAdapter = DS.FixtureAdapter.extend({

                });
                Balanced.Store.reopen({
                    adapter: fixtureAdapter
                });

                //  TODO: how does this work?
                Balanced.Marketplace.FIXTURES = [
                    {id: 1, name: '1'},
                    {id: 2, name: 'poop'},
                    {id: 3, name: 'poop'}
                ];
            },
            teardown: function () {
                // teardown code
            }
        }
    );

    test("Marketplace query", function () {
        var marketplaces = Balanced.Marketplace.find();
        //  TODO: how do I test this?
    });
})();

1 个答案:

答案 0 :(得分:2)

对于我使用jasmine的基本单元测试,我手动设置商店(使用本地存储适配器以避免xhr请求)

describe ("CodeCamp.SessionView Tests", function(){

  var get = Ember.get, set = Ember.set, sut, controller, session, store;

  beforeEach(function(){
    store = DS.Store.create({
      revision: 11,
      adapter: DS.LSAdapter.create()
    });
    sut = CodeCamp.SessionView.create();
    controller = CodeCamp.SessionController.create();
    controller.set("store", store);
    sut.set("controller", controller);
    session = CodeCamp.Session.createRecord({ id: 1, name: "First", room: "A", ratings: [], speakers: [], tags: []});
  });

  afterEach(function() {
    Ember.run(function() {
      store.destroy();
      controller.destroy();
      sut.destroy();
      session.destroy();
    });
    store = null;
    controller = null;
    sut = null;
    session = null;
  });

  it ("will create rating when form is valid", function(){
    sut.set('score', '1234');
    sut.set('feedback', 'abcd');
    sut.addRating(session);
    var ratings = CodeCamp.Session.find(1).get('ratings');
    var rating = ratings.objectAt(0);
    expect(rating.get('score')).toEqual('1234');
    expect(rating.get('feedback')).toEqual('abcd');
    expect(rating.get('session').get('id')).toEqual(1);
  });

});

上面的测试是针对以下ember视图进行端到端的

CodeCamp.SessionView = Ember.View.extend({
  templateName: 'session',
  addRating: function(event) {
    if (this.formIsValid()) {
      var rating = this.buildRatingFromInputs(event);
      this.get('controller').addRating(rating);
      this.resetForm();
    }
  },
  buildRatingFromInputs: function(session) {
    var score = this.get('score');
    var feedback = this.get('feedback');
    return CodeCamp.Rating.createRecord(
    { score: score,
      feedback: feedback,
      session: session
    });
  },
  formIsValid: function() {
    var score = this.get('score');
    var feedback = this.get('feedback');
    if (score === undefined || feedback === undefined || score.trim() === "" || feedback.trim() === "") {
      return false;
    }
    return true;
  },
  resetForm: function() {
    this.set('score', '');
    this.set('feedback', '');
  }
});

如果你想看到整个应用程序在运行(只是一个带有一些基本茉莉花测试的示例ember应用程序),它就在github上

https://github.com/toranb/ember-code-camp/