mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-15 17:42:15 +08:00
80 lines
3.0 KiB
JavaScript
80 lines
3.0 KiB
JavaScript
// ***********************************************
|
|
// This example commands.js shows you how to
|
|
// create various custom commands and overwrite
|
|
// existing commands.
|
|
//
|
|
// For more comprehensive examples of custom
|
|
// commands please read more here:
|
|
// https://on.cypress.io/custom-commands
|
|
// ***********************************************
|
|
//
|
|
//
|
|
// -- This is a parent command --
|
|
// Cypress.Commands.add('login', (email, password) => { ... })
|
|
//
|
|
//
|
|
// -- This is a child command --
|
|
// Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... })
|
|
//
|
|
//
|
|
// -- This is a dual command --
|
|
// Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... })
|
|
//
|
|
//
|
|
// -- This will overwrite an existing command --
|
|
// Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... })
|
|
|
|
Cypress.Commands.add('ionSwipeToGoBack', (complete = false, selector = 'ion-router-outlet') => {
|
|
const increment = complete ? 60 : 25;
|
|
cy.get(selector)
|
|
.first()
|
|
.trigger('mousedown', 0, 275, { which: 1, force: true })
|
|
.trigger('mousemove', increment * 1, 275, { which: 1, force: true })
|
|
.wait(50)
|
|
.trigger('mousemove', increment * 2, 275, { which: 1, force: true })
|
|
.wait(50)
|
|
.trigger('mousemove', increment * 3, 275, { which: 1, force: true })
|
|
.wait(50)
|
|
.trigger('mousemove', increment * 4, 275, { which: 1, force: true })
|
|
.wait(50)
|
|
.trigger('mouseup', increment * 4, 275, { which: 1, force: true });
|
|
cy.wait(150);
|
|
});
|
|
|
|
Cypress.Commands.add('testStack', (selector, expected) => {
|
|
cy.document().then((doc) => {
|
|
const children = Array.from(doc.querySelector(selector).children).map((el) => el.tagName.toLowerCase());
|
|
expect(children).to.deep.equal(expected);
|
|
});
|
|
});
|
|
|
|
Cypress.Commands.add('testLifeCycle', (selector, expected) => {
|
|
cy.get(`${selector} #ngOnInit`).invoke('text').should('equal', '1');
|
|
cy.get(`${selector} #ionViewWillEnter`).invoke('text').should('equal', expected.ionViewWillEnter.toString());
|
|
cy.get(`${selector} #ionViewDidEnter`).invoke('text').should('equal', expected.ionViewDidEnter.toString());
|
|
cy.get(`${selector} #ionViewWillLeave`).invoke('text').should('equal', expected.ionViewWillLeave.toString());
|
|
cy.get(`${selector} #ionViewDidLeave`).invoke('text').should('equal', expected.ionViewDidLeave.toString());
|
|
});
|
|
|
|
Cypress.Commands.add('ionPageVisible', (selector) => {
|
|
cy.get(selector)
|
|
.should('have.class', 'ion-page')
|
|
.should('not.have.class', 'ion-page-hidden')
|
|
.should('not.have.class', 'ion-page-invisible')
|
|
.should('have.length', 1);
|
|
});
|
|
|
|
Cypress.Commands.add('ionPageHidden', (selector) => {
|
|
cy.get(selector).should('have.class', 'ion-page').should('have.class', 'ion-page-hidden').should('have.length', 1);
|
|
});
|
|
|
|
Cypress.Commands.add('ionPageDoesNotExist', (selector) => {
|
|
cy.get(selector).should('not.exist');
|
|
});
|
|
|
|
Cypress.Commands.add('ionTabClick', (tabText) => {
|
|
// TODO FW-2790: Figure out how to get rid of wait. It's a workaround for flakiness in CI.
|
|
cy.wait(250);
|
|
cy.contains('ion-tab-button', tabText).click({ force: true });
|
|
});
|