n8n/cypress/pages/settings-personal.ts
Milorad FIlipović 4e491b754f
fix(editor): Vue3 - Fix modal positioning and multi-select tag sizing (#6783)
*  Updating modals positioning within the overlay
* 💄 Implemented multi-select variant with small tabs
* ✔️ Removing password link clicks while modal is open in e2e tests
* Set generous timeout for $paramter resolve
Signed-off-by: Oleg Ivaniv <me@olegivaniv.com>
---------
Signed-off-by: Oleg Ivaniv <me@olegivaniv.com>
Co-authored-by: Oleg Ivaniv <me@olegivaniv.com>
2023-07-28 17:57:25 +02:00

55 lines
2.3 KiB
TypeScript

import { ChangePasswordModal } from './modals/change-password-modal';
import { BasePage } from './base';
const changePasswordModal = new ChangePasswordModal();
export class PersonalSettingsPage extends BasePage {
url = '/settings/personal';
getters = {
currentUserName: () => cy.getByTestId('current-user-name'),
firstNameInput: () => cy.getByTestId('firstName').find('input').first(),
lastNameInput: () => cy.getByTestId('lastName').find('input').first(),
emailInputContainer: () => cy.getByTestId('email'),
emailInput: () => cy.getByTestId('email').find('input').first(),
changePasswordLink: () => cy.getByTestId('change-password-link').first(),
saveSettingsButton: () => cy.getByTestId('save-settings-button'),
};
actions = {
loginAndVisit: (email: string, password: string) => {
cy.signin({ email, password });
cy.visit(this.url);
},
updateFirstAndLastName: (newFirstName: string, newLastName: string) => {
this.getters.firstNameInput().type('{selectall}').type(newFirstName);
this.getters.lastNameInput().type('{selectall}').type(newLastName);
this.getters.saveSettingsButton().realClick();
},
updatePassword: (oldPassword: string, newPassword: string) => {
changePasswordModal.getters.modalContainer().should('be.visible');
changePasswordModal.getters.currentPasswordInput().type('{selectall}').type(oldPassword);
changePasswordModal.getters.newPasswordInput().type('{selectall}').type(newPassword);
changePasswordModal.getters.repeatPasswordInput().type('{selectall}').type(newPassword);
changePasswordModal.getters.changePasswordButton().click();
},
tryToSetWeakPassword: (oldPassword: string, newPassword: string) => {
this.actions.updatePassword(oldPassword, newPassword);
changePasswordModal.getters
.newPasswordInputContainer()
.find('div[class^="_errorInput"]')
.should('exist');
},
updateEmail: (newEmail: string) => {
this.getters.emailInput().type('{selectall}').type(newEmail).type('{enter}');
},
tryToSetInvalidEmail: (newEmail: string) => {
this.actions.updateEmail(newEmail);
this.getters.emailInputContainer().find('div[class^="_errorInput"]').should('exist');
},
loginWithNewData: (email: string, password: string) => {
cy.signout();
this.actions.loginAndVisit(email, password);
cy.url().should('match', new RegExp(this.url));
},
};
}