mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-15 17:42:15 +08:00

* fix(react): setting active tab properly on mount, closes #21830 * removing commented code * merge with master
280 lines
12 KiB
JavaScript
280 lines
12 KiB
JavaScript
const port = 3000;
|
|
|
|
describe('Navigation Tests', () => {
|
|
|
|
// before(() => {
|
|
// Cypress.config('userAgent', 'Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1')
|
|
// });
|
|
|
|
it('/ > Details 1, the details screen should appear', () => {
|
|
cy.visit(`http://localhost:${port}/routing`)
|
|
cy.ionPageVisible('home-page')
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.contains('[data-pageid=home-details-page-1] ion-label', 'Details 1')
|
|
})
|
|
|
|
it('/ > Details 1 > Back, should go back to home', () => {
|
|
cy.visit(`http://localhost:${port}/routing`)
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.contains('[data-pageid=home-details-page-1] ion-label', 'Details 1')
|
|
cy.ionBackClick('home-details-page-1');
|
|
cy.contains('[data-pageid=home-page] ion-title', 'Home')
|
|
})
|
|
|
|
it('/ > Details 1 > Settings Tab > Home Tab, should go back to details 1 on home tab', () => {
|
|
cy.visit(`http://localhost:${port}/routing`)
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.ionPageVisible('home-details-page-1')
|
|
cy.ionTabClick('Settings');
|
|
cy.ionPageVisible('settings-page');
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-details-page-1');
|
|
})
|
|
|
|
it('/ > Details 1 > Settings Tab > Home Tab > Home Tab, should go back to home', () => {
|
|
cy.visit(`http://localhost:${port}/routing`)
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.contains('[data-pageid=home-details-page-1] ion-label', 'Details 1')
|
|
cy.ionTabClick('Settings')
|
|
cy.ionPageVisible('settings-page');
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-details-page-1');
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-page');
|
|
})
|
|
|
|
it('When going directly to /tabs, it should load home page', () => {
|
|
cy.visit(`http://localhost:${port}/routing/tabs`)
|
|
cy.ionPageVisible('home-page');
|
|
})
|
|
|
|
it('When going directly to /tabs/home, it should load home page', () => {
|
|
cy.visit(`http://localhost:${port}/routing/tabs/home`)
|
|
cy.ionPageVisible('home-page');
|
|
})
|
|
|
|
it('When going directly to /tabs/settings, it should load settings page', () => {
|
|
cy.visit(`http://localhost:${port}/routing/tabs/settings`)
|
|
cy.ionPageVisible('settings-page');
|
|
})
|
|
|
|
it('Home Details 1 > Settings Tab > Home Tab, details 1 page should still be active', () => {
|
|
cy.visit(`http://localhost:${port}/routing/tabs/home/details/1`)
|
|
cy.ionTabClick('Settings')
|
|
cy.ionPageVisible('settings-page');
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-details-page-1');
|
|
})
|
|
|
|
it('/ > Home Details 1+2+3 > Settings Tab > Setting Details 1+2+3 > Home Tab > Back * 3 > Settings Tab > Back * 3, should be at settings page', () => {
|
|
// This was a bug when loading the root of the app and not going directly to the home tab
|
|
cy.visit(`http://localhost:${port}/routing/`)
|
|
cy.ionNav('ion-item', 'Details 1');
|
|
cy.ionNav('ion-button', 'Go to Details 2')
|
|
cy.ionNav('ion-button', 'Go to Details 3')
|
|
cy.contains('[data-pageid=home-details-page-3] ion-label', 'Details 3')
|
|
cy.ionTabClick('Settings')
|
|
cy.ionNav('ion-item', 'Settings Details 1');
|
|
cy.ionNav('ion-button', 'Go to Settings Details 2')
|
|
cy.ionNav('ion-button', 'Go to Settings Details 3')
|
|
cy.contains('[data-pageid=settings-details-page-3] ion-label', 'Details 3')
|
|
cy.ionTabClick('Home')
|
|
cy.contains('[data-pageid=home-details-page-3] ion-label', 'Details 3')
|
|
cy.ionBackClick('home-details-page-3');
|
|
cy.contains('[data-pageid=home-details-page-2] ion-label', 'Details 2')
|
|
cy.ionBackClick('home-details-page-2');
|
|
cy.contains('[data-pageid=home-details-page-1] ion-label', 'Details 1')
|
|
cy.ionBackClick('home-details-page-1');
|
|
cy.ionPageVisible('home-page');
|
|
})
|
|
|
|
it('/ > Details 1 with Query Param > Details 2 > Back, Query param should show on screen', () => {
|
|
cy.visit(`http://localhost:${port}/routing/`)
|
|
cy.ionNav('ion-item', 'Details 1 with Query Params')
|
|
cy.contains('[data-pageid=home-details-page-1] ion-label', 'Query Params: ')
|
|
cy.ionNav('ion-button', 'Go to Details 2')
|
|
cy.contains('[data-pageid=home-details-page-2] ion-label', 'Details 2')
|
|
cy.ionBackClick('home-details-page-2');
|
|
cy.contains('[data-pageid=home-details-page-1] ion-label', 'Query Params: ')
|
|
})
|
|
|
|
it('/ > Details 1 with Query Param > Settings Tab > Home Tab > Query param should show on screen', () => {
|
|
cy.visit(`http://localhost:${port}/routing/`)
|
|
cy.ionNav('ion-item', 'Details 1 with Query Params')
|
|
cy.contains('[data-pageid=home-details-page-1] ion-label', 'Query Params: ')
|
|
cy.ionTabClick('Settings')
|
|
cy.ionPageVisible('settings-page')
|
|
cy.ionTabClick('Home')
|
|
cy.contains('[data-pageid=home-details-page-1] ion-label', 'Query Params: ')
|
|
})
|
|
|
|
it('Home Details 1 > Home Tab > Details 1 > Home Tab, should be on home page', () => {
|
|
// Tests a bug when landing directly on a page thats not the originalHref and going back to home
|
|
cy.visit(`http://localhost:${port}/routing/tabs/home/details/1`)
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-page');
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.ionPageVisible('home-details-page-1');
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-page');
|
|
})
|
|
|
|
it('Home > Session Details Link > Session Details 2 > Back > Back, should be at home page', () => {
|
|
// Tests a bug when landing directly on a page thats not the originalHref and going back to home
|
|
cy.visit(`http://localhost:${port}/routing/tabs/home`)
|
|
cy.ionNav('a', 'Go to details 1 on settings')
|
|
cy.ionPageVisible('settings-details-page-1');
|
|
cy.ionNav('ion-button', 'Go to Settings Details 2')
|
|
cy.ionPageVisible('settings-details-page-2');
|
|
cy.ionBackClick('settings-details-page-2');
|
|
cy.ionPageVisible('settings-details-page-1');
|
|
cy.ionBackClick('settings-details-page-1');
|
|
cy.ionPageVisible('home-page');
|
|
})
|
|
|
|
it('Tab 3 > Other Page > Back, should be back on Tab 3', () => {
|
|
// Tests transferring from one outlet to another and back again with animation
|
|
// TODO: how to test the transition animation happens?
|
|
cy.visit(`http://localhost:${port}/routing/tabs/tab3`)
|
|
cy.ionNav('ion-button', 'Go to Other Page')
|
|
cy.ionPageVisible('other-page')
|
|
cy.ionBackClick('other-page')
|
|
cy.ionPageVisible('tab3-page')
|
|
})
|
|
|
|
it('/ > Menu > Favorites > Menu > Tabs, should be back on Home', () => {
|
|
// Tests transferring from one outlet to another and back again via menu
|
|
cy.visit(`http://localhost:${port}/routing`)
|
|
cy.ionMenuClick()
|
|
cy.ionMenuNav('Favorites')
|
|
cy.ionPageVisible('favorites-page')
|
|
cy.ionMenuClick()
|
|
cy.ionMenuNav('Tabs')
|
|
cy.ionPageVisible('home-page')
|
|
})
|
|
|
|
it('/ > Session Details > Details 2 > Details 3 > Browser Back * 3, should be back on home', () => {
|
|
// Tests browser back button
|
|
cy.visit(`http://localhost:${port}/routing/`)
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.ionPageVisible('home-details-page-1')
|
|
cy.ionNav('ion-button', 'Go to Details 2')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
cy.ionNav('ion-button', 'Go to Details 3')
|
|
cy.ionPageVisible('home-details-page-3')
|
|
cy.go('back')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
cy.go('back')
|
|
cy.ionPageVisible('home-details-page-1')
|
|
cy.go('back')
|
|
cy.ionPageVisible('home-page')
|
|
})
|
|
|
|
it('/ > Details 1 > Details 2 > Details 3 > Settings Tab > Home Tab > Browser Back, should be back on home', () => {
|
|
// Tests browser back button with a tab switch
|
|
cy.visit(`http://localhost:${port}/routing/`)
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.ionPageVisible('home-details-page-1')
|
|
cy.ionNav('ion-button', 'Go to Details 2')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
cy.ionNav('ion-button', 'Go to Details 3')
|
|
cy.ionPageVisible('home-details-page-3')
|
|
cy.ionTabClick('Settings')
|
|
cy.ionPageVisible('settings-page')
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-details-page-3')
|
|
cy.go('back')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
cy.get('ion-tab-button.tab-selected').contains('Home')
|
|
})
|
|
|
|
it('/ > Details 1 > Details 2 > Details 3 > Browser Back > Back > Back, should be back on home', () => {
|
|
// Tests browser back button with a tab switch
|
|
cy.visit(`http://localhost:${port}/routing/`)
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.ionPageVisible('home-details-page-1')
|
|
cy.ionNav('ion-button', 'Go to Details 2')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
cy.ionNav('ion-button', 'Go to Details 3')
|
|
cy.ionPageVisible('home-details-page-3')
|
|
cy.go('back')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
cy.ionBackClick('home-details-page-2')
|
|
cy.ionPageVisible('home-details-page-1')
|
|
cy.ionBackClick('home-details-page-1')
|
|
cy.ionPageVisible('home-page')
|
|
})
|
|
|
|
it('when props get passed into a route render, the component should update', () => {
|
|
cy.visit(`http://localhost:${port}/routing/propstest`)
|
|
cy.ionPageVisible('props-test')
|
|
cy.get('div[data-testid=count-label]').contains('1');
|
|
cy.contains('Increment').click();
|
|
cy.get('div[data-testid=count-label]').contains('2');
|
|
cy.contains('Increment').click();
|
|
cy.get('div[data-testid=count-label]').contains('3');
|
|
})
|
|
|
|
it('/asdf, when accessing a route not defined from root outlet, should show not found page', () => {
|
|
cy.visit(`http://localhost:${port}/routing/asdf`, { failOnStatusCode: false })
|
|
cy.ionPageVisible('not-found')
|
|
cy.get('div').contains('Not found')
|
|
})
|
|
|
|
|
|
it('/tabs/home > Details 1 on settings > Home Tab, should be back on home page', () => {
|
|
cy.visit(`http://localhost:${port}/routing/tabs/home`)
|
|
cy.ionNav('ion-item', 'Details 1 on settings')
|
|
cy.ionPageVisible('settings-details-page-1')
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-page')
|
|
})
|
|
|
|
it('/ > Details 1 on settings > Back > Settings Tab, should be on setting home', () => {
|
|
// For bug https://github.com/ionic-team/ionic/issues/21031
|
|
cy.visit(`http://localhost:${port}/routing/`)
|
|
cy.ionNav('ion-item', 'Details 1 on settings')
|
|
cy.ionPageVisible('settings-details-page-1')
|
|
cy.ionBackClick('settings-details-page-1')
|
|
cy.ionPageVisible('home-page')
|
|
cy.ionTabClick('Settings')
|
|
cy.ionPageVisible('settings-page')
|
|
})
|
|
|
|
it('/routing/tabs/redirect > Should be on settings page > Home Tab > Should be on home page', () => {
|
|
// tests that a redirect going to a tab other than the first tab works
|
|
// fixes bug https://github.com/ionic-team/ionic-framework/issues/21830
|
|
cy.visit(`http://localhost:${port}/routing/tabs/redirect`)
|
|
cy.ionPageVisible('settings-page')
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-page')
|
|
})
|
|
|
|
it('/routing/ > Details 1 > Details 2 > Details 3 > Back > Settings Tab > Home Tab > Should be at details 2 page', () => {
|
|
// fixes an issue where route history was being lost after starting to go back, switching tabs
|
|
// and switching back to the same tab again
|
|
// for bug https://github.com/ionic-team/ionic-framework/issues/21834
|
|
cy.visit(`http://localhost:${port}/routing`)
|
|
cy.ionPageVisible('home-page')
|
|
cy.ionNav('ion-item', 'Details 1')
|
|
cy.ionPageVisible('home-details-page-1')
|
|
cy.ionNav('ion-button', 'Go to Details 2')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
cy.ionNav('ion-button', 'Go to Details 3')
|
|
cy.ionPageVisible('home-details-page-3')
|
|
cy.ionBackClick('home-details-page-3')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
cy.ionTabClick('Settings')
|
|
cy.ionPageVisible('settings-page')
|
|
cy.ionTabClick('Home')
|
|
cy.ionPageVisible('home-details-page-2')
|
|
})
|
|
/*
|
|
Tests to add:
|
|
Test that lifecycle events fire
|
|
Test unmounting components by passing unmount to routerOptions
|
|
Test components mount/unmount properly
|
|
*/
|
|
|
|
})
|