From 93302f4dc05c988aea91f45c26ff69931fce2131 Mon Sep 17 00:00:00 2001 From: Hok Wai Chan <77360958+hokwaichan@users.noreply.github.com> Date: Wed, 29 May 2024 17:52:36 -1000 Subject: [PATCH] Replace fireEvent with userEvent in Jest tests (#20) --- ui/package.json | 2 ++ .../app/(index)/_components/LoginButton.test.tsx | 11 ++++++----- .../components/layout/navbar/LoginButton.test.tsx | 11 ++++++----- .../layout/navbar/MobileNavbar.test.tsx | 15 ++++++++------- 4 files changed, 22 insertions(+), 17 deletions(-) diff --git a/ui/package.json b/ui/package.json index 3d92dd95..1be129a2 100644 --- a/ui/package.json +++ b/ui/package.json @@ -34,8 +34,10 @@ "devDependencies": { "@stylistic/eslint-plugin": "^1.6.1", "@swc/core": "^1.3.106", + "@testing-library/dom": "^10.1.0", "@testing-library/jest-dom": "^6.3.0", "@testing-library/react": "^14.1.2", + "@testing-library/user-event": "^14.5.2", "@types/jest": "^29.5.11", "@types/node": "^20", "@types/react": "^18", diff --git a/ui/tests/app/(index)/_components/LoginButton.test.tsx b/ui/tests/app/(index)/_components/LoginButton.test.tsx index a7b84bca..654122af 100644 --- a/ui/tests/app/(index)/_components/LoginButton.test.tsx +++ b/ui/tests/app/(index)/_components/LoginButton.test.tsx @@ -1,4 +1,5 @@ -import { render, screen, fireEvent } from '@testing-library/react'; +import { render, screen } from '@testing-library/react'; +import userEvent from '@testing-library/user-event'; import { redirect } from 'next/navigation'; import User, { AnonymousUser } from '@/access/User'; import Role from '@/access/Role'; @@ -16,11 +17,11 @@ describe('LoginButton Component', () => { expect(screen.getByRole('button', {name: 'Login Here'})).toBeInTheDocument; }); - it('should visit the CAS login url on click', () => { + it('should visit the CAS login url on click', async() => { render(); const casLoginUrl = `${casUrl}/login?service=${encodeURIComponent(`${baseUrl}/api/cas/login`)}`; - fireEvent.click(screen.getByRole('button', {name: 'Login Here'})); + await userEvent.click(screen.getByRole('button', {name: 'Login Here'})); expect(redirect).toHaveBeenCalledWith(casLoginUrl); }); }); @@ -36,11 +37,11 @@ describe('LoginButton Component', () => { expect(screen.getByRole('button', {name: 'Logout'})).toBeInTheDocument; }); - it('should visit the CAS logout url on click', () => { + it('should visit the CAS logout url on click', async () => { render(); const casLogoutUrl = `${casUrl}/logout?service=${encodeURIComponent(`${baseUrl}/api/cas/logout`)}`; - fireEvent.click(screen.getByRole('button', {name: 'Logout'})); + await userEvent.click(screen.getByRole('button', {name: 'Logout'})); expect(redirect).toHaveBeenCalledWith(casLogoutUrl); }); }); diff --git a/ui/tests/components/layout/navbar/LoginButton.test.tsx b/ui/tests/components/layout/navbar/LoginButton.test.tsx index dba73f42..02f9808a 100644 --- a/ui/tests/components/layout/navbar/LoginButton.test.tsx +++ b/ui/tests/components/layout/navbar/LoginButton.test.tsx @@ -1,4 +1,5 @@ -import { render, screen, fireEvent } from '@testing-library/react'; +import { render, screen } from '@testing-library/react'; +import userEvent from '@testing-library/user-event'; import Login from '@/components/layout/navbar/LoginButton'; import { redirect } from 'next/navigation'; import User, { AnonymousUser } from '@/access/User'; @@ -18,11 +19,11 @@ describe('Login', () => { expect(screen.getByRole('button', { name: 'Login' })).toBeInTheDocument; }); - it('should visit the CAS login url on click', () => { + it('should visit the CAS login url on click', async() => { render(); const casLoginUrl = `${casUrl}/login?service=${encodeURIComponent(`${baseUrl}/api/cas/login`)}`; - fireEvent.click(screen.getByRole('button', { name: 'Login' })); + await userEvent.click(screen.getByRole('button', { name: 'Login' })); expect(redirect).toHaveBeenCalledWith(casLoginUrl); }); @@ -40,11 +41,11 @@ describe('Login', () => { expect(screen.getByRole('button', { name: `Logout (${testUser.uid})` })).toBeInTheDocument; }); - it('should visit the CAS logout url on click', () => { + it('should visit the CAS logout url on click', async () => { render(); const casLogoutUrl = `${casUrl}/logout?service=${encodeURIComponent(`${baseUrl}/api/cas/logout`)}`; - fireEvent.click(screen.getByRole('button', { name: `Logout (${testUser.uid})` })); + await userEvent.click(screen.getByRole('button', { name: `Logout (${testUser.uid})` })); expect(redirect).toHaveBeenCalledWith(casLogoutUrl); }); diff --git a/ui/tests/components/layout/navbar/MobileNavbar.test.tsx b/ui/tests/components/layout/navbar/MobileNavbar.test.tsx index 810a7c89..40eac48d 100644 --- a/ui/tests/components/layout/navbar/MobileNavbar.test.tsx +++ b/ui/tests/components/layout/navbar/MobileNavbar.test.tsx @@ -1,7 +1,8 @@ import Role from '@/access/Role'; import User, { AnonymousUser } from '@/access/User'; import MobileNavbar from '@/components/layout/navbar/MobileNavbar'; -import { fireEvent, render, screen } from '@testing-library/react'; +import { render, screen } from '@testing-library/react'; +import userEvent from '@testing-library/user-event'; const testUser: User = JSON.parse(process.env.TEST_USER_A as string); @@ -13,10 +14,10 @@ describe('MobileNavbar', () => { expect(screen.queryByRole('navigation')).not.toBeInTheDocument(); }); - it('should open the drawer on click', () => { + it('should open the drawer on click', async () => { render(); - fireEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); + await userEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); expect(screen.getByRole('navigation')).toBeInTheDocument(); }); @@ -25,7 +26,7 @@ describe('MobileNavbar', () => { it('should render the navbar with only the link to /about', async () => { render(); - fireEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); + await userEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); expect(screen.getByRole('navigation')).toBeInTheDocument(); expect(screen.queryByRole('link', { name: 'Admin' })).not.toBeInTheDocument(); expect(screen.queryByRole('link', { name: 'Memberships' })).not.toBeInTheDocument(); @@ -46,7 +47,7 @@ describe('MobileNavbar', () => { testUser.roles.push(Role.UH); render(); - fireEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); + await userEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); expect(screen.getByRole('navigation')).toBeInTheDocument(); expect(screen.queryByRole('link', { name: 'Admin' })).not.toBeInTheDocument(); expect(screen.getByRole('link', { name: 'Memberships' })).toHaveAttribute('href', '/memberships'); @@ -59,7 +60,7 @@ describe('MobileNavbar', () => { testUser.roles.push(Role.OWNER, Role.UH); render(); - fireEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); + await userEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); expect(screen.getByRole('navigation')).toBeInTheDocument(); expect(screen.queryByRole('link', { name: 'Admin' })).not.toBeInTheDocument(); expect(screen.getByRole('link', { name: 'Memberships' })).toHaveAttribute('href', '/memberships'); @@ -72,7 +73,7 @@ describe('MobileNavbar', () => { testUser.roles.push(Role.ADMIN, Role.UH); render(); - fireEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); + await userEvent.click(screen.getByRole('button', { name: 'Open navigation menu' })); expect(screen.getByRole('navigation')).toBeInTheDocument(); expect(screen.getByRole('link', { name: 'Admin' })).toHaveAttribute('href', '/admin'); expect(screen.getByRole('link', { name: 'Memberships' })).toHaveAttribute('href', '/memberships');