Mocha 运行 rendr 集合 ajax 单元测试

Mocha run rendr collection ajax unit test

我尝试使用 rendr(backbone in client&server) 创建一个 webapp 并尝试实现一些单元测试。

有没有办法 运行 在 mocha 中进行集合获取单元测试? 我想用 sinon-chai 在 mocha 中模拟 ajax 请求。但是当我尝试以这种方式存根 $ "ajax" 时发生错误,

var chai = require("chai");
var rekuire = require("rekuire");
var sinon = require("sinon");
var $ = require("jquery"); //because this is node-jquery, we don't have ajax function.
chai.use(require("sinon-chai"));

require("chai").should();
require("mocha-sinon");

var Books = rekuire("app/collections/books");

describe("Books interaction with REST API", function() {
    it("should load using the API", function(){
        //TypeError: Cannot stub non-existent own property ajax
        this.ajax_stub = this.sinon.stub($, "ajax").yieldsTo("success", [
            {
                count: 20,
                "books": [
                    {
                        title: "Google1",
                        author: ["author1", "author2"]
                    },
                    {
                        title: "Google2",
                        author: ["author3", "author4"]
                    }
                ]
            }
        ]);
        this.books = Books.fetch();
        this.books.should.have.length(2);
        this.ajax_stub.restore();
    });
}); 

我的问题是,当我们在 mocha 中 运行 进行单元测试时,有没有办法存根 $.ajax 函数?

为了渲染:

测试存在一些问题。模型/集合获取实际上使用 async.parallel,而不是 $.ajax.

此外,我不建议专门测试 .fetch,除非您要覆盖它。此功能已经在 Rendr 本身内部进行了测试,因此该测试不会给您带来太多实用性。如果您要覆盖,我建议只删除 collection.fetch 函数,并使用该 yield 而不是 $.