diff --git a/packages/e2e-tests/plugins/iframed-block.php b/packages/e2e-tests/plugins/iframed-block.php new file mode 100644 index 00000000000000..29e71fa75a2ec8 --- /dev/null +++ b/packages/e2e-tests/plugins/iframed-block.php @@ -0,0 +1,46 @@ + { + const { createElement: el } = element; + const { registerBlockType } = blocks; + const { useBlockProps } = blockEditor; + const { useRefEffect } = compose; + + registerBlockType( 'test/iframed-block', { + edit: function Edit() { + const ref = useRefEffect( ( node ) => { + $( node ).test(); + }, [] ); + return el( 'p', useBlockProps( { ref } ), 'Iframed Block (edit)' ); + }, + save: function Save() { + return el( 'p', useBlockProps.save(), 'Iframed Block (saved)' ); + }, + } ); +} )( window ); diff --git a/packages/e2e-tests/plugins/iframed-block/jquery.test.js b/packages/e2e-tests/plugins/iframed-block/jquery.test.js new file mode 100644 index 00000000000000..901a6f1281927b --- /dev/null +++ b/packages/e2e-tests/plugins/iframed-block/jquery.test.js @@ -0,0 +1,7 @@ +( ( $ ) => { + $.fn.test = function() { + return this.each( function() { + $( this ).text( 'Iframed Block (set with jQuery)' ); + } ); + }; +} )( window.jQuery ); diff --git a/packages/e2e-tests/plugins/iframed-block/script.js b/packages/e2e-tests/plugins/iframed-block/script.js new file mode 100644 index 00000000000000..f8872070f682b7 --- /dev/null +++ b/packages/e2e-tests/plugins/iframed-block/script.js @@ -0,0 +1,7 @@ +( ( win ) => { + const { jQuery: $ } = win; + win.addEventListener( 'DOMContentLoaded', () => { + $( '.wp-block-test-iframed-block' ).test(); + } ); +} )( window ); + diff --git a/packages/e2e-tests/plugins/iframed-block/style.css b/packages/e2e-tests/plugins/iframed-block/style.css new file mode 100644 index 00000000000000..42708ad70cbadb --- /dev/null +++ b/packages/e2e-tests/plugins/iframed-block/style.css @@ -0,0 +1,9 @@ +/** + * The following styles get applied both on the front of your site + * and in the editor. + */ +.wp-block-test-iframed-block { + background-color: #21759b; + color: #fff; + padding: 2px; +} diff --git a/packages/e2e-tests/specs/editor/plugins/__snapshots__/iframed-block.test.js.snap b/packages/e2e-tests/specs/editor/plugins/__snapshots__/iframed-block.test.js.snap new file mode 100644 index 00000000000000..a4efcd222188ef --- /dev/null +++ b/packages/e2e-tests/specs/editor/plugins/__snapshots__/iframed-block.test.js.snap @@ -0,0 +1,7 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`changing image size should load script and dependencies in iframe 1`] = ` +" +
Iframed Block (saved)
+" +`; diff --git a/packages/e2e-tests/specs/editor/plugins/iframed-block.test.js b/packages/e2e-tests/specs/editor/plugins/iframed-block.test.js new file mode 100644 index 00000000000000..ba3255a83a3300 --- /dev/null +++ b/packages/e2e-tests/specs/editor/plugins/iframed-block.test.js @@ -0,0 +1,57 @@ +/** + * WordPress dependencies + */ +import { + activatePlugin, + createNewPost, + deactivatePlugin, + insertBlock, + getEditedPostContent, + openDocumentSettingsSidebar, + clickButton, + canvas, +} from '@wordpress/e2e-test-utils'; + +describe( 'changing image size', () => { + beforeEach( async () => { + await activatePlugin( 'gutenberg-test-iframed-block' ); + await createNewPost( { postType: 'page' } ); + } ); + + afterEach( async () => { + await deactivatePlugin( 'gutenberg-test-iframed-block' ); + } ); + + it( 'should load script and dependencies in iframe', async () => { + await insertBlock( 'Iframed Block' ); + + expect( await getEditedPostContent() ).toMatchSnapshot(); + + await page.waitForSelector( '.wp-block-test-iframed-block' ); + const text = await page.evaluate( () => { + return document.querySelector( '.wp-block-test-iframed-block' ) + .innerText; + } ); + + expect( text ).toBe( 'Iframed Block (set with jQuery)' ); + + await openDocumentSettingsSidebar(); + await clickButton( 'Page' ); + await clickButton( 'Template' ); + await clickButton( 'New' ); + await page.keyboard.press( 'Tab' ); + await page.keyboard.press( 'Tab' ); + await page.keyboard.type( 'Iframed Test' ); + await clickButton( 'Create' ); + await page.waitForSelector( 'iframe[name="editor-canvas"]' ); + + const iframedText = await canvas().evaluate( () => { + return document.querySelector( '.wp-block-test-iframed-block' ) + .innerText; + } ); + + // Expect the script to load in the iframe, which replaces the block + // text. + expect( iframedText ).toBe( 'Iframed Block (set with jQuery)' ); + } ); +} );