angular2 - 如何在http.post单元测试中模拟错误

时间:2016-03-26 16:36:55

标签: unit-testing http post angular

我正在使用HTTP.post调用为登录方法编写Uni-test,如:

this.http.post( endpoint, creds, { headers: headers})
        .map(res => res.json())
        .subscribe(
        data => this.onLoginComplete(data.access_token, credentials),  
        err => this.onHttpLoginFailed(err),
        () => this.trace.debug(this.componentName, "Login completed.")
    );

问题在于我无法模拟错误分支;每次都称为onLoginComplete方法;

这是我的测试:

it("check that  Atfer Login, console show an error ", inject(
  [TraceService, Http, MockBackend, WsiEndpointService],
  (traceService: TraceService, http: Http, 
   backend: MockBackend, wsiEndpoint: WsiEndpointService) => {

  let tokenTest: number =  404 ;

  let response: ResponseOptions = null {} // i think i have to modify this

  let connection: any;

  backend.connections.subscribe((c: any) => connection = c);

  let authService: AuthService = new AuthService(http, Service1, Service2);

  authenticationservice.login({ "username": "a", "password": "1" });

  connection.mockRespond(new Response(response));

  expect(ERROR);

}));

再次感谢大家。

2 个答案:

答案 0 :(得分:18)

首先,您需要通过XHRBackend一个覆盖MockBackend类:

describe('HttpService Tests', () => {
  beforeEachProviders(() => {
    return [
      HTTP_PROVIDERS,
      provide(XHRBackend, { useClass: MockBackend }),
      HttpService
    ];
  });

  (...)
});

请注意HttpService是使用Http对象的服务,我想测试。

然后你需要注入mockBackend并订阅它的connections属性。发送请求时,将调用相应的回调,您可以指定响应元素,如正文。该服务将接收此响应作为呼叫的响应。因此,您将能够基于此测试您的服务方法。

下面我将介绍如何测试getItems的<{1}}方法:

HttpService

以下是it('Should return a list of items', inject([XHRBackend, HttpService, Injector], (mockBackend, httpService, injector) => { mockBackend.connections.subscribe( (connection: MockConnection) => { connection.mockRespond(new Response( new ResponseOptions({ body: [ { id: '1', label: 'item1' }] }))); }); httpService.getItems().subscribe( items => { expect(items).toEqual([ { id: '1', label: 'item1' }]); }); }); }); 的{​​{1}}方法的代码:

getItems

要模拟错误,只需使用HttpService方法而不是@Injectable() export class HttpService { constructor(private http:Http) { } getItems(): Observable<any[]> { return this.http.get('/items').map(res => res.json()); } } 方法:

mockError

答案 1 :(得分:3)

你可以模拟这样的错误:

connection.mockError(new Response(new ResponseOptions({
    body: '',
    status: 404,
})));

我创建了一个小类

import {ResponseOptions, Response} from '@angular/http';

export class MockError extends Response implements Error {

    name: any;
    message: any;

    constructor(status: number, body: string = '') {
        super(new ResponseOptions({status, body}));
    }
}

可以像这样使用

connection.mockError(new MockError(404));