nginit中的component变量应该被定义,但是未定义

时间:2019-05-15 09:37:06

标签: typescript unit-testing jasmine

我正在测试角度应用程序。我嘲笑了http get调用,并用dummydata刷新了。我希望期望该哑元数据被定义或打印此变量的变量。我看到这是不确定的。希望下面的代码段给出清晰的主意

打字稿

ngOnInit() {
    this.data = [];
    this.getData()
    .subscribe(res => {
        if (res['status'] == "FAILURE") {
         ....
        } else {
          this.data = res['data'] as Array<something>;
        }
      }, (err) => {
        console.log(err);
      }
    );
  }

 getData(): Observable<something[]> {
    return this.http.get<something[]>('/api/getData');
  }

export class something {
    id: number;
    name: string;
}

规格

mockheader=
[
      ['id', 'id'],
      ['name', 'name'],
]
it('should define data', () => {
    let spyOndata=spyOn(component,'ngOnInit').and.callThrough();
      var dummyFinancial : Array<something>;
      dummydata = [
        {
          id:"gdg"
          name:"xys"  
        }
      ];
      component.headers=mockheaders;
      //fixture.detectChanges();
      const req = httpMock.expectOne('/api/getData');
      expect(req.request.method).toBe("GET");
      req.flush(dummydata);

      console.log(component.data);//nothing prints
      expect(component.data.length).toBe(1);//fails
      expect(component.data).toEqual(dummydata);//fails


  });

0 个答案:

没有答案