2019-09-11 18:53:05 +02:00
|
|
|
/// <reference types="Cypress" />
|
|
|
|
|
|
|
|
context('Spies, Stubs, and Clock', () => {
|
|
|
|
it('cy.spy() - wrap a method in a spy', () => {
|
|
|
|
// https://on.cypress.io/spy
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.visit('https://example.cypress.io/commands/spies-stubs-clocks');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
const obj = {
|
2022-02-10 20:32:21 +01:00
|
|
|
foo() {},
|
|
|
|
};
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
const spy = cy.spy(obj, 'foo').as('anyArgs');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
obj.foo();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
expect(spy).to.be.called;
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('cy.spy() retries until assertions pass', () => {
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.visit('https://example.cypress.io/commands/spies-stubs-clocks');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
const obj = {
|
|
|
|
/**
|
|
|
|
* Prints the argument passed
|
2022-02-10 20:32:21 +01:00
|
|
|
*
|
2019-09-11 18:53:05 +02:00
|
|
|
* @param x {any}
|
2022-02-10 20:32:21 +01:00
|
|
|
*/
|
|
|
|
foo(x) {
|
|
|
|
console.log('obj.foo called with', x);
|
2019-09-11 18:53:05 +02:00
|
|
|
},
|
2022-02-10 20:32:21 +01:00
|
|
|
};
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.spy(obj, 'foo').as('foo');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
setTimeout(() => {
|
2022-02-10 20:32:21 +01:00
|
|
|
obj.foo('first');
|
|
|
|
}, 500);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
setTimeout(() => {
|
2022-02-10 20:32:21 +01:00
|
|
|
obj.foo('second');
|
|
|
|
}, 2500);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.get('@foo').should('have.been.calledTwice');
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('cy.stub() - create a stub and/or replace a function with stub', () => {
|
|
|
|
// https://on.cypress.io/stub
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.visit('https://example.cypress.io/commands/spies-stubs-clocks');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
const obj = {
|
|
|
|
/**
|
2022-02-10 20:32:21 +01:00
|
|
|
* Prints both arguments to the console
|
|
|
|
*
|
2019-09-11 18:53:05 +02:00
|
|
|
* @param a {string}
|
|
|
|
* @param b {string}
|
2022-02-10 20:32:21 +01:00
|
|
|
*/
|
|
|
|
foo(a, b) {
|
|
|
|
console.log('a', a, 'b', b);
|
2019-09-11 18:53:05 +02:00
|
|
|
},
|
2022-02-10 20:32:21 +01:00
|
|
|
};
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
const stub = cy.stub(obj, 'foo').as('foo');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
obj.foo('foo', 'bar');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
expect(stub).to.be.called;
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('cy.clock() - control time in the browser', () => {
|
|
|
|
// https://on.cypress.io/clock
|
|
|
|
|
|
|
|
// create the date in UTC so its always the same
|
|
|
|
// no matter what local timezone the browser is running in
|
2022-02-10 20:32:21 +01:00
|
|
|
const now = new Date(Date.UTC(2017, 2, 14)).getTime();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.clock(now);
|
|
|
|
cy.visit('https://example.cypress.io/commands/spies-stubs-clocks');
|
|
|
|
cy.get('#clock-div').click().should('have.text', '1489449600');
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('cy.tick() - move time in the browser', () => {
|
|
|
|
// https://on.cypress.io/tick
|
|
|
|
|
|
|
|
// create the date in UTC so its always the same
|
|
|
|
// no matter what local timezone the browser is running in
|
2022-02-10 20:32:21 +01:00
|
|
|
const now = new Date(Date.UTC(2017, 2, 14)).getTime();
|
|
|
|
|
|
|
|
cy.clock(now);
|
|
|
|
cy.visit('https://example.cypress.io/commands/spies-stubs-clocks');
|
|
|
|
cy.get('#tick-div').click().should('have.text', '1489449600');
|
|
|
|
cy.tick(10000); // 10 seconds passed
|
|
|
|
cy.get('#tick-div').click().should('have.text', '1489449610');
|
|
|
|
});
|
|
|
|
});
|