如何解决用茉莉花大理石测试效果
我在Effects
中有此代码:
@Injectable()
export class MyEffects {
readonly counter$ = createEffect(() =>
this.actions$.pipe(
ofType(someAction),withLatestFrom(this.store$.pipe(select(selectStatusFailed))),exhaustMap(([{ someObj },statusFailed]) => {
return interval(1000).pipe(
scan(acc => acc - 1,someObj.expirationTime),// expiration time is expressed in seconds
filter(counter => counter === 0),filter(() => !statusFailed),mapTo(anAction({ someObj })),takeuntil(
this.actions$.pipe(ofType(anAction,anotherAction)),),);
}),);
}
我想测试一下,但是由于我是大理石图以及大理石测试的新手,所以我遇到了几个问题。
到目前为止,我的尝试:
import { cold,hot } from '@nrwl/angular/testing';
test('something',() => {
const mock = myMock({ expirationTime: 5 });
const action = someAction({ mock });
const completion = anAction({ mock });
actions$ = hot('-a',{ a: action });
const expected$ = cold(
'b 1000ms c 1000ms d 1000ms e 1000ms f 1000ms (g|)',{
b: 4,c: 3,d: 2,e: 1,f: 0,g: completion,},);
expect(myEffects.counter$).toBeObservable(expected$);
});
现在我正在接收
- 预期-95
- 已接收+ 1
- 数组[]
问题:
请注意,我使用的是Angular 10.x.y,NGRX 10.x.y,NX 10.x.y和spectator 5.x.y。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。