-
-
Notifications
You must be signed in to change notification settings - Fork 3.2k
/
Copy pathuseObservable.test.ts
108 lines (82 loc) Β· 2.57 KB
/
useObservable.test.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
import { act, renderHook } from '@testing-library/react-hooks';
import { Subject } from 'rxjs';
import * as useIsomorphicLayoutEffect from '../src/useIsomorphicLayoutEffect';
import useObservable, { Observable } from '../src/useObservable';
const setUp = (observable: Observable<any>, initialValue?: any) =>
renderHook(() => useObservable(observable, initialValue));
it('should init to initial value provided', () => {
const subject$ = new Subject();
const { result } = setUp(subject$, 123);
expect(result.current).toBe(123);
});
it('should init to undefined if not initial value provided', () => {
const subject$ = new Subject();
const { result } = setUp(subject$);
expect(result.current).toBeUndefined();
});
it('should return latest value of observables', () => {
const subject$ = new Subject();
const { result } = setUp(subject$, 123);
act(() => {
subject$.next(125);
});
expect(result.current).toBe(125);
act(() => {
subject$.next(300);
subject$.next(400);
});
expect(result.current).toBe(400);
});
it('should use layout effect to subscribe synchronously', async () => {
const subject$ = new Subject();
const spy = jest.spyOn(useIsomorphicLayoutEffect, 'default');
expect(spy).toHaveBeenCalledTimes(0);
setUp(subject$, 123);
expect(spy).toHaveBeenCalledTimes(1);
});
it('should subscribe to observable only once', () => {
const subject$ = new Subject();
const spy = jest.spyOn(subject$, 'subscribe');
expect(spy).not.toHaveBeenCalled();
setUp(subject$, 123);
expect(spy).toHaveBeenCalledTimes(1);
act(() => {
subject$.next('a');
});
act(() => {
subject$.next('b');
});
expect(spy).toHaveBeenCalledTimes(1);
});
it('should return updated value when observable changes', () => {
const subject$ = new Subject();
const { result } = setUp(subject$);
expect(result.current).toBeUndefined();
act(() => {
subject$.next('foo');
});
expect(result.current).toBe('foo');
act(() => {
subject$.next('bar');
});
expect(result.current).toBe('bar');
});
it('should unsubscribe from observable', () => {
const subject$ = new Subject();
const unsubscribeMock = jest.fn();
subject$.subscribe = jest.fn().mockReturnValue({
unsubscribe: unsubscribeMock,
});
const { unmount } = setUp(subject$);
expect(unsubscribeMock).not.toHaveBeenCalled();
act(() => {
subject$.next('foo');
});
expect(unsubscribeMock).not.toHaveBeenCalled();
act(() => {
subject$.next('bar');
});
expect(unsubscribeMock).not.toHaveBeenCalled();
unmount();
expect(unsubscribeMock).toHaveBeenCalledTimes(1);
});