-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathuse-async.spec.ts
88 lines (74 loc) · 2.81 KB
/
use-async.spec.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
/// <reference types="@rbxts/testez/globals" />
import { renderHook } from "../utils/testez";
import { useAsync } from "./use-async";
export = () => {
it("should run the promise on mount", () => {
const { result } = renderHook(() => {
const [value, status, message] = useAsync(() => Promise.resolve("foo"));
return { value, status, message };
});
expect(result.current.status).to.be.equal(Promise.Status.Resolved);
expect(result.current.value).to.be.equal("foo");
expect(result.current.message).to.never.be.ok();
});
it("should run the promise when the dependencies change", () => {
const { result, rerender } = renderHook(
(deps: unknown[]) => {
const [value, status, message] = useAsync(() => Promise.resolve(deps[0]), [deps]);
return { value, status, message };
},
{ initialProps: [0] },
);
expect(result.current.status).to.be.equal(Promise.Status.Resolved);
expect(result.current.value).to.be.equal(0);
expect(result.current.message).to.never.be.ok();
rerender([1]);
expect(result.current.status).to.be.equal(Promise.Status.Resolved);
expect(result.current.value).to.be.equal(1);
expect(result.current.message).to.never.be.ok();
});
it("should cancel the previous promise", () => {
let completions = 0;
const { result, rerender } = renderHook(
(deps: unknown[]) => {
const [value, status, message] = useAsync(() => Promise.delay(0).then(() => ++completions), [deps]);
return { value, status, message };
},
{ initialProps: [0] },
);
rerender([1]);
rerender([2]);
rerender([3]);
expect(completions).to.be.equal(0);
expect(result.current.status).to.be.equal(Promise.Status.Started);
expect(result.current.value).to.never.be.ok();
expect(result.current.message).to.never.be.ok();
task.wait(0.04);
expect(completions).to.be.equal(1);
expect(result.current.status).to.be.equal(Promise.Status.Resolved);
expect(result.current.value).to.be.equal(1);
expect(result.current.message).to.never.be.ok();
});
it("should update the state when the promise resolves", () => {
const { result } = renderHook(() => {
const [value, status, message] = useAsync(() => Promise.delay(0).then(() => "foo"));
return { value, status, message };
});
expect(result.current.status).to.be.equal(Promise.Status.Started);
expect(result.current.value).to.never.be.ok();
expect(result.current.message).to.never.be.ok();
task.wait(0.04);
expect(result.current.status).to.be.equal(Promise.Status.Resolved);
expect(result.current.value).to.be.equal("foo");
expect(result.current.message).to.never.be.ok();
});
it("should cancel the promise on unmount", () => {
let completions = 0;
const { unmount } = renderHook(() => {
useAsync(() => Promise.delay(0).then(() => ++completions));
});
unmount();
task.wait(0.04);
expect(completions).to.be.equal(0);
});
};