如何使用 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);
我现在面临一个问题。不确定如何使用过滤器运算符测试 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);