Skip to content

Commit

Permalink
Fix JS unit tests
Browse files Browse the repository at this point in the history
  • Loading branch information
m1r0 committed Nov 6, 2024
1 parent 5c7e889 commit ab5f7be
Show file tree
Hide file tree
Showing 5 changed files with 48 additions and 33 deletions.
2 changes: 1 addition & 1 deletion assets/admin/editor-wizard/helpers.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -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 () => {
Expand Down
14 changes: 8 additions & 6 deletions assets/admin/students/student-bulk-action-button/index.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -62,15 +62,16 @@ describe( '<StudentBulkActionButton />', () => {
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' },
{ value: 'remove_enrolment' },
] );
render( <StudentBulkActionButton isDisabled={ false } /> );

selectActionButton().click();
await selectActionButton().click();

expect(
screen.getByText(
ignoreInlineTags(
Expand All @@ -80,15 +81,15 @@ describe( '<StudentBulkActionButton />', () => {
).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 },
{ value: 'remove_enrolment' },
] );
render( <StudentBulkActionButton isDisabled={ false } /> );

selectActionButton().click();
await selectActionButton().click();

expect(
screen.getByText(
Expand All @@ -98,15 +99,16 @@ describe( '<StudentBulkActionButton />', () => {
)
).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' },
{ value: 'remove_enrolment', selected: true },
] );
render( <StudentBulkActionButton isDisabled={ false } /> );

selectActionButton().click();
await selectActionButton().click();

expect(
screen.getByText(
ignoreInlineTags(
Expand Down
26 changes: 14 additions & 12 deletions assets/admin/students/student-modal/index.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -337,14 +337,14 @@ describe( '<StudentModal />', () => {
/>
);

fireEvent.click( await courseOptionAt( 0 ) );
fireEvent.click( await buttonByLabel( 'Add to Course' ) );
await fireEvent.click( await courseOptionAt( 0 ) );
await fireEvent.click( await buttonByLabel( 'Add to Course' ) );

expect(
await findAllByText(
'Unable to add student. Please try again.'
)
).toHaveLength( 2 ); // ARIA + notice
).toBeTruthy();
} );

it( 'Should display an error message when removing a student from a course', async () => {
Expand All @@ -363,7 +363,7 @@ describe( '<StudentModal />', () => {
await findAllByText(
'Unable to remove student. Please try again.'
)
).toHaveLength( 2 ); // ARIA + notice
).toBeTruthy();
} );

it( 'Should display an error message when resetting progress for a single student', async () => {
Expand All @@ -383,7 +383,7 @@ describe( '<StudentModal />', () => {
await findAllByText(
'Unable to reset progress for this student. Please try again.'
)
).toHaveLength( 2 ); // ARIA + notice
).toBeTruthy();
} );
} );

Expand Down Expand Up @@ -437,14 +437,14 @@ describe( '<StudentModal />', () => {
/>
);

fireEvent.click( await courseOptionAt( 0 ) );
fireEvent.click( await buttonByLabel( 'Add to Course' ) );
await fireEvent.click( await courseOptionAt( 0 ) );
await fireEvent.click( await buttonByLabel( 'Add to Course' ) );

expect(
await findAllByText(
'Unable to add students. Please try again.'
)
).toHaveLength( 2 ); // ARIA + notice
).toBeTruthy();
} );

it( 'Should display an error message when removing multiple students from a course', async () => {
Expand All @@ -456,14 +456,16 @@ describe( '<StudentModal />', () => {
/>
);

fireEvent.click( await courseOptionAt( 0 ) );
fireEvent.click( await buttonByLabel( 'Remove from Course' ) );
await fireEvent.click( await courseOptionAt( 0 ) );
await fireEvent.click(
await buttonByLabel( 'Remove from Course' )
);

expect(
await findAllByText(
'Unable to remove students. Please try again.'
)
).toHaveLength( 2 ); // ARIA + notice
).toBeTruthy();
} );

it( 'Should display an error message when resetting progress for multiple students', async () => {
Expand All @@ -482,7 +484,7 @@ describe( '<StudentModal />', () => {
await findAllByText(
'Unable to reset progress for these students. Please try again.'
)
).toHaveLength( 2 ); // ARIA + notice
).toBeTruthy();
} );
} );
} );
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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 );
} );
Expand All @@ -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 );
} );
Expand Down
21 changes: 17 additions & 4 deletions assets/shared/blocks/single-line-input/single-line-input.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -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
*/
Expand Down Expand Up @@ -49,7 +54,7 @@ describe( '<SingleLineInput />', () => {
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(
<SingleLineInput
Expand All @@ -59,18 +64,26 @@ describe( '<SingleLineInput />', () => {
/>
);

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(
<SingleLineInput onEnter={ onEnterMock } onChange={ jest.fn() } />
);

await userEvent.type( getByRole( 'textbox' ), 'Title{enter}' );
fireEvent.keyDown( getByRole( 'textbox' ), {
key: 'Enter',
code: 'Enter',
keyCode: ENTER,
} );

expect( onEnterMock ).toHaveBeenCalledTimes( 1 );
} );
Expand Down

0 comments on commit ab5f7be

Please sign in to comment.