* test(UI): Add UI tests using cypress * test: Add test configuration for travis * fix: Lock redis version * fix: Refactor fill_field command * fix: Rename setup_wizard test to run first * test: Add setup for dashboard service * test: Add build matrix for ui test * test: Add name to each build matrix * test: Only include ui test for an extra build stage * fix: Exclude UI test with python 3.6 * test: Test order * test: Enable developer_mode * test(login): Check session user and not hash * test: Refactor assert * test: Refactor setup wizard test * test: Remove setup wizard test * test: Add blank seed database * test(form): Scroll to top before save * test: Fix form test * test: timeout * test: more wait * test: Remove specific selector * test: Remove wait, delay typing * test: Blur input after typing * test: Wait for form to get dirty * test: Add credentials for frappe org * test: Remove node install step * style: Fix linting issues * fix: List view filters - ToDo: Dont override frappe.route_options if it is already set * test: Dont reload page before test
52 lines
No EOL
1.4 KiB
JavaScript
52 lines
No EOL
1.4 KiB
JavaScript
// ***********************************************
|
|
// This example commands.js shows you how to
|
|
// create various custom commands and overwrite
|
|
// existing commands.
|
|
//
|
|
// For more comprehensive examples of custom
|
|
// commands please read more here:
|
|
// https://on.cypress.io/custom-commands
|
|
// ***********************************************
|
|
//
|
|
//
|
|
// -- This is a parent command --
|
|
// Cypress.Commands.add("login", (email, password) => { ... });
|
|
//
|
|
//
|
|
// -- This is a child command --
|
|
// Cypress.Commands.add("drag", { prevSubject: 'element'}, (subject, options) => { ... });
|
|
//
|
|
//
|
|
// -- This is a dual command --
|
|
// Cypress.Commands.add("dismiss", { prevSubject: 'optional'}, (subject, options) => { ... });
|
|
//
|
|
//
|
|
// -- This is will overwrite an existing command --
|
|
// Cypress.Commands.overwrite("visit", (originalFn, url, options) => { ... });
|
|
Cypress.Commands.add('login', (email, password) => {
|
|
cy.request({
|
|
url: '/',
|
|
method: 'POST',
|
|
body: {
|
|
cmd: 'login',
|
|
usr: email,
|
|
pwd: password
|
|
}
|
|
});
|
|
});
|
|
|
|
Cypress.Commands.add('fill_field', (fieldname, value, fieldtype='Data') => {
|
|
let selector = `.form-control[data-fieldname="${fieldname}"]`;
|
|
|
|
if (fieldtype === 'Text Editor') {
|
|
selector = `[data-fieldname="${fieldname}"] .ql-editor`;
|
|
}
|
|
|
|
cy.get(selector).as('input');
|
|
|
|
if (fieldtype === 'Select') {
|
|
return cy.get('@input').select(value);
|
|
} else {
|
|
return cy.get('@input').type(value);
|
|
}
|
|
}); |