2019-09-11 18:53:05 +02:00
|
|
|
/// <reference types="Cypress" />
|
|
|
|
|
|
|
|
context('Aliasing', () => {
|
|
|
|
beforeEach(() => {
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.visit('https://example.cypress.io/commands/aliasing');
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
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 @
|
|
|
|
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.get('.as-table').find('tbody>tr').first().find('td').first().find('button').as('firstBtn');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// when we reference the alias, we place an
|
|
|
|
// @ in front of its name
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.get('@firstBtn').click();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.get('@firstBtn').should('have.class', 'btn-success').and('contain', 'Changed');
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('.as() - alias a route for later use', () => {
|
|
|
|
// Alias the route to wait for its response
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.server();
|
|
|
|
cy.route('GET', 'comments/*').as('getComment');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// we have code that gets a comment when
|
|
|
|
// the button is clicked in scripts.js
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.get('.network-btn').click();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// https://on.cypress.io/wait
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.wait('@getComment').its('status').should('eq', 200);
|
|
|
|
});
|
|
|
|
});
|