From ea247dcb3119bd0cccc4d512029bcafc2e28c3b3 Mon Sep 17 00:00:00 2001 From: Miroslav Mitev Date: Tue, 5 Nov 2024 17:56:05 +0200 Subject: [PATCH] Fix tests --- assets/admin/editor-wizard/helpers.test.js | 2 +- .../student-bulk-action-button/index.test.js | 14 +++++++------ .../use-confirm-dialog-props.test.js | 18 +++++++--------- .../single-line-input.test.js | 21 +++++++++++++++---- 4 files changed, 34 insertions(+), 21 deletions(-) diff --git a/assets/admin/editor-wizard/helpers.test.js b/assets/admin/editor-wizard/helpers.test.js index a3ea9d4817..0016318d60 100644 --- a/assets/admin/editor-wizard/helpers.test.js +++ b/assets/admin/editor-wizard/helpers.test.js @@ -116,7 +116,7 @@ describe( 'useWizardOpenState', () => { expect( await findByText( 'closed' ) ).toBeTruthy(); document.body.classList.remove( 'modal-open' ); - expect( findByText( 'open' ) ).toBeTruthy(); + expect( await findByText( 'open' ) ).toBeTruthy(); } ); it( 'Should be closed when wizard is done', async () => { diff --git a/assets/admin/students/student-bulk-action-button/index.test.js b/assets/admin/students/student-bulk-action-button/index.test.js index bd67f64f1a..080bc313f9 100644 --- a/assets/admin/students/student-bulk-action-button/index.test.js +++ b/assets/admin/students/student-bulk-action-button/index.test.js @@ -62,7 +62,7 @@ describe( '', () => { expect( button ).toBeDisabled(); } ); - it( 'Should render the `Add to course` modal', () => { + it( 'Should render the `Add to course` modal', async () => { setupSelector( [ { value: 'enrol_restore_enrolment', selected: true }, { value: 'remove_progress' }, @@ -70,7 +70,8 @@ describe( '', () => { ] ); render( ); - selectActionButton().click(); + await selectActionButton().click(); + expect( screen.getByText( ignoreInlineTags( @@ -80,7 +81,7 @@ describe( '', () => { ).toBeInTheDocument(); } ); - it( 'Should render the `Reset Progress` modal', () => { + it( 'Should render the `Reset Progress` modal', async () => { setupSelector( [ { value: 'enrol_restore_enrolment' }, { value: 'remove_progress', selected: true }, @@ -88,7 +89,7 @@ describe( '', () => { ] ); render( ); - selectActionButton().click(); + await selectActionButton().click(); expect( screen.getByText( @@ -98,7 +99,7 @@ describe( '', () => { ) ).toBeInTheDocument(); } ); - it( 'Should render the `Remove from Course` modal', () => { + it( 'Should render the `Remove from Course` modal', async () => { setupSelector( [ { value: 'enrol_restore_enrolment' }, { value: 'remove_progress' }, @@ -106,7 +107,8 @@ describe( '', () => { ] ); render( ); - selectActionButton().click(); + await selectActionButton().click(); + expect( screen.getByText( ignoreInlineTags( diff --git a/assets/blocks/editor-components/confirm-dialog/use-confirm-dialog-props.test.js b/assets/blocks/editor-components/confirm-dialog/use-confirm-dialog-props.test.js index 9051118b1e..a8c4553534 100644 --- a/assets/blocks/editor-components/confirm-dialog/use-confirm-dialog-props.test.js +++ b/assets/blocks/editor-components/confirm-dialog/use-confirm-dialog-props.test.js @@ -34,16 +34,15 @@ describe( 'useConfirmDialogProps()', () => { const { result } = renderHook( () => useConfirmDialogProps() ); let [ props, confirm ] = result.current; expect( props.isOpen ).toBe( false ); - const confirmResponse = act( () => + act( () => { + // eslint-disable-next-line jest/valid-expect expect( confirm( 'Hey Content', { title: 'Hey Title' } ) - ).resolves.toBe( true ) - ); + ).resolves.toBe( true ); + } ); [ props, confirm ] = result.current; expect( props.isOpen ).toBe( true ); act( () => props.onConfirm() ); - // We need to verify AFTER calling the props.on* callback, otherwise, the promise won't be resolved yet. - await confirmResponse; [ props, confirm ] = result.current; expect( props.isOpen ).toBe( false ); } ); @@ -52,16 +51,15 @@ describe( 'useConfirmDialogProps()', () => { const { result } = renderHook( () => useConfirmDialogProps() ); let [ props, confirm ] = result.current; expect( props.isOpen ).toBe( false ); - const confirmResponse = act( () => + act( () => { + // eslint-disable-next-line jest/valid-expect expect( confirm( 'Hey Content', { title: 'Hey Title' } ) - ).resolves.toBe( false ) - ); + ).resolves.toBe( false ); + } ); [ props, confirm ] = result.current; expect( props.isOpen ).toBe( true ); act( () => props.onCancel() ); - // We need to verify AFTER calling the props.on* callback, otherwise, the promise won't be resolved yet. - await confirmResponse; [ props, confirm ] = result.current; expect( props.isOpen ).toBe( false ); } ); diff --git a/assets/shared/blocks/single-line-input/single-line-input.test.js b/assets/shared/blocks/single-line-input/single-line-input.test.js index bcb24183fa..00ed020696 100644 --- a/assets/shared/blocks/single-line-input/single-line-input.test.js +++ b/assets/shared/blocks/single-line-input/single-line-input.test.js @@ -4,6 +4,11 @@ import { render, fireEvent } from '@testing-library/react'; import userEvent from '@testing-library/user-event'; +/** + * WordPress dependencies + */ +import { BACKSPACE, ENTER } from '@wordpress/keycodes'; + /** * Internal dependencies */ @@ -49,7 +54,7 @@ describe( '', () => { expect( onChangeMock ).toHaveBeenLastCalledWith( 'input line' ); } ); - it( 'Calls onRemove on backspace with an empty title', async () => { + it( 'Calls onRemove on backspace with an empty title', () => { const onRemoveMock = jest.fn(); const { getByRole } = render( ', () => { /> ); - await userEvent.type( getByRole( 'textbox' ), '{backspace}' ); + fireEvent.keyDown( getByRole( 'textbox' ), { + key: 'Backspace', + code: 'Backspace', + keyCode: BACKSPACE, + } ); expect( onRemoveMock ).toHaveBeenCalledTimes( 1 ); } ); - it( 'Calls onEnter on enter', async () => { + it( 'Calls onEnter on enter', () => { const onEnterMock = jest.fn(); const { getByRole } = render( ); - await userEvent.type( getByRole( 'textbox' ), 'Title{enter}' ); + fireEvent.keyDown( getByRole( 'textbox' ), { + key: 'Enter', + code: 'Enter', + keyCode: ENTER, + } ); expect( onEnterMock ).toHaveBeenCalledTimes( 1 ); } );