gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-04 23:13:59 26 4
gpt4 key购买 nike

我现在面临一个问题。不知道如何测试 action$ 是否带有过滤器运算符。

我也在努力遵守 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。

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

最佳答案

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

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

关于store - 如何使用 Jasmine 和 Marble 在 Angular 4 5 中使用 ngrx 过滤器测试效果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48021543/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com