如何使用茉莉花和大理石在Angular 4 5中使用ngrx过滤器测试效果

时间:2017-12-29 11:00:32

标签: store effects ngrx angular5 marble

我现在面临一个问题。不知道如何用过滤器运算符测试动作$。

我也在尝试遵循https://github.com/vsavkin/testing_ngrx_effects/tree/309b84883c2709a34ab98b696398332d33c2104f

的规则

简单,我只是设置过滤器,如果数组的长度为0则返回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);

当过滤器返回true时。

但我不知道如何测试过滤器是否返回false。

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

1 个答案:

答案 0 :(得分:5)

您希望效果不会返回新动作,因此您可以将其与“空”可观察对象进行比较:

    awk '{sub(/john/,"bob")}1' file

output
{
     "id" : "123",
     "firstname" : "bob",
     "lastname" : "doe",
     "tel" : "123"
}