无法让MockBackend返回错误响应

时间:2016-02-12 14:28:02

标签: javascript unit-testing mocking angular

当我尝试使用Angular 2 MockBackend

进行单元测试时出现问题

我对后端成功响应的测试工作正常,但是当我尝试模拟来自后端的错误响应时,它总是在成功案例中。

我将以下内容绑定到两个不同的按钮,其中一个传递true,另一个传递false给函数。无论我按什么按钮,我们总是在订阅中找到成功块。我错过了什么?

callHttp(success) {
  let connection;
  mockBackend.connections.subscribe(c => connection = c);
  this.http.get("/test")
    .subscribe(
      res => {
        let msg = "Success status ("+res.status+")";
        console.log(msg);
        this.latestMessage = msg;
      }),
      err => {
        // We never get here...
        let msg = "Error status ("+res.status+")";
        console.log(msg);
        this.latestMessage = msg;
      });
  connection.mockRespond(new Response(new BaseResponseOptions().merge({
    status: success ? 200 : 401,
    body: JSON.stringify("Response")
  })));
}

我已在以下插件中复制了该问题:http://plnkr.co/edit/Rsl8Zcj6iEAIoD8KDDly

当我使用实际后端运行代码时,它按预期工作。当我编写测试时,我的问题仅仅是模拟错误响应。

1 个答案:

答案 0 :(得分:7)

MockConnection对象有一个mockError(err?: Error)函数,你应该调用它而不是mockRespond。