Skip to content

Commit

Permalink
Block Editor: Refactor BlockControls tests to `@testing-library/rea…
Browse files Browse the repository at this point in the history
…ct` (#44122)
  • Loading branch information
tyxla authored Sep 14, 2022
1 parent 9a345b7 commit 7137b14
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 72 deletions.

This file was deleted.

92 changes: 84 additions & 8 deletions packages/block-editor/src/components/block-controls/test/index.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,17 @@
/**
* External dependencies
*/
import { shallow } from 'enzyme';
import { render, screen } from '@testing-library/react';

/**
* WordPress dependencies
*/
import {
registerBlockType,
unregisterBlockType,
getBlockTypes,
} from '@wordpress/blocks';
import { SlotFillProvider, ToolbarGroup } from '@wordpress/components';
import { alignCenter, alignLeft, alignRight } from '@wordpress/icons';

/**
Expand Down Expand Up @@ -33,15 +39,85 @@ describe( 'BlockControls', () => {
},
];

beforeEach( () => {
const edit = ( { children } ) => <>{ children }</>;

registerBlockType( 'core/test-block', {
save: () => {},
category: 'text',
title: 'block title',
edit,
} );
} );

afterEach( () => {
getBlockTypes().forEach( ( block ) => {
unregisterBlockType( block.name );
} );
} );

it( 'should render a dynamic toolbar of controls', () => {
const wrapper = shallow(
<BlockEdit isSelected>
<BlockControls controls={ controls }>
<p>Child</p>
</BlockControls>
</BlockEdit>
render(
<SlotFillProvider>
<BlockEdit name="core/test-block" isSelected>
<BlockControls controls={ controls }>
<p>Child</p>
</BlockControls>
</BlockEdit>
<BlockControls.Slot />
</SlotFillProvider>
);

expect( wrapper ).toMatchSnapshot();
expect(
screen.getAllByRole( 'button', { name: /^Align [\w]+/ } )
).toHaveLength( controls.length );

controls.forEach( ( { title, align } ) => {
const control = screen.getByRole( 'button', {
name: title,
} );
expect( control ).toBeVisible();
expect( control ).toHaveAttribute( 'align', align );
} );
} );

it( 'should render its children', () => {
render(
<SlotFillProvider>
<BlockEdit name="core/test-block" isSelected>
<BlockControls controls={ controls }>
<p>Child</p>
</BlockControls>
</BlockEdit>
<BlockControls.Slot />
</SlotFillProvider>
);

expect( screen.getByText( 'Child' ) ).toBeVisible();
} );

it( 'should a dynamic toolbar when passed as children', () => {
render(
<SlotFillProvider>
<BlockEdit name="core/test-block" isSelected>
<BlockControls>
<ToolbarGroup controls={ controls } />
</BlockControls>
</BlockEdit>
<BlockControls.Slot />
</SlotFillProvider>
);

expect(
screen.getAllByRole( 'button', { name: /^Align [\w]+/ } )
).toHaveLength( controls.length );

controls.forEach( ( { title, align } ) => {
const control = screen.getByRole( 'button', {
name: title,
} );
expect( control ).toBeVisible();
expect( control ).toHaveAttribute( 'align', align );
} );
} );
} );

0 comments on commit 7137b14

Please sign in to comment.