订阅进行Jasmine Angular单元测试

时间:2020-06-04 18:00:33

标签: angular unit-testing jasmine karma-jasmine angular-unit-test

------服务文件-------

postStatus(status: String) {
    return this.http
        .post(url, null, {
          headers: new HttpHeaders({"Content-Type": "application/json"}),
          observe: "response"
        })
        .subscribe(
            responseDate => {
              console.log(responseDate)
              this.statusUpdated.next(status);
            },
            error => {
              if (status === "Z") this.statusUpdated.next("ZERROR")
              else this.statusUpdated.next("YERROR")
            })
  }

-----规范文件---------

const errorResponse = new HttpErrorResponse({
  error: 'test 404 error',
  status: 404, statusText: 'Not Found'
});


it('postStatus should return error and update status to error to ZERROR' ,() =>{
    httpCientSpyPost = jasmine.createSpyObj('http', ['post']);
    service  = new ChangelogService(<any>httpCientSpyPost,null,null,new PostMessageService());
    let updatedStatus:string = '';


    httpCientSpyPost.post.and.returnValue(of(errorResponse));
    service.statusUpdated.subscribe((status:string) => {updatedStatus=status});

    service.postStatus('Z');

    expect(httpCientSpyPost.post.calls.count()).toBe(1, 'one call');
    expect(updatedStatus).toBe('ZERROR');
});

---------错误我正在得到------------

错误:

Expected 'Z' to be 'ZERROR'.

它不会出错。我在这里想念东西吗?

1 个答案:

答案 0 :(得分:0)

您将返回错误对象而不会在可观察对象中引起错误,因此它正在执行成功路径。尝试将returnValue替换为以下内容:

httpCientSpyPost.post.and.returnValue(throwError(errorResponse));

这将导致被观察者输入错误路径。您将需要从rxjs导入throwError