-
-
Notifications
You must be signed in to change notification settings - Fork 10.2k
/
useLocation-test.tsx
105 lines (94 loc) · 3.35 KB
/
useLocation-test.tsx
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
import * as React from "react";
import * as TestRenderer from "react-test-renderer";
import { MemoryRouter, Routes, Route, useLocation } from "react-router";
import type { Equal, Expect } from "@remix-run/router/__tests__/utils/utils";
function ShowLocation() {
let location = useLocation();
return <pre>{JSON.stringify(location)}</pre>;
}
describe("useLocation", () => {
it("returns the current location object", () => {
let renderer: TestRenderer.ReactTestRenderer;
TestRenderer.act(() => {
renderer = TestRenderer.create(
<MemoryRouter initialEntries={["/home?the=search#the-hash"]}>
<Routes>
<Route path="/home" element={<ShowLocation />} />
</Routes>
</MemoryRouter>
);
});
expect(renderer.toJSON()).toMatchInlineSnapshot(`
<pre>
{"pathname":"/home","search":"?the=search","hash":"#the-hash","state":null,"key":"default"}
</pre>
`);
});
it("returns the scoped location object when nested in <Routes location>", () => {
let renderer: TestRenderer.ReactTestRenderer;
TestRenderer.act(() => {
renderer = TestRenderer.create(
<MemoryRouter initialEntries={["/home?the=search#the-hash"]}>
<App />
</MemoryRouter>
);
});
function App() {
return (
<div>
<Routes>
<Route path="/home" element={<ShowLocation />} />
</Routes>
<Routes location="/scoped?scoped=search#scoped-hash">
<Route path="/scoped" element={<ShowLocation />} />
</Routes>
</div>
);
}
expect(renderer.toJSON()).toMatchInlineSnapshot(`
<div>
<pre>
{"pathname":"/home","search":"?the=search","hash":"#the-hash","state":null,"key":"default"}
</pre>
<pre>
{"pathname":"/scoped","search":"?scoped=search","hash":"#scoped-hash","state":null,"key":"default"}
</pre>
</div>
`);
});
it("preserves state from initialEntries", () => {
let renderer: TestRenderer.ReactTestRenderer;
TestRenderer.act(() => {
renderer = TestRenderer.create(
<MemoryRouter
initialEntries={[
{ pathname: "/example", state: { my: "state" }, key: "my-key" },
]}
>
<Routes>
<Route path={"/example"} element={<ShowLocation />} />
</Routes>
</MemoryRouter>
);
});
expect(renderer.toJSON()).toMatchInlineSnapshot(`
<pre>
{"pathname":"/example","search":"","hash":"","state":{"my":"state"},"key":"my-key"}
</pre>
`);
});
// eslint-disable-next-line jest/expect-expect -- type tests
it("returns an object with the correct type", () => {
// eslint-disable-next-line @typescript-eslint/no-unused-vars -- used for type tests
function TestUseLocationReturnType() {
let location = useLocation();
// eslint-disable-next-line @typescript-eslint/no-unused-vars -- type test
type Test1 = Expect<Equal<typeof location.hash, "" | `#${string}`>>;
// eslint-disable-next-line @typescript-eslint/no-unused-vars -- type test
type Test2 = Expect<Equal<typeof location.pathname, "" | `/${string}`>>;
// eslint-disable-next-line @typescript-eslint/no-unused-vars -- type test
type Test3 = Expect<Equal<typeof location.search, "" | `?${string}`>>;
return null;
}
});
});