From 1389df09b7bde578757b4b1ee9b49239f02b752a Mon Sep 17 00:00:00 2001 From: ntsekouras Date: Wed, 14 Feb 2024 18:34:38 +0200 Subject: [PATCH 1/2] Restore patterns e2e tests --- .../site-editor/new-templates-list.spec.js | 11 +-- test/e2e/specs/site-editor/patterns.spec.js | 97 ++++++------------- 2 files changed, 37 insertions(+), 71 deletions(-) diff --git a/test/e2e/specs/site-editor/new-templates-list.spec.js b/test/e2e/specs/site-editor/new-templates-list.spec.js index a0dd0ccb903c2..f0a4a579fc186 100644 --- a/test/e2e/specs/site-editor/new-templates-list.spec.js +++ b/test/e2e/specs/site-editor/new-templates-list.spec.js @@ -7,15 +7,14 @@ test.describe( 'Templates', () => { test.beforeAll( async ( { requestUtils } ) => { await Promise.all( [ requestUtils.activateTheme( 'emptytheme' ), - requestUtils.setGutenbergExperiments( [ 'gutenberg-dataviews' ] ), + requestUtils.deleteAllTemplates( 'wp_template' ), ] ); } ); test.afterAll( async ( { requestUtils } ) => { - await Promise.all( [ - requestUtils.activateTheme( 'twentytwentyone' ), - requestUtils.deleteAllTemplates( 'wp_template' ), - requestUtils.setGutenbergExperiments( [] ), - ] ); + await requestUtils.activateTheme( 'twentytwentyone' ); + } ); + test.afterEach( async ( { requestUtils } ) => { + await requestUtils.deleteAllTemplates( 'wp_template' ); } ); test( 'Sorting', async ( { admin, page } ) => { await admin.visitSiteEditor( { path: '/wp_template/all' } ); diff --git a/test/e2e/specs/site-editor/patterns.spec.js b/test/e2e/specs/site-editor/patterns.spec.js index 6b2561d1f5bd9..4359397eab1a1 100644 --- a/test/e2e/specs/site-editor/patterns.spec.js +++ b/test/e2e/specs/site-editor/patterns.spec.js @@ -15,7 +15,8 @@ const test = base.extend( { // Skip these tests for now as we plan to adapt them to // the new patterns UI. -test.describe.skip( 'Patterns', () => { +test.describe( 'Patterns', () => { + const noResultsMsg = 'No results'; test.beforeAll( async ( { requestUtils } ) => { await requestUtils.activateTheme( 'emptytheme' ); await requestUtils.deleteAllBlocks(); @@ -35,19 +36,14 @@ test.describe.skip( 'Patterns', () => { admin, patterns, } ) => { - await admin.visitSiteEditor(); - - await patterns.navigation - .getByRole( 'button', { name: 'Patterns' } ) - .click(); - + await admin.visitSiteEditor( { path: '/patterns' } ); await expect( patterns.navigation.getByRole( 'heading', { name: 'Patterns', level: 1, } ) ).toBeVisible(); - await expect( patterns.content ).toContainText( 'No patterns found.' ); + await expect( patterns.content ).toContainText( noResultsMsg ); await patterns.navigation .getByRole( 'button', { name: 'Create pattern' } ) @@ -101,7 +97,6 @@ test.describe.skip( 'Patterns', () => { await patterns.navigation .getByRole( 'button', { name: 'Back' } ) .click(); - // TODO: await expect( page ).toHaveTitle( /^Patterns/ ); await expect( patterns.navigation.getByRole( 'button', { @@ -125,11 +120,11 @@ test.describe.skip( 'Patterns', () => { level: 2, } ) ).toBeVisible(); - await expect( patterns.list.getByRole( 'listitem' ) ).toHaveCount( 1 ); + await expect( patterns.item ).toHaveCount( 1 ); await expect( - patterns.list - .getByRole( 'heading', { name: 'My pattern' } ) - .getByRole( 'button', { name: 'My pattern', exact: true } ) + patterns.itemsList.getByText( 'My pattern', { + exact: true, + } ) ).toBeVisible(); } ); @@ -137,6 +132,7 @@ test.describe.skip( 'Patterns', () => { admin, requestUtils, patterns, + page, } ) => { await Promise.all( [ requestUtils.createBlock( { @@ -163,76 +159,46 @@ test.describe.skip( 'Patterns', () => { await admin.visitSiteEditor( { path: '/patterns' } ); - await expect( patterns.list.getByRole( 'listitem' ) ).toHaveCount( 3 ); - - await patterns.content - .getByRole( 'searchbox', { name: 'Search patterns' } ) - .fill( 'footer' ); - await expect( patterns.list.getByRole( 'listitem' ) ).toHaveCount( 2 ); + await expect( patterns.item ).toHaveCount( 3 ); + const searchBox = patterns.content.getByRole( 'searchbox', { + name: 'Search', + } ); + await searchBox.fill( 'footer' ); + await expect( patterns.item ).toHaveCount( 2 ); expect( - await patterns.list - .getByRole( 'listitem' ) - .getByRole( 'heading' ) - .allInnerTexts() + await patterns.item.getByRole( 'button' ).allInnerTexts() ).toEqual( expect.arrayContaining( [ 'Unsynced footer', 'Synced footer' ] ) ); - const searchBox = patterns.content.getByRole( 'searchbox', { - name: 'Search patterns', - } ); - await searchBox.fill( 'no match' ); - await expect( patterns.content ).toContainText( 'No patterns found.' ); + await expect( patterns.content ).toContainText( noResultsMsg ); await patterns.content - .getByRole( 'button', { name: 'Reset search' } ) + .getByRole( 'button', { name: 'Reset filters' } ) .click(); await expect( searchBox ).toHaveValue( '' ); - await expect( patterns.list.getByRole( 'listitem' ) ).toHaveCount( 3 ); - - const syncFilter = patterns.content.getByRole( 'radiogroup', { - name: 'Filter by sync status', - } ); - await expect( - syncFilter.getByRole( 'radio', { name: 'All' } ) - ).toBeChecked(); + await expect( patterns.item ).toHaveCount( 3 ); - await syncFilter - .getByRole( 'radio', { name: 'Synced', exact: true } ) + await patterns.content + .getByRole( 'button', { name: 'Sync Status' } ) .click(); - await expect( patterns.list.getByRole( 'listitem' ) ).toHaveCount( 1 ); - await expect( patterns.list.getByRole( 'listitem' ) ).toContainText( - 'Synced footer' - ); + await page.getByRole( 'option', { name: /^Synced/ } ).click(); + + await expect( patterns.item ).toHaveCount( 1 ); + await expect( patterns.item ).toContainText( 'Synced footer' ); - await syncFilter.getByRole( 'radio', { name: 'Not synced' } ).click(); - await expect( patterns.list.getByRole( 'listitem' ) ).toHaveCount( 2 ); + await page.getByRole( 'option', { name: /^Not synced/ } ).click(); + await expect( patterns.item ).toHaveCount( 2 ); expect( - await patterns.list - .getByRole( 'listitem' ) - .getByRole( 'heading' ) - .allInnerTexts() + await patterns.item.getByRole( 'button' ).allInnerTexts() ).toEqual( expect.arrayContaining( [ 'Unsynced header', 'Unsynced footer' ] ) ); await searchBox.fill( 'footer' ); - await expect( patterns.list.getByRole( 'listitem' ) ).toHaveCount( 1 ); - await expect( patterns.list.getByRole( 'listitem' ) ).toContainText( - 'Unsynced footer' - ); - - await syncFilter.getByRole( 'radio', { name: 'All' } ).click(); - await expect( patterns.list.getByRole( 'listitem' ) ).toHaveCount( 2 ); - expect( - await patterns.list - .getByRole( 'listitem' ) - .getByRole( 'heading' ) - .allInnerTexts() - ).toEqual( - expect.arrayContaining( [ 'Unsynced footer', 'Synced footer' ] ) - ); + await expect( patterns.item ).toHaveCount( 1 ); + await expect( patterns.item ).toContainText( 'Unsynced footer' ); } ); } ); @@ -249,6 +215,7 @@ class Patterns { this.navigation = this.#page.getByRole( 'region', { name: 'Navigation', } ); - this.list = this.content.getByRole( 'list' ); + this.itemsList = this.content.locator( '.dataviews-view-grid' ); + this.item = this.itemsList.locator( '.dataviews-view-grid__card' ); } } From 05b7f5ef68773e0e9a4ad13f56269cc70381bc9a Mon Sep 17 00:00:00 2001 From: ntsekouras Date: Thu, 15 Feb 2024 09:57:25 +0200 Subject: [PATCH 2/2] feedback --- test/e2e/specs/site-editor/patterns.spec.js | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/test/e2e/specs/site-editor/patterns.spec.js b/test/e2e/specs/site-editor/patterns.spec.js index 4359397eab1a1..97d8c0e8fcd25 100644 --- a/test/e2e/specs/site-editor/patterns.spec.js +++ b/test/e2e/specs/site-editor/patterns.spec.js @@ -13,10 +13,7 @@ const test = base.extend( { }, } ); -// Skip these tests for now as we plan to adapt them to -// the new patterns UI. test.describe( 'Patterns', () => { - const noResultsMsg = 'No results'; test.beforeAll( async ( { requestUtils } ) => { await requestUtils.activateTheme( 'emptytheme' ); await requestUtils.deleteAllBlocks(); @@ -43,7 +40,7 @@ test.describe( 'Patterns', () => { level: 1, } ) ).toBeVisible(); - await expect( patterns.content ).toContainText( noResultsMsg ); + await expect( patterns.content ).toContainText( 'No results' ); await patterns.navigation .getByRole( 'button', { name: 'Create pattern' } ) @@ -172,7 +169,7 @@ test.describe( 'Patterns', () => { ); await searchBox.fill( 'no match' ); - await expect( patterns.content ).toContainText( noResultsMsg ); + await expect( patterns.content ).toContainText( 'No results' ); await patterns.content .getByRole( 'button', { name: 'Reset filters' } )