diff --git a/.eslintrc.js b/.eslintrc.js index 4df9493b2e8c..d9764707d721 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -78,7 +78,7 @@ const restrictedImportPatterns = [ module.exports = { extends: ['expensify', 'plugin:storybook/recommended', 'plugin:react-native-a11y/basic', 'plugin:@dword-design/import-alias/recommended', 'prettier'], - plugins: ['react-native-a11y'], + plugins: ['react-native-a11y', 'testing-library'], parser: 'babel-eslint', ignorePatterns: ['!.*', 'src/vendor', '.github/actions/**/index.js', 'desktop/dist/*.js', 'dist/*.js', 'node_modules/.bin/**', 'node_modules/.cache/**', '.git/**'], env: { @@ -129,6 +129,20 @@ module.exports = { files: ['tests/**/*.js', 'tests/**/*.ts', 'tests/**/*.jsx', 'assets/**/*.js', '.storybook/**/*.js'], rules: {'@dword-design/import-alias/prefer-alias': ['off']}, }, + { + files: ['tests/**/*.js', 'tests/**/*.ts', 'tests/**/*.jsx', 'tests/**/*.tsx'], + extends: ['plugin:testing-library/react'], + rules: { + 'testing-library/await-async-queries': 'error', + 'testing-library/await-async-utils': 'error', + 'testing-library/no-debugging-utils': 'error', + 'testing-library/no-manual-cleanup': 'error', + 'testing-library/no-unnecessary-act': 'error', + 'testing-library/prefer-find-by': 'error', + 'testing-library/prefer-presence-queries': 'error', + 'testing-library/prefer-screen-queries': 'error', + }, + }, { files: ['*.js', '*.jsx'], settings: { diff --git a/package-lock.json b/package-lock.json index 47737d0223d7..4e8d6ecf407e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -213,6 +213,7 @@ "eslint-plugin-jsx-a11y": "^6.6.1", "eslint-plugin-react-native-a11y": "^3.3.0", "eslint-plugin-storybook": "^0.8.0", + "eslint-plugin-testing-library": "^6.2.2", "eslint-plugin-you-dont-need-lodash-underscore": "^6.12.0", "html-webpack-plugin": "^5.5.0", "jest": "29.4.1", @@ -14286,6 +14287,15 @@ "sprintf-js": "~1.0.2" } }, + "node_modules/aria-query": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-5.3.0.tgz", + "integrity": "sha512-b0P0sZPKtyu8HkeRAfCq0IfURZK+SuwMjY1UXGBU27wpAiTwQAIlq56IbIO+ytk/JjS1fMR14ee5WBBfKi5J6A==", + "dev": true, + "dependencies": { + "dequal": "^2.0.3" + } + }, "node_modules/arr-diff": { "version": "4.0.0", "license": "MIT", @@ -19600,14 +19610,6 @@ "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" } }, - "node_modules/eslint-plugin-jsx-a11y/node_modules/aria-query": { - "version": "5.3.0", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "dequal": "^2.0.3" - } - }, "node_modules/eslint-plugin-jsx-a11y/node_modules/axobject-query": { "version": "3.2.1", "dev": true, @@ -19786,6 +19788,22 @@ "lodash": "^4.17.15" } }, + "node_modules/eslint-plugin-testing-library": { + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-testing-library/-/eslint-plugin-testing-library-6.2.2.tgz", + "integrity": "sha512-1E94YOTUDnOjSLyvOwmbVDzQi/WkKm3WVrMXu6SmBr6DN95xTGZmI6HJ/eOkSXh/DlheRsxaPsJvZByDBhWLVQ==", + "dev": true, + "dependencies": { + "@typescript-eslint/utils": "^5.58.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0", + "npm": ">=6" + }, + "peerDependencies": { + "eslint": "^7.5.0 || ^8.0.0" + } + }, "node_modules/eslint-plugin-you-dont-need-lodash-underscore": { "version": "6.12.0", "dev": true, diff --git a/package.json b/package.json index b01a03dc109f..ef11ffcd5dd3 100644 --- a/package.json +++ b/package.json @@ -265,6 +265,7 @@ "eslint-plugin-jsx-a11y": "^6.6.1", "eslint-plugin-react-native-a11y": "^3.3.0", "eslint-plugin-storybook": "^0.8.0", + "eslint-plugin-testing-library": "^6.2.2", "eslint-plugin-you-dont-need-lodash-underscore": "^6.12.0", "html-webpack-plugin": "^5.5.0", "jest": "29.4.1", diff --git a/tests/ui/UnreadIndicatorsTest.tsx b/tests/ui/UnreadIndicatorsTest.tsx index 6c90a3dbf841..5218c1e696c9 100644 --- a/tests/ui/UnreadIndicatorsTest.tsx +++ b/tests/ui/UnreadIndicatorsTest.tsx @@ -439,11 +439,11 @@ describe('Unread Indicators', () => { expect(displayNameTexts).toHaveLength(2); const firstReportOption = displayNameTexts[0]; expect(firstReportOption?.props?.style?.fontWeight).toBe(FontUtils.fontWeight.bold); - expect(firstReportOption?.props?.children?.[0]).toBe('C User'); + expect(screen.getByText('C User')).toBeOnTheScreen(); const secondReportOption = displayNameTexts[1]; expect(secondReportOption?.props?.style?.fontWeight).toBe(FontUtils.fontWeight.bold); - expect(secondReportOption?.props?.children?.[0]).toBe('B User'); + expect(screen.getByText('B User')).toBeOnTheScreen(); // Tap the new report option and navigate back to the sidebar again via the back button return navigateToSidebarOption(0); @@ -456,9 +456,9 @@ describe('Unread Indicators', () => { const displayNameTexts = screen.queryAllByLabelText(hintText); expect(displayNameTexts).toHaveLength(2); expect(displayNameTexts[0]?.props?.style?.fontWeight).toBe(undefined); - expect(displayNameTexts[0]?.props?.children?.[0]).toBe('C User'); + expect(screen.getAllByText('C User')[0]).toBeOnTheScreen(); expect(displayNameTexts[1]?.props?.style?.fontWeight).toBe(FontUtils.fontWeight.bold); - expect(displayNameTexts[1]?.props?.children?.[0]).toBe('B User'); + expect(screen.getByText('B User')).toBeOnTheScreen(); })); xit('Manually marking a chat message as unread shows the new line indicator and updates the LHN', () => @@ -490,7 +490,7 @@ describe('Unread Indicators', () => { const displayNameTexts = screen.queryAllByLabelText(hintText); expect(displayNameTexts).toHaveLength(1); expect(displayNameTexts[0]?.props?.style?.fontWeight).toBe(FontUtils.fontWeight.bold); - expect(displayNameTexts[0]?.props?.children?.[0]).toBe('B User'); + expect(screen.getByText('B User')).toBeOnTheScreen(); // Navigate to the report again and back to the sidebar return navigateToSidebarOption(0); @@ -502,7 +502,7 @@ describe('Unread Indicators', () => { const displayNameTexts = screen.queryAllByLabelText(hintText); expect(displayNameTexts).toHaveLength(1); expect(displayNameTexts[0]?.props?.style?.fontWeight).toBe(undefined); - expect(displayNameTexts[0]?.props?.children?.[0]).toBe('B User'); + expect(screen.getByText('B User')).toBeOnTheScreen(); // Navigate to the report again and verify the new line indicator is missing return navigateToSidebarOption(0); @@ -615,7 +615,7 @@ describe('Unread Indicators', () => { const hintText = Localize.translateLocal('accessibilityHints.lastChatMessagePreview'); const alternateText = screen.queryAllByLabelText(hintText); expect(alternateText).toHaveLength(1); - expect(alternateText[0].props.children).toBe('Current User Comment 1'); + expect(screen.getByText('Current User Comment 1')).toBeOnTheScreen(); if (lastReportAction) { Report.deleteReportComment(REPORT_ID, lastReportAction); @@ -626,7 +626,7 @@ describe('Unread Indicators', () => { const hintText = Localize.translateLocal('accessibilityHints.lastChatMessagePreview'); const alternateText = screen.queryAllByLabelText(hintText); expect(alternateText).toHaveLength(1); - expect(alternateText[0].props.children).toBe('Comment 9'); + expect(screen.getAllByText('Comment 9')[0]).toBeOnTheScreen(); }) ); }); diff --git a/tests/unit/CalendarPickerTest.tsx b/tests/unit/CalendarPickerTest.tsx index 8beb02ec80c4..9c471be5b035 100644 --- a/tests/unit/CalendarPickerTest.tsx +++ b/tests/unit/CalendarPickerTest.tsx @@ -1,5 +1,5 @@ import type ReactNavigationNative from '@react-navigation/native'; -import {fireEvent, render, within} from '@testing-library/react-native'; +import {fireEvent, render, screen, within} from '@testing-library/react-native'; import {addMonths, addYears, subMonths, subYears} from 'date-fns'; import type {ComponentType} from 'react'; import CalendarPicker from '@components/DatePicker/CalendarPicker'; @@ -45,40 +45,40 @@ describe('CalendarPicker', () => { const currentDate = new Date(); const maxDate = addYears(new Date(currentDate), 1); const minDate = subYears(new Date(currentDate), 1); - const {getByText} = render( + render( , ); - expect(getByText(monthNames[currentDate.getMonth()])).toBeTruthy(); - expect(getByText(currentDate.getFullYear().toString())).toBeTruthy(); + expect(screen.getByText(monthNames[currentDate.getMonth()])).toBeTruthy(); + expect(screen.getByText(currentDate.getFullYear().toString())).toBeTruthy(); }); test('clicking next month arrow updates the displayed month', () => { const minDate = new Date('2022-01-01'); const maxDate = new Date('2030-01-01'); - const {getByTestId, getByText} = render( + render( , ); - fireEvent.press(getByTestId('next-month-arrow')); + fireEvent.press(screen.getByTestId('next-month-arrow')); const nextMonth = addMonths(new Date(), 1).getMonth(); - expect(getByText(monthNames[nextMonth])).toBeTruthy(); + expect(screen.getByText(monthNames[nextMonth])).toBeTruthy(); }); test('clicking previous month arrow updates the displayed month', () => { - const {getByTestId, getByText} = render(); + render(); - fireEvent.press(getByTestId('prev-month-arrow')); + fireEvent.press(screen.getByTestId('prev-month-arrow')); const prevMonth = subMonths(new Date(), 1).getMonth(); - expect(getByText(monthNames[prevMonth])).toBeTruthy(); + expect(screen.getByText(monthNames[prevMonth])).toBeTruthy(); }); test('clicking a day updates the selected date', () => { @@ -86,7 +86,7 @@ describe('CalendarPicker', () => { const minDate = new Date('2022-01-01'); const maxDate = new Date('2030-01-01'); const value = '2023-01-01'; - const {getByText} = render( + render( { />, ); - fireEvent.press(getByText('15')); + fireEvent.press(screen.getByText('15')); expect(onSelectedMock).toHaveBeenCalledWith('2023-01-15'); expect(onSelectedMock).toHaveBeenCalledTimes(1); @@ -106,7 +106,7 @@ describe('CalendarPicker', () => { const value = '2022-01-01'; const minDate = new Date('2022-01-01'); const maxDate = new Date('2030-01-01'); - const {getByText, getByTestId} = render( + render( { />, ); - fireEvent.press(getByTestId('next-month-arrow')); - fireEvent.press(getByText('15')); + fireEvent.press(screen.getByTestId('next-month-arrow')); + fireEvent.press(screen.getByText('15')); expect(onSelectedMock).toHaveBeenCalledWith('2022-02-15'); }); @@ -124,126 +124,126 @@ describe('CalendarPicker', () => { test('should block the back arrow when there is no available dates in the previous month', () => { const minDate = new Date('2003-02-01'); const value = new Date('2003-02-17'); - const {getByTestId} = render( + render( , ); - expect(getByTestId('prev-month-arrow')).toBeDisabled(); + expect(screen.getByTestId('prev-month-arrow')).toBeDisabled(); }); test('should block the next arrow when there is no available dates in the next month', () => { const maxDate = new Date('2003-02-24'); const value = '2003-02-17'; - const {getByTestId} = render( + render( , ); - expect(getByTestId('next-month-arrow')).toBeDisabled(); + expect(screen.getByTestId('next-month-arrow')).toBeDisabled(); }); test('should allow navigating to the month of the max date when it has less days than the selected date', () => { const maxDate = new Date('2003-11-27'); // This month has 30 days const value = '2003-10-31'; - const {getByTestId} = render( + render( , ); - expect(getByTestId('next-month-arrow')).not.toBeDisabled(); + expect(screen.getByTestId('next-month-arrow')).not.toBeDisabled(); }); test('should open the calendar on a month from max date if it is earlier than current month', () => { const onSelectedMock = jest.fn(); const maxDate = new Date('2011-03-01'); - const {getByText} = render( + render( , ); - fireEvent.press(getByText('1')); + fireEvent.press(screen.getByText('1')); expect(onSelectedMock).toHaveBeenCalledWith('2011-03-01'); }); test('should open the calendar on a year from max date if it is earlier than current year', () => { const maxDate = new Date('2011-03-01'); - const {getByTestId} = render(); + render(); - expect(within(getByTestId('currentYearText')).getByText('2011')).toBeTruthy(); + expect(within(screen.getByTestId('currentYearText')).getByText('2011')).toBeTruthy(); }); test('should open the calendar on a month from min date if it is later than current month', () => { const minDate = new Date('2035-02-16'); const maxDate = new Date('2040-02-16'); - const {getByTestId} = render( + render( , ); - expect(within(getByTestId('currentYearText')).getByText(minDate.getFullYear().toString())).toBeTruthy(); + expect(within(screen.getByTestId('currentYearText')).getByText(minDate.getFullYear().toString())).toBeTruthy(); }); test('should not allow to press earlier day than minDate', () => { const value = '2003-02-17'; const minDate = new Date('2003-02-16'); - const {getByLabelText} = render( + render( , ); - expect(getByLabelText('15')).toBeDisabled(); + expect(screen.getByLabelText('15')).toBeDisabled(); }); test('should not allow to press later day than max', () => { const value = '2003-02-17'; const maxDate = new Date('2003-02-24'); - const {getByLabelText} = render( + render( , ); - expect(getByLabelText('25')).toBeDisabled(); + expect(screen.getByLabelText('25')).toBeDisabled(); }); test('should allow to press min date', () => { const value = '2003-02-17'; const minDate = new Date('2003-02-16'); - const {getByLabelText} = render( + render( , ); - expect(getByLabelText('16')).not.toBeDisabled(); + expect(screen.getByLabelText('16')).not.toBeDisabled(); }); test('should allow to press max date', () => { const value = '2003-02-17'; const maxDate = new Date('2003-02-24'); - const {getByLabelText} = render( + render( , ); - expect(getByLabelText('24')).not.toBeDisabled(); + expect(screen.getByLabelText('24')).not.toBeDisabled(); }); }); diff --git a/tests/unit/ReportActionItemSingleTest.ts b/tests/unit/ReportActionItemSingleTest.ts index 74a0b5f24777..e0bf06be1609 100644 --- a/tests/unit/ReportActionItemSingleTest.ts +++ b/tests/unit/ReportActionItemSingleTest.ts @@ -1,4 +1,4 @@ -import {cleanup, screen, waitFor} from '@testing-library/react-native'; +import {screen, waitFor} from '@testing-library/react-native'; import Onyx from 'react-native-onyx'; import type {PersonalDetailsList} from '@src/types/onyx'; import {toCollectionDataSet} from '@src/types/utils/CollectionDataSet'; @@ -33,7 +33,6 @@ describe('ReportActionItemSingle', () => { // Clear out Onyx after each test so that each test starts with a clean slate afterEach(() => { - cleanup(); Onyx.clear(); }); @@ -54,11 +53,8 @@ describe('ReportActionItemSingle', () => { }, }; - beforeEach(() => { - LHNTestUtils.getDefaultRenderedReportActionItemSingle(shouldShowSubscriptAvatar, fakeReport, fakeReportAction); - }); - function setup() { + LHNTestUtils.getDefaultRenderedReportActionItemSingle(shouldShowSubscriptAvatar, fakeReport, fakeReportAction); const policyCollectionDataSet = toCollectionDataSet(ONYXKEYS.COLLECTION.POLICY, [fakePolicy], (item) => item.id); return waitForBatchedUpdates().then(() => @@ -70,13 +66,12 @@ describe('ReportActionItemSingle', () => { ); } - it('renders secondary Avatar properly', () => { + it('renders secondary Avatar properly', async () => { const expectedSecondaryIconTestId = 'SvgDefaultAvatar_w Icon'; - return setup().then(() => { - waitFor(() => { - expect(screen.getByTestId(expectedSecondaryIconTestId)).toBeDefined(); - }); + await setup(); + await waitFor(() => { + expect(screen.getByTestId(expectedSecondaryIconTestId)).toBeOnTheScreen(); }); }); @@ -84,7 +79,7 @@ describe('ReportActionItemSingle', () => { const [expectedPerson] = fakeReportAction.person ?? []; return setup().then(() => { - expect(screen.getByText(expectedPerson.text ?? '')).toBeDefined(); + expect(screen.getByText(expectedPerson.text ?? '')).toBeOnTheScreen(); }); }); }); diff --git a/tests/unit/SidebarFilterTest.ts b/tests/unit/SidebarFilterTest.ts index 3f8678fa8cf9..09ad1c379a09 100644 --- a/tests/unit/SidebarFilterTest.ts +++ b/tests/unit/SidebarFilterTest.ts @@ -1,4 +1,4 @@ -import {cleanup, screen} from '@testing-library/react-native'; +import {screen} from '@testing-library/react-native'; import Onyx from 'react-native-onyx'; import DateUtils from '@libs/DateUtils'; import * as Localize from '@libs/Localize'; @@ -45,11 +45,8 @@ xdescribe('Sidebar', () => { return Onyx.merge(ONYXKEYS.NETWORK, {isOffline: false}); }); - // Cleanup (ie. unmount) all rendered components and clear out Onyx after each test so that each test starts with a clean slate - afterEach(() => { - cleanup(); - return Onyx.clear(); - }); + // clear out Onyx after each test so that each test starts with a clean slate + afterEach(() => Onyx.clear()); describe('in default (most recent) mode', () => { it('excludes a report with no participants', () => { @@ -365,7 +362,7 @@ xdescribe('Sidebar', () => { const navigatesToChatHintText = Localize.translateLocal('accessibilityHints.navigatesToChat'); expect(screen.queryAllByAccessibilityHint(navigatesToChatHintText)).toHaveLength(1); expect(displayNames).toHaveLength(1); - expect(displayNames[0].props.children[0]).toBe('Three, Four'); + expect(screen.getByText('One, Two')).toBeOnTheScreen(); } else { // Both reports visible const navigatesToChatHintText = Localize.translateLocal('accessibilityHints.navigatesToChat'); @@ -410,8 +407,9 @@ xdescribe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(2); - expect(displayNames[0].props.children[0]).toBe('One, Two'); - expect(displayNames[1].props.children[0]).toBe('Three, Four'); + + expect(screen.getByText('One, Two')).toBeOnTheScreen(); + expect(screen.getByText('Three, Four')).toBeOnTheScreen(); }) // When report3 becomes unread @@ -484,8 +482,9 @@ xdescribe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(2); - expect(displayNames[0].props.children[0]).toBe('Three, Four'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); + + expect(screen.getByText('One, Two')).toBeOnTheScreen(); + expect(screen.getByText('Three, Four')).toBeOnTheScreen(); }) ); }); @@ -711,7 +710,7 @@ xdescribe('Sidebar', () => { const navigatesToChatHintText = Localize.translateLocal('accessibilityHints.navigatesToChat'); expect(screen.queryAllByAccessibilityHint(navigatesToChatHintText)).toHaveLength(1); expect(displayNames).toHaveLength(1); - expect(displayNames[0].props.children[0]).toBe('Three, Four'); + expect(screen.getByText('One, Two')).toBeOnTheScreen(); } else { // Both reports visible const navigatesToChatHintText = Localize.translateLocal('accessibilityHints.navigatesToChat'); diff --git a/tests/unit/SidebarOrderTest.ts b/tests/unit/SidebarOrderTest.ts index fd39d4efef65..644bba5a589b 100644 --- a/tests/unit/SidebarOrderTest.ts +++ b/tests/unit/SidebarOrderTest.ts @@ -1,4 +1,4 @@ -import {cleanup, screen} from '@testing-library/react-native'; +import {screen} from '@testing-library/react-native'; import Onyx from 'react-native-onyx'; import * as Report from '@libs/actions/Report'; import DateUtils from '@libs/DateUtils'; @@ -48,7 +48,6 @@ describe('Sidebar', () => { // Clear out Onyx after each test so that each test starts with a clean slate afterEach(() => { - cleanup(); Onyx.clear(); }); @@ -149,11 +148,11 @@ describe('Sidebar', () => { .then(() => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); - expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('Three, Four'); - expect(displayNames[2].props.children[0]).toBe('One, Two'); + + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('Three, Four'); + expect(displayNames[2]).toHaveTextContent('One, Two'); }) ); }); @@ -204,9 +203,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('One, Two'); // this has `hasDraft` flag enabled so it will be on top - expect(displayNames[1].props.children[0]).toBe('Five, Six'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('One, Two'); // this has `hasDraft` flag enabled so it will be on top + expect(displayNames[1]).toHaveTextContent('Five, Six'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); }) ); }); @@ -255,9 +254,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('One, Two'); - expect(displayNames[1].props.children[0]).toBe('Five, Six'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('One, Two'); + expect(displayNames[1]).toHaveTextContent('Five, Six'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); }) ); }); @@ -309,10 +308,10 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(4); - expect(displayNames[0].props.children[0]).toBe(taskReportName); - expect(displayNames[1].props.children[0]).toBe('Five, Six'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); - expect(displayNames[3].props.children[0]).toBe('One, Two'); + expect(displayNames[0]).toHaveTextContent(taskReportName); + expect(displayNames[1]).toHaveTextContent('Five, Six'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); + expect(displayNames[3]).toHaveTextContent('One, Two'); }) ); }); @@ -373,10 +372,10 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(4); - expect(displayNames[0].props.children[0]).toBe('Email Two owes $100.00'); - expect(displayNames[1].props.children[0]).toBe('Five, Six'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); - expect(displayNames[3].props.children[0]).toBe('One, Two'); + expect(displayNames[0]).toHaveTextContent('Email Two owes $100.00'); + expect(displayNames[1]).toHaveTextContent('Five, Six'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); + expect(displayNames[3]).toHaveTextContent('One, Two'); }) ); }); @@ -441,10 +440,10 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(4); - expect(displayNames[0].props.children[0]).toBe('Workspace owes $100.00'); - expect(displayNames[1].props.children[0]).toBe('Email Five'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); - expect(displayNames[3].props.children[0]).toBe('One, Two'); + expect(displayNames[0]).toHaveTextContent('Workspace owes $100.00'); + expect(displayNames[1]).toHaveTextContent('Email Five'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); + expect(displayNames[3]).toHaveTextContent('One, Two'); }) ); }); @@ -500,9 +499,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('Three, Four'); - expect(displayNames[1].props.children[0]).toBe('Five, Six'); - expect(displayNames[2].props.children[0]).toBe('One, Two'); + expect(displayNames[0]).toHaveTextContent('Three, Four'); + expect(displayNames[1]).toHaveTextContent('Five, Six'); + expect(displayNames[2]).toHaveTextContent('One, Two'); }) ); }); @@ -657,9 +656,9 @@ describe('Sidebar', () => { expect(displayNames).toHaveLength(3); expect(screen.queryAllByTestId('Pin Icon')).toHaveLength(1); expect(screen.queryAllByTestId('Pencil Icon')).toHaveLength(1); - expect(displayNames[0].props.children[0]).toBe('Email Two owes $100.00'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('Email Two owes $100.00'); + expect(displayNames[1]).toHaveTextContent('One, Two'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); }) ); }); @@ -709,9 +708,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('One, Two'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); }) // When a new report is added @@ -722,10 +721,10 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(4); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); - expect(displayNames[2].props.children[0]).toBe('Seven, Eight'); - expect(displayNames[3].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('One, Two'); + expect(displayNames[2]).toHaveTextContent('Seven, Eight'); + expect(displayNames[3]).toHaveTextContent('Three, Four'); }) ); }); @@ -778,9 +777,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('One, Two'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); }) // When a new report is added @@ -798,10 +797,10 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(4); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); - expect(displayNames[2].props.children[0]).toBe('Seven, Eight'); - expect(displayNames[3].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('One, Two'); + expect(displayNames[2]).toHaveTextContent('Seven, Eight'); + expect(displayNames[3]).toHaveTextContent('Three, Four'); }) ); }); @@ -851,9 +850,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('Three, Four'); - expect(displayNames[2].props.children[0]).toBe('Report (archived)'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('Three, Four'); + expect(displayNames[2]).toHaveTextContent('Report (archived)'); }) ); }); @@ -892,9 +891,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('One, Two'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); }) // When a new report is added @@ -905,10 +904,10 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(4); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); - expect(displayNames[2].props.children[0]).toBe('Seven, Eight'); - expect(displayNames[3].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('One, Two'); + expect(displayNames[2]).toHaveTextContent('Seven, Eight'); + expect(displayNames[3]).toHaveTextContent('Three, Four'); }) ); }); @@ -953,9 +952,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('Three, Four'); - expect(displayNames[2].props.children[0]).toBe('Report (archived)'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('Three, Four'); + expect(displayNames[2]).toHaveTextContent('Report (archived)'); }) ); }); @@ -1094,11 +1093,11 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(5); - expect(displayNames[0].props.children[0]).toBe('Email Five owes $100.00'); - expect(displayNames[1].props.children[0]).toBe('Email Four owes $1,000.00'); - expect(displayNames[2].props.children[0]).toBe('Email Six owes $100.00'); - expect(displayNames[3].props.children[0]).toBe('Email Three owes $100.00'); - expect(displayNames[4].props.children[0]).toBe('Email Two owes $100.00'); + expect(displayNames[0]).toHaveTextContent('Email Five owes $100.00'); + expect(displayNames[1]).toHaveTextContent('Email Four owes $1,000.00'); + expect(displayNames[2]).toHaveTextContent('Email Six owes $100.00'); + expect(displayNames[3]).toHaveTextContent('Email Three owes $100.00'); + expect(displayNames[4]).toHaveTextContent('Email Two owes $100.00'); }) ); }); @@ -1149,9 +1148,9 @@ describe('Sidebar', () => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); expect(displayNames).toHaveLength(3); - expect(displayNames[0].props.children[0]).toBe('Five, Six'); - expect(displayNames[1].props.children[0]).toBe('One, Two'); - expect(displayNames[2].props.children[0]).toBe('Three, Four'); + expect(displayNames[0]).toHaveTextContent('Five, Six'); + expect(displayNames[1]).toHaveTextContent('One, Two'); + expect(displayNames[2]).toHaveTextContent('Three, Four'); }) ); }); diff --git a/tests/unit/SidebarTest.ts b/tests/unit/SidebarTest.ts index 23ea0d377634..c037c1ced3f0 100644 --- a/tests/unit/SidebarTest.ts +++ b/tests/unit/SidebarTest.ts @@ -1,4 +1,4 @@ -import {cleanup, screen} from '@testing-library/react-native'; +import {screen} from '@testing-library/react-native'; import Onyx from 'react-native-onyx'; import CONST from '@src/CONST'; import * as Localize from '@src/libs/Localize'; @@ -31,7 +31,6 @@ describe('Sidebar', () => { // Clear out Onyx after each test so that each test starts with a clean slate afterEach(() => { - cleanup(); Onyx.clear(); }); @@ -79,11 +78,11 @@ describe('Sidebar', () => { .then(() => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); - expect(displayNames[0].props.children[0]).toBe('Report (archived)'); + expect(displayNames[0]).toHaveTextContent('Report (archived)'); const hintMessagePreviewText = Localize.translateLocal('accessibilityHints.lastChatMessagePreview'); const messagePreviewTexts = screen.queryAllByLabelText(hintMessagePreviewText); - expect(messagePreviewTexts[0].props.children).toBe('This chat room has been archived.'); + expect(messagePreviewTexts[0]).toHaveTextContent('This chat room has been archived.'); }) ); }); @@ -131,11 +130,11 @@ describe('Sidebar', () => { .then(() => { const hintText = Localize.translateLocal('accessibilityHints.chatUserDisplayNames'); const displayNames = screen.queryAllByLabelText(hintText); - expect(displayNames[0].props.children[0]).toBe('Report (archived)'); + expect(displayNames[0]).toHaveTextContent('Report (archived)'); const hintMessagePreviewText = Localize.translateLocal('accessibilityHints.lastChatMessagePreview'); const messagePreviewTexts = screen.queryAllByLabelText(hintMessagePreviewText); - expect(messagePreviewTexts[0].props.children).toBe('This chat is no longer active because Vikings Policy is no longer an active workspace.'); + expect(messagePreviewTexts[0]).toHaveTextContent('This chat is no longer active because Vikings Policy is no longer an active workspace.'); }) ); });