Angular Jasmine的角度单元测试滤波器谓词函数

Angular Jasmine的角度单元测试滤波器谓词函数,angular,jasmine,karma-jasmine,angular-material2,Angular,Jasmine,Karma Jasmine,Angular Material2,我有一个filter谓词函数,我用它来过滤角度表中的mat表 this.dataSource.filterPredicate = this.myService.tableFilter(); tableFilter(): (data: any, filter: string) => boolean { let filterFunction = function (data, filter): boolean { let filterValues = JSON.parse

我有一个filter谓词函数,我用它来过滤角度表中的mat表

this.dataSource.filterPredicate = this.myService.tableFilter();

tableFilter(): (data: any, filter: string) => boolean {
    let filterFunction = function (data, filter): boolean {
      let filterValues = JSON.parse(filter);
      ... my logic ...
    };
    return filterFunction;
  }
}
我想写一个单元测试来测试这个过滤器谓词函数

it('filter table', inject(
    [MyService],
    (service: MyService) => {

      // how to do this?
      let messageObject = service.tableFilter(dummyData, 
        getDummyFilterValues());
    }
  ));

如何在单元测试中调用service.tableFilter函数?

将下面代码中返回对象的逻辑替换为布尔返回。我认为问题在于如何调用返回的函数

打字脚本代码

tableFilter(): (data: any, filter: string) => any {
    const filterFunction = (data, filter) => {
      const filterValues = JSON.parse(filter);
      return data.find(d => {
        return d.num === filterValues.num;
      });
    };
    return filterFunction;
  }
规范文件/单元试块

  it('test filterfx', () => {
    const fixture = TestBed.createComponent(AppComponent);
    const app = fixture.debugElement.componentInstance;
    const filterfx =  app.tableFilter();
    expect(filterfx(app.data,  JSON.stringify({ num: 'one' })).num).toEqual('one');
  });