Skip to content

Commit

Permalink
add testIsolation for plugin tests
Browse files Browse the repository at this point in the history
simplify tests when possible and add mobile nav test
  • Loading branch information
circlecube committed Jun 10, 2024
1 parent 43b1536 commit 4fd53ef
Show file tree
Hide file tree
Showing 8 changed files with 117 additions and 176 deletions.
1 change: 1 addition & 0 deletions src/app/components/app-nav/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,7 @@ export const MobileNav = () => {
<Logo />
</div>
<button
id="nfd-app-mobile-nav"
className="nfd-h-16 nfd-px-4 nfd-text-body nfd-flex nfd-items-center focus:nfd-outline-none focus:nfd-ring-2 focus:nfd-ring-inset focus:nfd-ring-primary"
onClick={ () => {
setIsOpen( true );
Expand Down
23 changes: 5 additions & 18 deletions tests/cypress/integration/help.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@
const pluginNotificationsFixture = require( '../fixtures/plugin-notifications.json' );
const pluginProductsFixture = require( '../fixtures/plugin-products.json' );

describe( 'Help Page', function () {
before( () => {
describe( 'Help Page', { testIsolation: true }, function () {
beforeEach( () => {
cy.intercept(
{
method: 'GET',
Expand All @@ -22,63 +22,50 @@ describe( 'Help Page', function () {
'/wp-admin/admin.php?page=' + Cypress.env( 'pluginId' ) + '#/help',
{ timeout: 30000 }
);
cy.injectAxe();
} );

it( 'Is Accessible', () => {
cy.injectAxe();
cy.wait( 500 );
cy.checkA11y( '.wppbh-app-body' );
} );

it( 'Phone Card Exists', () => {
it( 'Cards Each Exist', () => {
cy.get( '.card-help-phone' )
.contains( 'h3', 'Phone' )
.scrollIntoView()
.should( 'be.visible' );
} );

it( 'Chat Card Exists', () => {
cy.get( '.card-help-chat' )
.contains( 'h3', 'Chat' )
.scrollIntoView()
.should( 'be.visible' );
} );

it( 'Tweet Card Exists', () => {
cy.get( '.card-help-twitter' )
.contains( 'h3', 'Tweet' )
.scrollIntoView()
.should( 'be.visible' );
} );

it( 'Youtube Card Exists', () => {
cy.get( '.card-help-youtube' )
.contains( 'h3', 'YouTube' )
.scrollIntoView()
.should( 'be.visible' );
} );

it( 'Online Support Card Exists', () => {
cy.get( '.card-help-kb' )
.contains( 'h3', 'Knowledge Base' )
.scrollIntoView()
.should( 'be.visible' );
} );

it( 'Resources Card Exists', () => {
cy.get( '.card-help-resources' )
.contains( 'h3', 'Resources' )
.scrollIntoView()
.should( 'be.visible' );
} );

it( 'Events Card Exists', () => {
cy.get( '.card-help-events' )
.contains( 'h3', 'Events and Webinars' )
.scrollIntoView()
.should( 'be.visible' );
} );

it( 'Website Card Exists', () => {
cy.get( '.card-help-website' )
.contains( 'h3', 'Bluehost Website' )
.scrollIntoView()
Expand Down
43 changes: 28 additions & 15 deletions tests/cypress/integration/home.cy.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,12 @@
// <reference types="Cypress" />
const webinarsFixture = require( '../fixtures/webinars.json' );
const webinarsPastFixture = require( '../fixtures/webinars-past.json' );
const webinarsInactiveFixture = require( '../fixtures/webinars-inactive.json' );

describe( 'Home Page', function () {
describe( 'Home Page', { testIsolation: true }, function () {
let NewfoldRuntime;

before( () => {
beforeEach( () => {
cy.visit(
'/wp-admin/admin.php?page=' + Cypress.env( 'pluginId' ) + '#/home'
);
Expand All @@ -12,7 +15,6 @@ describe( 'Home Page', function () {
.then( ( data ) => {
NewfoldRuntime = data;
} );
cy.injectAxe();
} );

it( 'Site Info Exists', () => {
Expand All @@ -23,6 +25,7 @@ describe( 'Home Page', function () {
} );

it( 'Is Accessible', () => {
cy.injectAxe();
cy.wait( 500 );
cy.checkA11y( '.wppbh-app-body' );
} );
Expand Down Expand Up @@ -55,22 +58,24 @@ describe( 'Home Page', function () {
.should( 'be.visible' );
} );

it( 'Webinars Section Exists', () => {
it( 'Webinars Section Exists and Renders Properly', () => {
cy.intercept(
'https://cdn.hiive.space/resources/bluehost-webinars.json',
{ fixture: 'webinars.json' }
);
{
method: 'GET',
url: 'https://cdn.hiive.space/resources/bluehost-webinars.json',
},
webinarsFixture
).as( 'webinarsFixture' );
cy.reload();
cy.wait( '@webinarsFixture' );
cy.get( '.wppbh-webinars-banner-section' )
.contains(
'h2',
'FREE Monthly Webinar: Build your brand with WordPress'
)
.scrollIntoView()
.should( 'be.visible' );
} );

it( 'Webinars Section Renders Correctly', () => {
// Title
cy.get( '.wppbh-webinars-banner-section' )
.contains(
Expand Down Expand Up @@ -120,19 +125,27 @@ describe( 'Home Page', function () {

it( "Webinars Section Doesn't Render When Active Propety is False", () => {
cy.intercept(
'https://cdn.hiive.space/resources/bluehost-webinars.json',
{ fixture: 'webinars-inactive.json' }
);
{
method: 'GET',
url: 'https://cdn.hiive.space/resources/bluehost-webinars.json',
},
webinarsInactiveFixture
).as( 'webinarsInactiveFixture' );
cy.reload();
cy.wait( '@webinarsInactiveFixture' );
cy.get( '.wppbh-webinars-banner-section' ).should( 'not.exist' );
} );

it( "Webinars Section Doesn't Render Items Are in the Past", () => {
cy.intercept(
'https://cdn.hiive.space/resources/bluehost-webinars.json',
{ fixture: 'webinars-past.json' }
);
{
method: 'GET',
url: 'https://cdn.hiive.space/resources/bluehost-webinars.json',
},
webinarsPastFixture
).as( 'webinarsPastFixture' );
cy.reload();
cy.wait( '@webinarsPastFixture' );
cy.get( '.wppbh-webinars-banner-section' ).should( 'not.exist' );
} );
} );
54 changes: 12 additions & 42 deletions tests/cypress/integration/navigation.cy.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// <reference types="Cypress" />

describe( 'Navigation', function () {
before( () => {
describe( 'Navigation', { testIsolation: true }, function () {
beforeEach( () => {
cy.visit( '/wp-admin/admin.php?page=' + Cypress.env( 'pluginId' ) );
} );

Expand Down Expand Up @@ -118,49 +118,19 @@ describe( 'Navigation', function () {
).should( 'exist' );
} );

// utility nav is no more, leaving this in place un case we bring it back anytime soon.
it.skip( 'Utility nav links properly navigates', () => {
cy.get( '.utility-link-Performance' ).should(
'not.have.class',
'active'
);
cy.get( '.utility-link-Performance' ).click();
cy.wait( 500 );
cy.hash().should( 'eq', '#/performance' );
cy.get( '.utility-link-Performance' ).should( 'have.class', 'active' );

cy.get( '.utility-link-Settings' ).click();
cy.wait( 500 );
cy.hash().should( 'eq', '#/settings' );
cy.get( '.utility-link-Settings' ).should( 'have.class', 'active' );
cy.get( '.utility-link-Performance' ).should(
'not.have.class',
'active'
);

cy.get( '.utility-link-Help' ).click();
cy.wait( 500 );
cy.hash().should( 'eq', '#/help' );
cy.get( '.utility-link-Help' ).should( 'have.class', 'active' );
cy.get( '.utility-link-Settings' ).should( 'not.have.class', 'active' );
} );

// no mobile nav, but should probably add
it.skip( 'Mobile nav links dispaly for mobile', () => {
cy.get( '.mobile-toggle' ).should( 'not.exist' );
it( 'Mobile nav links dispaly and link properly on mobile', () => {
cy.get( '#nfd-app-mobile-nav' ).should( 'not.exist' );

cy.viewport( 'iphone-x' );
cy.get( '.mobile-toggle' ).should( 'be.visible' );
} );
cy.get( '#nfd-app-mobile-nav' ).should( 'be.visible' );

it.skip( 'Mobile nav links properly navigates', () => {
cy.get( '.mobile-link-Home' ).should( 'not.exist' );
cy.viewport( 'iphone-x' );
cy.get( '.mobile-toggle' ).click();
cy.get( '.wppbh-app-navitem-Home' ).should( 'not.exist' );

cy.get( '#nfd-app-mobile-nav' ).click();
cy.wait( 500 );
cy.get( '.mobile-link-Home' ).should( 'be.visible' );
cy.get( 'button[aria-label="Close"]' ).should( 'be.visible' );
cy.get( 'button[aria-label="Close"]' ).click();
cy.get( '.mobile-link-Home' ).should( 'not.exist' );
cy.get( '.wppbh-app-navitem-Home' ).should( 'be.visible' );
cy.get( 'button.nfd-modal__close-button' ).should( 'be.visible' );
cy.get( 'button.nfd-modal__close-button' ).click();
cy.get( '.wppbh-app-navitem-Home' ).should( 'not.exist' );
} );
} );
107 changes: 48 additions & 59 deletions tests/cypress/integration/pages-and-posts.cy.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,25 @@
describe( 'Pages & Posts', function () {
let NewfoldRuntime;
describe( 'Pages & Posts', { testIsolation: true }, function () {

before( () => {
beforeEach( () => {
cy.visit(
'/wp-admin/admin.php?page=' +
Cypress.env( 'pluginId' ) +
'#/pages-and-posts'
'#/pages-and-posts',
{
onLoad() {
cy.window().then( ( win ) => {
win.NewfoldRuntime.isYithBookingActive = true;
win.NewfoldRuntime.isWoocommerceActive = true;
} );
},
}
);
cy.window()
.its( 'NewfoldRuntime' )
.then( ( data ) => {
NewfoldRuntime = data;
} );
} );

it( 'Is Accessible', () => {
cy.injectAxe();
cy.wait( 100 );
cy.checkA11y( '.wppbh-app-body' );
} );

it( 'Pages & Posts Exists', () => {
Expand All @@ -22,7 +29,7 @@ describe( 'Pages & Posts', function () {
.should( 'be.visible' );
} );

it( 'site pages Exists', () => {
it( 'Site Pages Exists', () => {
cy.get( '.wppbh-app-site-page' )
.findByText( 'Site Pages' )
.should( 'exist' );
Expand Down Expand Up @@ -55,59 +62,41 @@ describe( 'Pages & Posts', function () {
} );

it( 'Bookings & Appointments Exists', () => {
if (
NewfoldRuntime.isYithBookingActive &&
NewfoldRuntime.isWoocommerceActive
) {
cy.get( '.wppbh-app-bookings' )
.findByText( 'Bookings & Appointments' )
.should( 'exist' );
cy.get( '.wppbh-app-bookings' )
.find(
'a[href="edit.php?post_type=yith_booking&yith-plugin-fw-panel-skip-redirect=1"]'
)
.first()
.click();
cy.url().should(
'include',
'edit.php?post_type=yith_booking&yith-plugin-fw-panel-skip-redirect=1'
);
cy.go( 'back' );
cy.get( '.wppbh-app-bookings' )
.findByText( 'Bookings & Appointments' )
.should( 'exist' );
cy.get( '.wppbh-app-bookings' )
.find(
'a[href="edit.php?post_type=yith_booking&yith-plugin-fw-panel-skip-redirect=1"]'
)
.first()
.should( 'exist' );

cy.get( '.wppbh-app-bookings' )
.find(
'a[href="edit.php?post_type=yith_booking&yith-plugin-fw-panel-skip-redirect=1"] Button'
)
.last()
.click();
cy.url().should(
'include',
'edit.php?post_type=yith_booking&yith-plugin-fw-panel-skip-redirect=1'
);
cy.go( 'back' );
} else {
cy.findByText( 'Bookings & Appointments' ).should( 'not.exist' );
}
cy.get( '.wppbh-app-bookings' )
.find(
'a[href="edit.php?post_type=yith_booking&yith-plugin-fw-panel-skip-redirect=1"] Button'
)
.last()
.should( 'exist' );
} );

it( 'Products Exists', () => {
if ( NewfoldRuntime.isWoocommerceActive ) {
cy.get( '.wppbh-app-products' )
.findByText( 'Products' )
.should( 'exist' );
cy.get( '.wppbh-app-products' )
.find( 'a[href="edit.php?post_type=product"]' )
.click();
cy.url().should( 'include', 'edit.php?post_type=product' );
cy.go( 'back' );
cy.get( '.wppbh-app-products' )
.findByText( 'Products' )
.should( 'exist' );
cy.get( '.wppbh-app-products' )
.find( 'a[href="edit.php?post_type=product"]' )
.should( 'exist' );

cy.get( '.wppbh-app-products' )
.find( 'a[href="post-new.php?post_type=product"] Button' )
.click();
cy.url().should( 'include', 'post-new.php?post_type=product' );
cy.go( 'back' );
} else {
cy.findByText( 'Products' ).should( 'not.exist' );
}
cy.get( '.wppbh-app-products' )
.find( 'a[href="post-new.php?post_type=product"] Button' )
.should( 'exist' );
} );

it( 'Products and Booking does not load if Yith and Woo are not active', () => {
// clears edited NewfoldRuntime values
cy.reload();
cy.findByText( 'Products' ).should( 'not.exist' );
cy.findByText( 'Bookings & Appointments' ).should( 'not.exist' );
});
} );
Loading

0 comments on commit 4fd53ef

Please sign in to comment.