mermaid/cypress/examples/assertions.spec.js

170 lines
5.4 KiB
JavaScript
Raw Normal View History

/// <reference types="Cypress" />
context('Assertions', () => {
beforeEach(() => {
2022-02-10 20:32:21 +01:00
cy.visit('https://example.cypress.io/commands/assertions');
});
describe('Implicit Assertions', () => {
it('.should() - make an assertion about the current subject', () => {
// https://on.cypress.io/should
cy.get('.assertion-table')
.find('tbody tr:last')
.should('have.class', 'success')
.find('td')
.first()
// checking the text of the <td> element in various ways
.should('have.text', 'Column content')
.should('contain', 'Column content')
.should('have.html', 'Column content')
// chai-jquery uses "is()" to check if element matches selector
.should('match', 'td')
// to match text content against a regular expression
// first need to invoke jQuery method text()
// and then match using regular expression
.invoke('text')
2022-02-10 20:32:21 +01:00
.should('match', /column content/i);
// a better way to check element's text content against a regular expression
// is to use "cy.contains"
// https://on.cypress.io/contains
cy.get('.assertion-table')
.find('tbody tr:last')
// finds first <td> element with text content matching regular expression
.contains('td', /column content/i)
2022-02-10 20:32:21 +01:00
.should('be.visible');
// for more information about asserting element's text
// see https://on.cypress.io/using-cypress-faq#How-do-I-get-an-elements-text-contents
2022-02-10 20:32:21 +01:00
});
it('.and() - chain multiple assertions together', () => {
// https://on.cypress.io/and
cy.get('.assertions-link')
.should('have.class', 'active')
.and('have.attr', 'href')
2022-02-10 20:32:21 +01:00
.and('include', 'cypress.io');
});
});
describe('Explicit Assertions', () => {
// https://on.cypress.io/assertions
it('expect - make an assertion about a specified subject', () => {
// We can use Chai's BDD style assertions
2022-02-10 20:32:21 +01:00
expect(true).to.be.true;
const o = { foo: 'bar' };
2022-02-10 20:32:21 +01:00
expect(o).to.equal(o);
expect(o).to.deep.equal({ foo: 'bar' });
// matching text using regular expression
2022-02-10 20:32:21 +01:00
expect('FooBar').to.match(/bar$/i);
});
it('pass your own callback function to should()', () => {
// Pass a function to should that can have any number
// of explicit assertions within it.
// The ".should(cb)" function will be retried
// automatically until it passes all your explicit assertions or times out.
cy.get('.assertions-p')
.find('p')
.should(($p) => {
// https://on.cypress.io/$
// return an array of texts from all of the p's
// @ts-ignore TS6133 unused variable
2022-02-10 20:32:21 +01:00
const texts = $p.map((i, el) => Cypress.$(el).text());
// jquery map returns jquery object
// and .get() convert this to simple array
2022-02-10 20:32:21 +01:00
const paragraphs = texts.get();
// array should have length of 3
2022-02-10 20:32:21 +01:00
expect(paragraphs, 'has 3 paragraphs').to.have.length(3);
// use second argument to expect(...) to provide clear
// message with each assertion
expect(paragraphs, 'has expected text in each paragraph').to.deep.eq([
'Some text from first p',
'More text from second p',
'And even more text from third p',
2022-02-10 20:32:21 +01:00
]);
});
});
it('finds element by class name regex', () => {
cy.get('.docs-header')
.find('div')
// .should(cb) callback function will be retried
.should(($div) => {
2022-02-10 20:32:21 +01:00
expect($div).to.have.length(1);
2022-02-10 20:32:21 +01:00
const className = $div[0].className;
2022-02-10 20:32:21 +01:00
expect(className).to.match(/heading-/);
})
// .then(cb) callback is not retried,
// it either passes or fails
.then(($div) => {
2022-02-10 20:32:21 +01:00
expect($div, 'text content').to.have.text('Introduction');
});
});
it('can throw any error', () => {
cy.get('.docs-header')
.find('div')
.should(($div) => {
if ($div.length !== 1) {
// you can throw your own errors
2022-02-10 20:32:21 +01:00
throw new Error('Did not find 1 element');
}
2022-02-10 20:32:21 +01:00
const className = $div[0].className;
if (!className.match(/heading-/)) {
2022-02-10 20:32:21 +01:00
throw new Error(`Could not find class "heading-" in ${className}`);
}
2022-02-10 20:32:21 +01:00
});
});
it('matches unknown text between two elements', () => {
/**
* Text from the first element.
2022-02-10 20:32:21 +01:00
*
* @type {string}
2022-02-10 20:32:21 +01:00
*/
let text;
/**
2022-02-10 20:32:21 +01:00
* Normalizes passed text, useful before comparing text with spaces and different capitalization.
*
* @param {string} s Text to normalize
2022-02-10 20:32:21 +01:00
*/
const normalizeText = (s) => s.replace(/\s/g, '').toLowerCase();
cy.get('.two-elements')
.find('.first')
.then(($first) => {
// save text from the first element
2022-02-10 20:32:21 +01:00
text = normalizeText($first.text());
});
cy.get('.two-elements')
.find('.second')
.should(($div) => {
// we can massage text before comparing
2022-02-10 20:32:21 +01:00
const secondText = normalizeText($div.text());
2022-02-10 20:32:21 +01:00
expect(secondText, 'second text').to.equal(text);
});
});
it('assert - assert shape of an object', () => {
const person = {
name: 'Joe',
age: 20,
2022-02-10 20:32:21 +01:00
};
2022-02-10 20:32:21 +01:00
assert.isObject(person, 'value is object');
});
});
});