2019-09-11 18:53:05 +02:00
|
|
|
|
/// <reference types="Cypress" />
|
|
|
|
|
|
|
|
|
|
context('Assertions', () => {
|
|
|
|
|
beforeEach(() => {
|
2022-02-10 20:32:21 +01:00
|
|
|
|
cy.visit('https://example.cypress.io/commands/assertions');
|
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
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);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
// 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');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
// for more information about asserting element's text
|
|
|
|
|
// see https://on.cypress.io/using-cypress-faq#How-do-I-get-an-element’s-text-contents
|
2022-02-10 20:32:21 +01:00
|
|
|
|
});
|
2019-09-11 18:53:05 +02: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');
|
|
|
|
|
});
|
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
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' };
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
|
expect(o).to.equal(o);
|
|
|
|
|
expect(o).to.deep.equal({ foo: 'bar' });
|
2019-09-11 18:53:05 +02:00
|
|
|
|
// matching text using regular expression
|
2022-02-10 20:32:21 +01:00
|
|
|
|
expect('FooBar').to.match(/bar$/i);
|
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
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());
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
// jquery map returns jquery object
|
|
|
|
|
// and .get() convert this to simple array
|
2022-02-10 20:32:21 +01:00
|
|
|
|
const paragraphs = texts.get();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
// array should have length of 3
|
2022-02-10 20:32:21 +01:00
|
|
|
|
expect(paragraphs, 'has 3 paragraphs').to.have.length(3);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
// 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
|
|
|
|
]);
|
|
|
|
|
});
|
|
|
|
|
});
|
2019-09-11 18:53:05 +02: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);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
|
const className = $div[0].className;
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
|
expect(className).to.match(/heading-/);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
})
|
|
|
|
|
// .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');
|
|
|
|
|
});
|
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
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');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
}
|
|
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
|
const className = $div[0].className;
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
if (!className.match(/heading-/)) {
|
2022-02-10 20:32:21 +01:00
|
|
|
|
throw new Error(`Could not find class "heading-" in ${className}`);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
}
|
2022-02-10 20:32:21 +01:00
|
|
|
|
});
|
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
it('matches unknown text between two elements', () => {
|
|
|
|
|
/**
|
|
|
|
|
* Text from the first element.
|
2022-02-10 20:32:21 +01:00
|
|
|
|
*
|
2019-09-11 18:53:05 +02:00
|
|
|
|
* @type {string}
|
2022-02-10 20:32:21 +01:00
|
|
|
|
*/
|
|
|
|
|
let text;
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
/**
|
2022-02-10 20:32:21 +01:00
|
|
|
|
* Normalizes passed text, useful before comparing text with spaces and different capitalization.
|
|
|
|
|
*
|
2019-09-11 18:53:05 +02:00
|
|
|
|
* @param {string} s Text to normalize
|
2022-02-10 20:32:21 +01:00
|
|
|
|
*/
|
|
|
|
|
const normalizeText = (s) => s.replace(/\s/g, '').toLowerCase();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
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());
|
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
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());
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
|
expect(secondText, 'second text').to.equal(text);
|
|
|
|
|
});
|
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
|
|
it('assert - assert shape of an object', () => {
|
|
|
|
|
const person = {
|
|
|
|
|
name: 'Joe',
|
|
|
|
|
age: 20,
|
2022-02-10 20:32:21 +01:00
|
|
|
|
};
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
|
assert.isObject(person, 'value is object');
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|