Skip to content

Commit

Permalink
Testing: Create new selectAll, selectAllBlocks utilities
Browse files Browse the repository at this point in the history
  • Loading branch information
aduth committed Apr 3, 2019
1 parent 3b91b6a commit fbff4a4
Show file tree
Hide file tree
Showing 9 changed files with 67 additions and 25 deletions.
8 changes: 8 additions & 0 deletions packages/e2e-test-utils/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -377,6 +377,14 @@ _Parameters_

- _searchTerm_ `string`: The text to search the inserter for.

<a name="selectAllBlocks" href="#selectAllBlocks">#</a> **selectAllBlocks**

Selects all blocks present in the block editor.

_Returns_

- `Promise`: Promise resolving once active element selected.

<a name="selectBlockByClientId" href="#selectBlockByClientId">#</a> **selectBlockByClientId**

Given the clientId of a block, selects the block on the editor.
Expand Down
2 changes: 2 additions & 0 deletions packages/e2e-test-utils/src/index.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
export { __unstableSelectAll } from './select-all';
export { activatePlugin } from './activate-plugin';
export { arePrePublishChecksEnabled } from './are-pre-publish-checks-enabled';
export { clearLocalStorage } from './clear-local-storage';
Expand Down Expand Up @@ -37,6 +38,7 @@ export { publishPost } from './publish-post';
export { publishPostWithPrePublishChecksDisabled } from './publish-post-with-pre-publish-checks-disabled';
export { saveDraft } from './save-draft';
export { searchForBlock } from './search-for-block';
export { selectAllBlocks } from './select-all-blocks';
export { selectBlockByClientId } from './select-block-by-client-id';
export { setBrowserViewport } from './set-browser-viewport';
export { setPostContent } from './set-post-content';
Expand Down
17 changes: 7 additions & 10 deletions packages/e2e-test-utils/src/login-user.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import { WP_USERNAME, WP_PASSWORD } from './shared/config';
import { createURL } from './create-url';
import { isCurrentURL } from './is-current-url';
import { __unstableSelectAll } from './select-all';

/**
* Performs log in with specified username and password.
Expand All @@ -18,16 +19,12 @@ export async function loginUser( username = WP_USERNAME, password = WP_PASSWORD
);
}

// Explicitly assign values of form, since the username is prefilled if
// already logged in. This could be done by keyboard interactions as well,
// but as of Puppeteer 1.6.1, Cmd+A does not work as expected in Mac,
// making it difficult to erase the contents of the field.
//
// See: https://github.com/GoogleChrome/puppeteer/issues/1313
await page.evaluate( ( _username, _password ) => {
document.getElementById( 'user_login' ).value = _username;
document.getElementById( 'user_pass' ).value = _password;
}, username, password );
await page.focus( '#user_login' );
await __unstableSelectAll();
await page.type( '#user_login', username );
await page.focus( '#user_pass' );
await __unstableSelectAll();
await page.type( '#user_pass', password );

await Promise.all( [ page.waitForNavigation(), page.click( '#wp-submit' ) ] );
}
19 changes: 19 additions & 0 deletions packages/e2e-test-utils/src/select-all-blocks.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
/**
* Internal dependencies
*/
import { pressKeyWithModifier } from './press-key-with-modifier';
import { __unstableSelectAll } from './select-all';

/**
* Selects all blocks present in the block editor.
*
* @return {Promise} Promise resolving once active element selected.
*/
export async function selectAllBlocks() {
// NOTE: `__unstableSelectAll` is used for cross-platform compatibility
// alternative to Cmd+A. The second issuance of the key combination is
// handled internerally by the block editor's KeyboardShortcuts utility,
// and is not subject to the same buggy browser/OS emulation.
await __unstableSelectAll();
await pressKeyWithModifier( 'primary', 'a' );
}
15 changes: 15 additions & 0 deletions packages/e2e-test-utils/src/select-all.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
/**
* Selects all text within the current active element field. Throws if there is
* no active element.
*
* This serves as a temporary solution to a bug present as of Puppeteer 1.6.1
* in which the Cmd+A keyboard combination does not work correctly in macOS
* environments. Once the bug is resolved, the utility will be removed.
*
* @link https://github.com/GoogleChrome/puppeteer/issues/1313
*
* @return {Promise} Promise resolving once active element selected.
*/
export async function __unstableSelectAll() {
await page.evaluate( () => document.execCommand( 'selectall', false, null ) );
}
8 changes: 3 additions & 5 deletions packages/e2e-tests/specs/block-hierarchy-navigation.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import {
getEditedPostContent,
pressKeyTimes,
pressKeyWithModifier,
__unstableSelectAll,
} from '@wordpress/e2e-test-utils';

async function openBlockNavigator() {
Expand Down Expand Up @@ -98,11 +99,8 @@ describe( 'Navigating the block hierarchy', () => {
await openBlockNavigator();
await page.keyboard.press( 'Space' );

// Replace its content
// note Cmd/Ctrl + A doesn't work on Mac with Pupetter right now
// https://github.com/GoogleChrome/puppeteer/issues/1313
await pressKeyTimes( 'ArrowRight', textString.length );
await pressKeyTimes( 'Backspace', textString.length );
// Replace its content.
await __unstableSelectAll();
await page.keyboard.type( 'and I say hello' );

expect( await getEditedPostContent() ).toMatchSnapshot();
Expand Down
13 changes: 8 additions & 5 deletions packages/e2e-tests/specs/multi-block-selection.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ import {
pressKeyWithModifier,
pressKeyTimes,
getEditedPostContent,
selectAllBlocks,
__unstableSelectAll,
} from '@wordpress/e2e-test-utils';

describe( 'Multi-block selection', () => {
Expand Down Expand Up @@ -74,7 +76,11 @@ describe( 'Multi-block selection', () => {

// Select all via double shortcut.
await page.click( firstBlockSelector );
await pressKeyWithModifier( 'primary', 'a' );
// NOTE: `__unstableSelectAll` is used for cross-platform compatibility
// alternative to Cmd+A. The second issuance of the key combination is
// handled internerally by the block editor's KeyboardShortcuts utility
// and is not subject to the same buggy emulation.
await __unstableSelectAll();
await pressKeyWithModifier( 'primary', 'a' );
await expectMultiSelected( blocks, true );
} );
Expand Down Expand Up @@ -126,10 +132,7 @@ describe( 'Multi-block selection', () => {
await page.keyboard.type( 'Second Paragraph' );
await insertBlock( 'Paragraph' );
await page.keyboard.type( 'Third Paragraph' );

// Multiselect via keyboard.
await pressKeyWithModifier( 'primary', 'a' );
await pressKeyWithModifier( 'primary', 'a' );
await selectAllBlocks();

// TODO: It would be great to do this test by spying on `wp.a11y.speak`,
// but it's very difficult to do that because `wp.a11y` has
Expand Down
5 changes: 2 additions & 3 deletions packages/e2e-tests/specs/reusable-blocks.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@ import {
insertBlock,
createNewPost,
clickBlockToolbarButton,
pressKeyWithModifier,
searchForBlock,
getEditedPostContent,
selectAllBlocks,
} from '@wordpress/e2e-test-utils';

function waitForAndAcceptDialog() {
Expand Down Expand Up @@ -210,8 +210,7 @@ describe( 'Reusable Blocks', () => {
await page.keyboard.type( 'Second paragraph' );

// Select all the blocks
await pressKeyWithModifier( 'primary', 'a' );
await pressKeyWithModifier( 'primary', 'a' );
await selectAllBlocks();

// Convert block to a reusable block
await page.waitForSelector( 'button[aria-label="More options"]' );
Expand Down
5 changes: 3 additions & 2 deletions packages/e2e-tests/specs/rich-text.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import {
insertBlock,
clickBlockAppender,
pressKeyWithModifier,
__unstableSelectAll,
} from '@wordpress/e2e-test-utils';

describe( 'RichText', () => {
Expand All @@ -30,7 +31,7 @@ describe( 'RichText', () => {
it( 'should apply formatting with access shortcut', async () => {
await clickBlockAppender();
await page.keyboard.type( 'test' );
await pressKeyWithModifier( 'primary', 'a' );
await __unstableSelectAll();
await pressKeyWithModifier( 'access', 'd' );

expect( await getEditedPostContent() ).toMatchSnapshot();
Expand All @@ -39,7 +40,7 @@ describe( 'RichText', () => {
it( 'should apply formatting with primary shortcut', async () => {
await clickBlockAppender();
await page.keyboard.type( 'test' );
await pressKeyWithModifier( 'primary', 'a' );
await __unstableSelectAll();
await pressKeyWithModifier( 'primary', 'b' );

expect( await getEditedPostContent() ).toMatchSnapshot();
Expand Down

0 comments on commit fbff4a4

Please sign in to comment.