2019-12-18 18:16:02 +02:00
|
|
|
export const before = (taskResult, options, backend = 'github') => {
|
|
|
|
Cypress.config('taskTimeout', 7 * 60 * 1000);
|
2019-10-22 19:59:13 +03:00
|
|
|
cy.task('setupBackend', { backend, options }).then(data => {
|
|
|
|
taskResult.data = data;
|
|
|
|
Cypress.config('defaultCommandTimeout', data.mockResponses ? 5 * 1000 : 1 * 60 * 1000);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2019-12-18 18:16:02 +02:00
|
|
|
export const after = (taskResult, backend = 'github') => {
|
2019-10-22 19:59:13 +03:00
|
|
|
cy.task('teardownBackend', {
|
|
|
|
backend,
|
|
|
|
...taskResult.data,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2019-12-18 18:16:02 +02:00
|
|
|
export const beforeEach = (taskResult, backend = 'github') => {
|
2019-10-22 19:59:13 +03:00
|
|
|
const spec = Cypress.mocha.getRunner().suite.ctx.currentTest.parent.title;
|
|
|
|
const testName = Cypress.mocha.getRunner().suite.ctx.currentTest.title;
|
|
|
|
cy.task('setupBackendTest', {
|
|
|
|
backend,
|
|
|
|
...taskResult.data,
|
|
|
|
spec,
|
|
|
|
testName,
|
|
|
|
});
|
|
|
|
|
|
|
|
if (taskResult.data.mockResponses) {
|
|
|
|
const fixture = `${spec}__${testName}.json`;
|
|
|
|
console.log('loading fixture:', fixture);
|
|
|
|
cy.stubFetch({ fixture });
|
|
|
|
}
|
|
|
|
|
|
|
|
return cy.clock(0, ['Date']);
|
|
|
|
};
|
|
|
|
|
2019-12-18 18:16:02 +02:00
|
|
|
export const afterEach = (taskResult, backend = 'github') => {
|
2019-10-22 19:59:13 +03:00
|
|
|
const spec = Cypress.mocha.getRunner().suite.ctx.currentTest.parent.title;
|
|
|
|
const testName = Cypress.mocha.getRunner().suite.ctx.currentTest.title;
|
|
|
|
|
|
|
|
cy.task('teardownBackendTest', {
|
|
|
|
backend,
|
|
|
|
...taskResult.data,
|
|
|
|
spec,
|
|
|
|
testName,
|
|
|
|
});
|
|
|
|
|
|
|
|
if (Cypress.mocha.getRunner().suite.ctx.currentTest.state === 'failed') {
|
|
|
|
Cypress.runner.stop();
|
|
|
|
}
|
|
|
|
};
|