我通过ember-cli-mirage的文档阅读有关创建模拟响应的文档,但无法弄清楚如何针对完全相同的请求测试错误响应。例如:
test("I can view the users", function() {
var users = server.createList('user', 3);
visit('/users');
andThen(function() {
equal( find('li').length, 3 );
equal( find('li:first').text(), users[0].name );
});
});
test("I can view the error if viewing the users returns an error", function() {
// somehow set up an error response (?)
visit('/users');
andThen(function() {
equal( find('#error').length, 1 );
});
});
看起来形成响应的唯一方法是在路径
中this.get('/users', function(db, request) {
if (something based on the request, i guess?) {
return new Mirage.Response(500, {}, {message: 'Oops! Something bad happenned. :('});
} else {
return db.users.insert([
{name: 'Zelda', age: 142},
{name: 'Epona', age: 58},
]);
}
});
海市蜃楼如何推荐这样做?
答案 0 :(得分:3)
在测试中,config.js
中定义的路由处理程序已加载,但由于您可以访问server
,因此实际上可以覆盖这些处理程序。
在这种情况下我只是为错误状态创建一个临时路由处理程序:
test("I can view the error if viewing the users returns an error", function() {
server.get('/users', {errors: ['there was an error']}, 404);
visit('/users');
andThen(function() {
equal( find('#error').length, 1 );
});
});
由于服务器已针对每个测试进行了重新实例化,因此该处理程序将不会存在于其他测试中。
还有一个PR用于API,允许您编写临时路由处理程序,这对于测试应用程序是否可以从错误中恢复非常有用。