Skip to content

Commit

Permalink
WIP: Migrate draggable block tests to Playwright (#43798)
Browse files Browse the repository at this point in the history
* WIP

* Get the first draggable test to work in Playwright

* Try adding remaining test

* Move mouse in addition to hovering

* Set the viewport size

* Fix the tests

* Make sure to focus on the correct paragraph block

* Set viewport in test.use

* Try steps

* Remove puppeteer test

Co-authored-by: Kai Hao <kai@kaihao.dev>
Co-authored-by: Daniel Richards <daniel.richards@automattic.com>
  • Loading branch information
3 people authored Sep 7, 2022
1 parent 0f20196 commit 5c2bc87
Show file tree
Hide file tree
Showing 5 changed files with 161 additions and 170 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,10 @@ import BlockIcon from '../block-icon';
export default function BlockDraggableChip( { count, icon } ) {
return (
<div className="block-editor-block-draggable-chip-wrapper">
<div className="block-editor-block-draggable-chip">
<div
className="block-editor-block-draggable-chip"
data-testid="block-draggable-chip"
>
<Flex
justify="center"
className="block-editor-block-draggable-chip__content"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,7 @@ function InsertionPointPopover( {
<motion.div
variants={ lineVariants }
className="block-editor-block-list__insertion-point-indicator"
data-testid="block-list-insertion-point-indicator"
/>
{ isInserterShown && (
<motion.div
Expand Down

This file was deleted.

128 changes: 0 additions & 128 deletions packages/e2e-tests/specs/editor/various/draggable-block.test.js

This file was deleted.

156 changes: 156 additions & 0 deletions test/e2e/specs/editor/various/draggable-blocks.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,156 @@
/**
* WordPress dependencies
*/
const { test, expect } = require( '@wordpress/e2e-test-utils-playwright' );

test.use( {
// Make the viewport large enough so that a scrollbar isn't displayed.
// Otherwise, the page scrolling can interfere with the test runner's
// ability to drop a block in the right location.
viewport: {
width: 960,
height: 1024,
},
} );

test.describe( 'Draggable block', () => {
test.beforeEach( async ( { admin } ) => {
await admin.createNewPost();
} );

test( 'can drag and drop to the top of a block list', async ( {
editor,
page,
} ) => {
await page.keyboard.press( 'Enter' );
await page.keyboard.type( '1' );
await page.keyboard.press( 'Enter' );
await page.keyboard.type( '2' );

// Confirm correct setup.
await expect.poll( editor.getEditedPostContent )
.toBe( `<!-- wp:paragraph -->
<p>1</p>
<!-- /wp:paragraph -->
<!-- wp:paragraph -->
<p>2</p>
<!-- /wp:paragraph -->` );

await page.focus( 'role=document[name="Paragraph block"i] >> text=2' );
await editor.showBlockToolbar();

const dragHandle = page.locator(
'role=toolbar[name="Block tools"i] >> role=button[name="Drag"i][include-hidden]'
);
// Hover to the center of the drag handle.
await dragHandle.hover();
// Start dragging.
await page.mouse.down();

// Move to and hover on the upper half of the paragraph block to trigger the indicator.
const firstParagraph = page.locator(
'role=document[name="Paragraph block"i] >> text=1'
);
const firstParagraphBound = await firstParagraph.boundingBox();
await page.mouse.move( firstParagraphBound.x, firstParagraphBound.y, {
steps: 10,
} );

await expect(
page.locator( 'data-testid=block-draggable-chip >> visible=true' )
).toBeVisible();

const indicator = page.locator(
'data-testid=block-list-insertion-point-indicator'
);
await expect( indicator ).toBeVisible();
// Expect the indicator to be above the first paragraph.
await expect
.poll( () => indicator.boundingBox().then( ( { y } ) => y ) )
.toBeLessThan( firstParagraphBound.y );

// Drop the paragraph block.
await page.mouse.up();

await expect.poll( editor.getEditedPostContent )
.toBe( `<!-- wp:paragraph -->
<p>2</p>
<!-- /wp:paragraph -->
<!-- wp:paragraph -->
<p>1</p>
<!-- /wp:paragraph -->` );
} );

test( 'can drag and drop to the bottom of a block list', async ( {
editor,
page,
} ) => {
await page.keyboard.press( 'Enter' );
await page.keyboard.type( '1' );
await page.keyboard.press( 'Enter' );
await page.keyboard.type( '2' );

// Confirm correct setup.
await expect.poll( editor.getEditedPostContent )
.toBe( `<!-- wp:paragraph -->
<p>1</p>
<!-- /wp:paragraph -->
<!-- wp:paragraph -->
<p>2</p>
<!-- /wp:paragraph -->` );

await page.focus( 'role=document[name="Paragraph block"i] >> text=1' );
await editor.showBlockToolbar();

const dragHandle = page.locator(
'role=toolbar[name="Block tools"i] >> role=button[name="Drag"i][include-hidden]'
);
// Hover to the center of the drag handle.
await dragHandle.hover();
// Start dragging.
await page.mouse.down();

// Move to and hover on the bottom half of the paragraph block to trigger the indicator.
const secondParagraph = page.locator(
'role=document[name="Paragraph block"i] >> text=2'
);
const secondParagraphBound = await secondParagraph.boundingBox();
await page.mouse.move(
secondParagraphBound.x,
secondParagraphBound.y + secondParagraphBound.height * 0.75,
{ steps: 10 }
);

await expect(
page.locator( 'data-testid=block-draggable-chip >> visible=true' )
).toBeVisible();

const indicator = page.locator(
'data-testid=block-list-insertion-point-indicator'
);
await expect( indicator ).toBeVisible();
// Expect the indicator to be below the second paragraph.
await expect
.poll( () =>
indicator.boundingBox().then( ( { y, height } ) => y + height )
)
.toBeGreaterThan(
secondParagraphBound.y + secondParagraphBound.height
);

// Drop the paragraph block.
await page.mouse.up();

await expect.poll( editor.getEditedPostContent )
.toBe( `<!-- wp:paragraph -->
<p>2</p>
<!-- /wp:paragraph -->
<!-- wp:paragraph -->
<p>1</p>
<!-- /wp:paragraph -->` );
} );
} );

0 comments on commit 5c2bc87

Please sign in to comment.