Angular Jasmine的角度单元测试滤波器谓词函数
我有一个filter谓词函数,我用它来过滤角度表中的mat表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
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');
});