-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathUserDropdownMenu.test.tsx
More file actions
76 lines (59 loc) · 2.51 KB
/
UserDropdownMenu.test.tsx
File metadata and controls
76 lines (59 loc) · 2.51 KB
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
// Copyright (c) Gridiron Survivor.
// Licensed under the MIT License.
import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import UserDropdownMenu from './UserDropdownMenu';
describe('UserDropdownMenu', () => {
let user: ReturnType<typeof userEvent.setup>;
beforeEach(() => {
global.fetch = jest.fn(() =>
Promise.resolve({
json: () => Promise.resolve({ avatarUrl: 'mock-avatar-url' }),
}),
) as jest.Mock;
user = userEvent.setup();
});
it('displays Avatar on page load', async () => {
render(<UserDropdownMenu />);
expect(screen.getByTestId('avatar-body')).toBeInTheDocument();
});
it('does not display dropdown menu contents on page load', async () => {
render(<UserDropdownMenu />);
expect(screen.queryByTestId('dropdown-menu-content')).toBeNull();
});
it('opens user dropdown menu when avatar is clicked', async () => {
render(<UserDropdownMenu />);
await user.click(screen.getByTestId('dropdown-menu-trigger'));
expect(screen.getByTestId('dropdown-menu-content')).toBeInTheDocument();
});
it('displays appropriate content when dropdown is open', async () => {
render(<UserDropdownMenu />);
await user.click(screen.getByTestId('dropdown-menu-trigger'));
expect(
screen.getByRole('menuitem', { name: 'My profile' }),
).toHaveTextContent('My profile');
expect(screen.getByRole('button', { name: 'Log out' })).toBeInTheDocument();
});
it('allows user to navigate dropdown menu items with keyboard', async () => {
render(<UserDropdownMenu />);
const trigger = screen.getByTestId('dropdown-menu-trigger');
trigger.focus();
await user.keyboard('[Space]');
expect(screen.getByTestId('my-profile-link')).toHaveFocus();
await user.keyboard('[ArrowDown]');
expect(screen.getByTestId('logout-button')).toHaveFocus();
});
it('navigates user to /profile page when My profile link is clicked', async () => {
render(<UserDropdownMenu />);
await user.click(screen.getByTestId('dropdown-menu-trigger'));
expect(
screen.getByRole('menuitem', { name: 'My profile' }),
).toHaveAttribute('href', '/profile');
});
it('closes the dropdown menu after clicking on an item', async () => {
render(<UserDropdownMenu />);
await user.click(screen.getByTestId('dropdown-menu-trigger'));
await user.click(screen.getByRole('menuitem', { name: 'My profile' }));
expect(screen.queryByTestId('dropdown-menu-content')).toBeNull();
});
});