如何使用 Jasmine 和 Marble 在 Angular 4 5 中使用 ngrx 过滤器测试效果

how to test effects with filter of ngrx in Angular 4 5 with Jasmine and Marble

我现在面临一个问题。不确定如何使用过滤器运算符测试 action$。

我也在努力遵守https://github.com/vsavkin/testing_ngrx_effects/tree/309b84883c2709a34ab98b696398332d33c2104f

的规则

简单点,如果数组的长度为0,我就设置过滤器return true。

例如:

loadDatas$: Observable<Action> = this.actions$.ofType(LOAD_DATAS_ACTION).pipe(

withLatestFrom(this.store.select(getDatas), (action, datas) =>datas),

filter(data => !data.length),

switchMap(() => {

console.log(‘run api’);

return this.dataApi.find().pipe(

map((datas: Data[]) => new DatasLoadedAction(datas))

…………

……

所以我试着写了两个测试用例,一个是

expect(effects.loadDatas$).toBeObservable(expected);

当过滤器 return 为真时。

但我不知道如何测试过滤器 return 是否为假。

对此你有什么建议吗?非常感谢

您希望效果不是 return 新动作,因此您可以将其与 'empty' 可观察值进行比较:

const expected = cold('----');
expect(effects.loadDatas$).toBeObservable(expected);