- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我将 QUnit 与 sinon 一起使用。我怎样才能制作 sinon 的 fakeserver响应由相同方法调用的链式 ajax?
module('demo', {
beforeEach: function(){
this.server = sinon.fakeServer.create();
},
afterEach: function(){
this.server.restore();
}
});
test('chained ajax calls', function(assert){
this.server.respondWith('GET', '/foo', [200,
{ 'Content-Type': 'application/json' }, '{ "foo": 1 }' ]);
this.server.respondWith('GET', '/bar', [200,
{ 'Content-Type': 'application/json' }, '{ "bar": 1 }' ]);
var successCount = 0;
$.get('/foo', function(data){
successCount++;
$.get('/bar', function(){
console.log('bar success');
successCount++;
});
});
this.server.respond();
assert.strictEqual(successCount, 2);
});
我上面的问题是我只从其中一种方法得到响应。假服务器能处理这个吗?
更新: 似乎添加另一个 server.respond()
可以解决问题。但一定有更好的方法,对吧?
根据文档,无论 ajax 调用次数如何,听起来都应该对作业进行一次调用:
server.respond(); Causes all queued asynchronous requests to receive a response.
fiddle :http://jsfiddle.net/3qj20r5m/1/
最佳答案
嗯,我认为 server.repond()
也应该这样做。无论如何,我通常将我的假服务器设置为自动响应。除非您需要在响应之前检查请求,否则这似乎更容易:
var server;
QUnit.module('fake server tests', {
beforeEach: function() {
server = sinon.fakeServer.create();
// *** it's this option I'm referring to...
server.autoRespond = true;
server.respondWith('GET', '/foo', [200, {
'Content-Type': 'application/json',
'{ "foo": 1 }'
}]);
server.respondWith('GET', '/bar', [200, {
'Content-Type': 'application/json',
'{ "bar": 1 }'
}]);
},
afterEach: function() {
server.restore();
}
});
QUnit.test('do some ajax', function(assert) {
var done = assert.async();
doTwoAjaxCalls(function () {
// whatever your assertions are...
// (of course, your method would need to perform the callback...)
done();
});
});
更新
查看更新后的代码,我们可以了解为什么需要调用 respond()
两次:第一次调用响应“释放”初始 ajax 请求(到 /foo
) 从它的队列中,然后调用第一个成功回调。在该回调中,您启动第二个 ajax 调用,Sinon 然后保持该调用,直到您再次调用 respond()
。
换句话说,调用 respond()
将使 Sinon 释放所有当前持有的 ajax 请求,但在您的情况下,一次只持有一个。使用我上面提到的 autoRespond
选项消除了这种需要,因为 Sinon 立即“响应”,但我相信在这种情况下您需要使测试异步(或者至少,这是最佳实践)。
祝你好运!
关于javascript - Sinonjs fakeserver - 多个ajax调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28304459/
我有一个类,我在其中绑定(bind)了一个初始化方法,如下所示 - function MyClass() { this.onHttpCallback = _.bind(onHttpCallba
我将 QUnit 与 sinon 一起使用。我怎样才能制作 sinon 的 fakeserver响应由相同方法调用的链式 ajax? module('demo', { beforeEach:
我正在使用 SinonJS 和 QUnit 运行以下代码: var clock = this.sandbox.useFakeTimers(); var el = jQuery(""); el.appe
我可以在实习生中运行测试,但我在让 spy 工作方面遇到了困难。我正在尝试整合 sinon 这样我就可以得到 spy 。这是一个示例测试文件: define([ 'intern!bdd',
我想做如下的事情: sinon.mock(obj) .expects('func') .atLeast(1) .withArgs(args) .returns(somePredefinedReturn
我正在尝试测试我的 Sinon 测试中的 spy 是否被一个确切的对象调用:没有丢失的属性,没有附加的属性,也没有更改的属性。 我有这个: assert( viewer.entities.add.ca
在开发 API 时(在我的例子中是围绕 websockets 服务的 API),是否有一种好方法可以将它的框架实现提供给另一个开发人员,以便他可以独立于我工作?例如,如果我的 API 仍处于设计阶段,
我有一个函数: var publish = function(a, b, c) { main = a + getWriterName(b,c); } getWriterName 是另一个函数:
我有一个可能会抛出错误的方法,但我无法为这种情况编写 SinonJS/Mocha/Should 单元测试用例。 被测函数示例: function testError(value) { if (!v
我有一个 myModule Node.js 模块,其中包含: function b() { console.log('original b'); } function a() { b(); }
我是SinonJs的初学者,当我尝试编写一些演示代码时,它无法工作,我不知道为什么。 应用程序.js const db = require('./db'); module.exports.si
我实际上使用的是我的社会创建的微框架,我们在其中使用了 Mongoose。 为了管理 mongoose 对象,我们创建了一个模型工厂,它返回一个对应于 mongoose 名称对象的模型。 实际上,我正
我正在尝试使用 Protractor 自动化端到端测试,并且我正在使用 sinonjs 设置一个 fakeServer 来响应由按钮点击触发的某些 ajax 调用(不是全部)。 我陷入困境,不知道如何
我目前正在编写一个 NodeJS 应用程序,我想为一个函数编写一个测试。 SinonJS 似乎是首选的 spy / stub /模拟库,但我似乎无法弄清楚如何在函数上 stub 方法。例如: 假设我正
我有一个用于自动注销功能的网络组件,它会在第 59 分钟显示带有消息的模式窗口,并在没有事件的情况下再停留一分钟。如果用户没有点击窗口上的任何地方,则注销用户。因此,一个小时内没有任何事件将自动注销用
我无法理解 sinonjs spy 的行为。 这是我的测试: asyncTest('sinon async spies test', function() { var pApi = {
使用 SinonJS 3 运行测试我遇到了以下问题 测试有什么问题? var creator = (function() { var createIfNotExists = function cr
在我的应用程序中,在我的路由器使用的导航守卫内,我有一个 vuex 命名空间的 getter 来检查身份验证状态。如果用户已通过身份验证,getter 会执行神奇的底层检查。 我想编写一个简单的单元测
我正在寻找 sinonjs 中的 jasmine.createSpy().and.callFake(fn) 的等价物。 例如: const mySpy = jasmine.createSpy('my
我使用 backbonejs、requirejs 来制作我的 javascript 应用。 我还使用 jasmine、sinonjs 和 jasmine-sinon 插件来测试我的应用程序,但是在使用
我是一名优秀的程序员,十分优秀!