diff --git a/packages/e2e-tests/specs/editor/various/editor-modes.test.js b/packages/e2e-tests/specs/editor/various/editor-modes.test.js deleted file mode 100644 index bb051fe705b38d..00000000000000 --- a/packages/e2e-tests/specs/editor/various/editor-modes.test.js +++ /dev/null @@ -1,163 +0,0 @@ -/** - * WordPress dependencies - */ -import { - clickBlockAppender, - clickBlockToolbarButton, - clickMenuItem, - createNewPost, - getCurrentPostContent, - switchEditorModeTo, - pressKeyTimes, - pressKeyWithModifier, - openTypographyToolsPanelMenu, - canvas, -} from '@wordpress/e2e-test-utils'; - -describe( 'Editing modes (visual/HTML)', () => { - beforeEach( async () => { - await createNewPost(); - await clickBlockAppender(); - await page.keyboard.type( 'Hello world!' ); - } ); - - it( 'should switch between visual and HTML modes', async () => { - // This block should be in "visual" mode by default. - let visualBlock = await canvas().$$( '[data-block].rich-text' ); - expect( visualBlock ).toHaveLength( 1 ); - - // Change editing mode from "Visual" to "HTML". - await clickBlockToolbarButton( 'Options' ); - await clickMenuItem( 'Edit as HTML' ); - - // Wait for the block to be converted to HTML editing mode. - const htmlBlock = await canvas().$$( - '[data-block] .block-editor-block-list__block-html-textarea' - ); - expect( htmlBlock ).toHaveLength( 1 ); - - // Change editing mode from "HTML" back to "Visual". - await clickBlockToolbarButton( 'Options' ); - await clickMenuItem( 'Edit visually' ); - - // This block should be in "visual" mode by default. - visualBlock = await canvas().$$( '[data-block].rich-text' ); - expect( visualBlock ).toHaveLength( 1 ); - } ); - - it( 'should display sidebar in HTML mode', async () => { - // Change editing mode from "Visual" to "HTML". - await clickBlockToolbarButton( 'Options' ); - await clickMenuItem( 'Edit as HTML' ); - - // The `drop cap` toggle for the paragraph block should appear, even in - // HTML editing mode. - await openTypographyToolsPanelMenu(); - await page.click( 'button[aria-label="Show Drop cap"]' ); - - const dropCapToggle = await page.$x( - "//label[contains(text(), 'Drop cap')]" - ); - - expect( dropCapToggle ).toHaveLength( 1 ); - } ); - - it( 'should update HTML in HTML mode when sidebar is used', async () => { - // Change editing mode from "Visual" to "HTML". - await clickBlockToolbarButton( 'Options' ); - await clickMenuItem( 'Edit as HTML' ); - - // Make sure the paragraph content is rendered as expected. - let htmlBlockContent = await canvas().$eval( - '.block-editor-block-list__layout .block-editor-block-list__block .block-editor-block-list__block-html-textarea', - ( node ) => node.textContent - ); - expect( htmlBlockContent ).toEqual( '

Hello world!

' ); - - // Change the `drop cap` using the sidebar. - await openTypographyToolsPanelMenu(); - await page.click( 'button[aria-label="Show Drop cap"]' ); - - const [ dropCapToggle ] = await page.$x( - "//label[contains(text(), 'Drop cap')]" - ); - await dropCapToggle.click(); - - // Make sure the HTML content updated. - htmlBlockContent = await canvas().$eval( - '.block-editor-block-list__layout .block-editor-block-list__block .block-editor-block-list__block-html-textarea', - ( node ) => node.textContent - ); - expect( htmlBlockContent ).toEqual( - '

Hello world!

' - ); - } ); - - it( 'the code editor should unselect blocks and disable the inserter', async () => { - // The paragraph block should be selected. - const title = await page.$eval( - '.block-editor-block-card__title', - ( element ) => element.innerText - ); - expect( title ).toBe( 'Paragraph' ); - - // The Block inspector should be active. - let [ blockInspectorTab ] = await page.$x( - '//button[@role="tab"][@aria-selected="true"][contains(text(), "Block")]' - ); - expect( blockInspectorTab ).not.toBeNull(); - - await switchEditorModeTo( 'Code' ); - - // The Block inspector should not be active anymore. - [ blockInspectorTab ] = await page.$x( - '//button[@role="tab"][@aria-selected="true"][contains(text(), "Block")]' - ); - expect( blockInspectorTab ).toBeUndefined(); - - // No block is selected. - const inactiveBlockInspectorTab = await page.waitForXPath( - '//button[@role="tab"][contains(text(), "Block")]' - ); - inactiveBlockInspectorTab.click(); - const noBlocksElement = page.waitForSelector( - '.block-editor-block-inspector__no-blocks' - ); - expect( noBlocksElement ).not.toBeNull(); - - // The inserter is disabled. - const disabledInserter = await page.$( - '.editor-document-tools__inserter-toggle:disabled, .editor-document-tools__inserter-toggle[aria-disabled="true"]' - ); - expect( disabledInserter ).not.toBeNull(); - } ); - - // Test for regressions of https://github.com/WordPress/gutenberg/issues/24054. - it( 'saves content when using the shortcut in the Code Editor', async () => { - await switchEditorModeTo( 'Code' ); - - const textContent = await page.evaluate( - () => document.querySelector( '.editor-post-text-editor' ).value - ); - const editPosition = textContent.indexOf( 'Hello' ); - - // Replace the word 'Hello' with 'Hi'. - await canvas().click( '.editor-post-title__input' ); - await page.keyboard.press( 'Tab' ); - await pressKeyTimes( 'ArrowRight', editPosition ); - await pressKeyTimes( 'Delete', 5 ); - await page.keyboard.type( 'Hi' ); - - // Save the post using the shortcut. - await pressKeyWithModifier( 'primary', 's' ); - await page.waitForSelector( '.editor-post-saved-state.is-saved' ); - - await switchEditorModeTo( 'Visual' ); - - expect( await getCurrentPostContent() ).toMatchInlineSnapshot( ` - " -

Hi world!

- " - ` ); - } ); -} ); diff --git a/test/e2e/specs/editor/various/editor-modes.spec.js b/test/e2e/specs/editor/various/editor-modes.spec.js new file mode 100644 index 00000000000000..5d5ae9a70ab5cf --- /dev/null +++ b/test/e2e/specs/editor/various/editor-modes.spec.js @@ -0,0 +1,158 @@ +/** + * WordPress dependencies + */ +const { test, expect } = require( '@wordpress/e2e-test-utils-playwright' ); + +test.describe( 'Editing modes (visual/HTML)', () => { + test.beforeEach( async ( { admin, editor } ) => { + await admin.createNewPost(); + await editor.insertBlock( { + name: 'core/paragraph', + attributes: { content: 'Hello world!' }, + } ); + } ); + + test( 'should switch between visual and HTML modes', async ( { + editor, + } ) => { + const paragraphBlock = editor.canvas.getByRole( 'document', { + name: 'Block: Paragraph', + } ); + + // This block should be in "visual" mode by default. + await expect( paragraphBlock ).toHaveClass( /rich-text/ ); + + // Change editing mode from "Visual" to "HTML". + await editor.clickBlockOptionsMenuItem( 'Edit as HTML' ); + + // Wait for the block to be converted to HTML editing mode. + await expect( paragraphBlock.getByRole( 'textbox' ) ).toBeVisible(); + + // Change editing mode from "HTML" back to "Visual". + await editor.clickBlockOptionsMenuItem( 'Edit visually' ); + + // This block should be in "visual" mode again. + await expect( paragraphBlock ).toHaveClass( /rich-text/ ); + } ); + + test( 'should display sidebar in HTML mode', async ( { editor, page } ) => { + await editor.clickBlockOptionsMenuItem( 'Edit as HTML' ); + await editor.openDocumentSettingsSidebar(); + + // The `drop cap` toggle for the paragraph block should appear, even in + // HTML editing mode. + await page + .getByRole( 'button', { name: 'Typography options' } ) + .click(); + await page + .getByRole( 'menuitemcheckbox', { name: 'Show Drop cap' } ) + .click(); + + await expect( + page.getByRole( 'checkbox', { name: 'Drop cap' } ) + ).toBeVisible(); + } ); + + test( 'should update HTML in HTML mode when sidebar is used', async ( { + editor, + page, + } ) => { + await editor.clickBlockOptionsMenuItem( 'Edit as HTML' ); + await editor.openDocumentSettingsSidebar(); + + const paragraphHTML = editor.canvas + .getByRole( 'document', { + name: 'Block: Paragraph', + } ) + .getByRole( 'textbox' ); + + // Make sure the paragraph content is rendered as expected. + await expect( paragraphHTML ).toHaveValue( '

Hello world!

' ); + + // Change the `drop cap` using the sidebar. + await page + .getByRole( 'button', { name: 'Typography options' } ) + .click(); + await page + .getByRole( 'menuitemcheckbox', { name: 'Show Drop cap' } ) + .click(); + await page.getByRole( 'checkbox', { name: 'Drop cap' } ).check(); + + // Make sure the HTML content updated. + await expect( paragraphHTML ).toHaveValue( + '

Hello world!

' + ); + } ); + + test( 'the code editor should unselect blocks and disable the inserter', async ( { + editor, + page, + pageUtils, + } ) => { + await editor.openDocumentSettingsSidebar(); + const editorSettings = page.getByRole( 'region', { + name: 'Editor settings', + } ); + const activeTab = editorSettings.getByRole( 'tab', { selected: true } ); + + // The Block inspector should be active. + await expect( activeTab ).toHaveText( 'Block' ); + await expect( + editorSettings.locator( '.block-editor-block-card__title' ) + ).toHaveText( 'Paragraph' ); + + // Open the code editor. + await pageUtils.pressKeys( 'secondary+M' ); + + // The Block inspector should not be active anymore. + await expect( activeTab ).not.toHaveText( 'Block' ); + + await editorSettings.getByRole( 'tab', { name: 'Block' } ).click(); + await expect( + editorSettings.locator( '.block-editor-block-inspector__no-blocks' ) + ).toHaveText( 'No block selected.' ); + + await expect( + page + .getByRole( 'toolbar', { name: 'Document tools' } ) + .getByRole( 'button', { name: 'Toggle block inserter' } ) + ).toBeDisabled(); + + // Go back to the visual editor. + await pageUtils.pressKeys( 'secondary+M' ); + } ); + + // Test for regressions of https://github.com/WordPress/gutenberg/issues/24054. + test( 'saves content when using the shortcut in the Code Editor', async ( { + editor, + page, + pageUtils, + } ) => { + // Open the code editor. + await pageUtils.pressKeys( 'secondary+M' ); + + // Change content. + await page.getByRole( 'textbox', { name: 'Type text or HTML' } ) + .fill( ` +

Hi world!

+` ); + + // Save the post using the shortcut. + await pageUtils.pressKeys( 'primary+s' ); + await expect( + page + .getByRole( 'button', { name: 'Dismiss this notice' } ) + .filter( { hasText: 'Draft saved' } ) + ).toBeVisible(); + + // Go back to the visual editor. + await pageUtils.pressKeys( 'secondary+M' ); + + await expect.poll( editor.getBlocks ).toMatchObject( [ + { + name: 'core/paragraph', + attributes: { content: 'Hi world!' }, + }, + ] ); + } ); +} );