I want to test ngLogger function with jasmine marble but a got error
Expected $.length = 2 to equal 1.
Expected $.length = 2 to equal 1.
Expected $[0].frame = 0 to equal 10.
Expected $[0].notification.value to be a kind of Observable, but was Object({ type: 'TECHNICAL', level: 'ERROR', msg: 'test' }).
Expected $[1] = Object({ frame: 0, notification: Notification({ kind: 'C', value: undefined, error: undefined, hasValue: false }) }) to equal undefined.
export namespace GlobalUtils {
export function ngLogger(error: string):
Observable<Log> {
return of({ type: LogEnum.TECHNICAL,
level: LevelEnum.ERROR,
msg: error } as Log
);
}
}
import { GlobalUtils } from './global.utils';
it('ngLogger should be return an Observable', () => {
const expected = of({
type: LogEnum.TECHNICAL,
level: LevelEnum.ERROR,
msg: 'test'
});
const expected$ = hot('-a', { a: expected });
const result$ = GlobalUtils.ngLogger('test');
expect(result$).toBeObservable(expected$);
});
const expected$ = hot('a', { a: expected });
don't do any difference. const expected$ = hot('a|', { a: expected });
give the error :
Expected $[0].notification.value to be a kind of Observable, but was Object({ type: 'TECHNICAL', level: 'ERROR', msg: 'test' }).
Expected $[1].frame = 0 to equal 10
then I changed
const expected = of({
type: LogEnum.TECHNICAL,
level: LevelEnum.ERROR,
msg: 'test'
});` to `const expected = of({
type: LogEnum.TECHNICAL,
level: LevelEnum.ERROR,
msg: 'test'
});
I get the error Expected $[1].frame = 0 to equal 10.
what does it means ?
You have 2 issues first is that marble should be (a|)
as this is how you describe simultaneous emit and end observable which is done when using of
.
The second issue is that you have your expected defined as observable and it should be only the data inside.
And thanks to this I have learnt how to use marbles:
const msg = 'test';
const expected = {
type: LogEnum.TECHNICAL,
level: LevelEnum.ERROR,
msg,
}; // notice that this value should not be observable
const expected$ = hot('(a|)', { a: expected }); // also you are returning of which is ending immediately
const result$ = GlobalUtils.ngLogger(msg);
expect(result$).toBeObservable(expected$);
Also in addition here is working example
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With