forked from adobe/react-spectrum
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathComboBox.ssr.test.js
98 lines (89 loc) · 3.61 KB
/
ComboBox.ssr.test.js
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
/*
* Copyright 2023 Adobe. All rights reserved.
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. You may obtain a copy
* of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
* OF ANY KIND, either express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
import {fireEvent, screen, testSSR} from '@react-spectrum/test-utils-internal';
describe('ComboBox SSR', function () {
it('should render text of default selected key', async function () {
await testSSR(__filename, `
import {ComboBox, Label, Input, Popover, ListBox, ListBoxItem} from '../';
<React.StrictMode>
<ComboBox defaultSelectedKey="dog">
<Label>Favorite Animal</Label>
<Input />
<Popover>
<ListBox>
<ListBoxItem id="cat">Cat</ListBoxItem>
<ListBoxItem id="dog">Dog</ListBoxItem>
<ListBoxItem id="kangaroo">Kangaroo</ListBoxItem>
</ListBox>
</Popover>
</ComboBox>
</React.StrictMode>
`, () => {
// Assert that server rendered stuff into the HTML.
let input = screen.getByRole('combobox');
expect(input.value).toBe('Dog');
});
// Assert that hydrated UI matches what we expect.
let input = screen.getByRole('combobox');
expect(input.value).toBe('Dog');
});
it('should point ref correctly after hydration', async function () {
await testSSR(__filename, `
import {ComboBox, Label, Input, Popover, ListBox, ListBoxItem} from '../';
import {useState, useRef} from 'react';
import {useLayoutEffect} from '@react-aria/utils';
function App() {
let [trigger, setTrigger] = useState(['null']);
let [otherState, setOtherState] = useState(0);
let ref = useRef(null);
useLayoutEffect(() => {
setTrigger(prev => [...prev, ref.current?.outerHTML]);
}, [otherState]);
return (
<React.StrictMode>
<ComboBox defaultSelectedKey="dog">
<div ref={ref}>
<Label>Favorite Animal</Label>
<Input />
</div>
<Popover>
<ListBox>
<ListBoxItem id="cat">Cat</ListBoxItem>
<ListBoxItem id="dog">Dog</ListBoxItem>
<ListBoxItem id="kangaroo">Kangaroo</ListBoxItem>
</ListBox>
</Popover>
</ComboBox>
<div role="button">{trigger.join(", ")}</div>
<div role="button" onClick={() => setOtherState(1)}>{otherState}</div>
</React.StrictMode>
);
}
<App />
`, () => {
// Assert that server rendered stuff into the HTML.
let input = screen.getByRole('combobox');
expect(input.value).toBe('Dog');
let buttons = screen.getAllByRole('button');
expect(buttons[0].textContent).toBe('null');
});
// Assert that hydrated UI matches what we expect.
let input = screen.getByRole('combobox');
expect(input.value).toBe('Dog');
let buttons = screen.getAllByRole('button');
let [button, button2] = buttons;
fireEvent.click(button2);
expect(button2.textContent).toBe('1');
let [, first, second] = button.textContent.split(', ');
expect(first.replace(/ aria-describedby="[^"]*"/, '')).toBe(second);
});
});