使用Sinon.js为Angular.js应用程序设置RESTful后端模拟

Nao*_*ton 5 javascript json xmlhttprequest sinon angularjs

我正在开发一个Angular.js应用程序,该应用程序具有扩展$ resource服务的RESTful服务.这个应用程序将来会连接到Java Spring应用程序,但是现在我正在尝试设置一个独立的模拟器,它将从客户端为我的应用程序提供所有必要的路由.我之前使用过Sinon.js创建了一个虚假的客户端服务器,当我使用其他MV*框架(如Backbone.js)开发其他应用程序时,它服务于我的路由.

看起来,与JQuery/Backbone执行的"标准"ajax调用获取JSON数据不同,Angular使用XHR的方式不同,并且不会被Sinon劫持请求和客户端响应的企图"欺骗".

我尝试使用$ httpBackend创建带有现成数据的虚假路由,但是看起来这个服务只是用于单元测试,而不是我需要设置的"暂存环境".

这就是我的Sinon设置的样子,它适用于JQuery.ajax,但不适用于Angular $ resource或$ http:

var server = sinon.fakeServer.create();
server.respondWith("GET", /mydata/gi, [200,
    { "Content-Type": "application/json" },
    JSON.stringify({
        data: "myData"
    })
]);
server.autoRespond = true;
Run Code Online (Sandbox Code Playgroud)

有关如何使用Angular的任何想法?或者更好的是,有没有人知道如何为Angular应用程序设置这样的模拟?

JD *_*ith 2

我相信“e2e”(端到端)$httpBackend 模拟正是您正在寻找的。

引用文档:“对于适合端到端测试或无后端开发的虚假 HTTP 后端实现,请参阅e2e $httpBackend mock。”

“与单元测试相反,在端到端测试场景中或在使用模拟替换真实后端 API 来开发应用程序的场景中,通常需要某些类别的请求绕过模拟并进行测试。发出真正的http请求(例如从网络服务器获取模板或静态文件)。”

我还发现了一篇很好的文章,描述了在 Angular 中使用假后端的一些优雅方法。