2

我正在使用 ember-cli 开发一个 ember 应用程序和 ember-data,并使用对 rails 后端的 restful API 调用。

也使用 qunit 进行测试。(https://github.com/appendto/jquery-mockjax用于模拟 AJAX 请求)

这是在模拟 AJAX 请求时面临的问题

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

module('Integration Test', {
  setup: function() {
    App = startApp();
    Ember.$.mockjax({
      url: '/api/v1/offers/1',
      type: 'GET',
      responseText: {
        offers: [{
          id: 1,
          state: 'draft'
        }]
      }
    });
  },

  teardown: function() {
    Ember.run(App, App.destroy);
  }
});

test('small test', function () {
  console.log("in")
  $.get('/api/v1/offers/1')
  console.log($.mockjax.mockedAjaxCalls().length);
  console.log("start")

  visit('/offers/1').then(function(){
    equal($('p.item_count').text(), "Offer Items(0)");
  });
  console.log($.mockjax.mockedAjaxCalls().length);
});

在控制台上它产生的输出为

in
MOCK GET: /api/v1/offers 
Object {url: "/api/v1/offers", type: "get", isLocal: false, global: true, processData: true…}
start
1 
1 

这里 API 是使用 restful 适配器调用的,而不是使用模拟的 AJAX 调用。

我该如何解决这个问题?

4

1 回答 1

0

使用 mockjax 拨打电话时。我们需要确保以下几点:

  • Adaptera/application.js 应该有

    if(window.app.environment === "test") {
      Adapter = DS.RESTAdapter.extend({ namespace: "ifany" });
    }
    
  • 使用 Ember-Cli是一个不错的选择,它也ember-data-factory-guy支持mockAjax

  • 使用 FactoryGuy,FactoryGuy.buildList("user", 9)您可以轻松获得 json 响应,并且 api 调用也可以正常工作

    $.mockjax({
      url: '/api/v1/offers/1',
      type: 'GET',
      responseText: {
      offers: Factory.buildList("offer",9)
      }
    });
    
  • 还要确保在测试模式下运行应用程序

    ember server -environment=test
    
于 2014-08-15T09:18:55.417 回答