mermaid/cypress/examples/aliasing.spec.js

37 lines
1.1 KiB
JavaScript
Raw Normal View History

/// <reference types="Cypress" />
context('Aliasing', () => {
beforeEach(() => {
2022-02-10 20:32:21 +01:00
cy.visit('https://example.cypress.io/commands/aliasing');
});
it('.as() - alias a DOM element for later use', () => {
// https://on.cypress.io/as
// Alias a DOM element for use later
// We don't have to traverse to the element
// later in our code, we reference it with @
2022-02-10 20:32:21 +01:00
cy.get('.as-table').find('tbody>tr').first().find('td').first().find('button').as('firstBtn');
// when we reference the alias, we place an
// @ in front of its name
2022-02-10 20:32:21 +01:00
cy.get('@firstBtn').click();
2022-02-10 20:32:21 +01:00
cy.get('@firstBtn').should('have.class', 'btn-success').and('contain', 'Changed');
});
it('.as() - alias a route for later use', () => {
// Alias the route to wait for its response
2022-02-10 20:32:21 +01:00
cy.server();
cy.route('GET', 'comments/*').as('getComment');
// we have code that gets a comment when
// the button is clicked in scripts.js
2022-02-10 20:32:21 +01:00
cy.get('.network-btn').click();
// https://on.cypress.io/wait
2022-02-10 20:32:21 +01:00
cy.wait('@getComment').its('status').should('eq', 200);
});
});