2024-06-10 06:49:50 -07:00
|
|
|
import generateOTPToken from 'cypress-otp';
|
2024-09-18 00:19:33 -07:00
|
|
|
|
|
|
|
import { BasePage } from './base';
|
2023-02-10 04:12:06 -08:00
|
|
|
import { ChangePasswordModal } from './modals/change-password-modal';
|
2023-08-23 19:59:16 -07:00
|
|
|
import { MfaSetupModal } from './modals/mfa-setup-modal';
|
2023-02-10 04:12:06 -08:00
|
|
|
|
|
|
|
const changePasswordModal = new ChangePasswordModal();
|
2023-08-23 19:59:16 -07:00
|
|
|
const mfaSetupModal = new MfaSetupModal();
|
2023-02-10 04:12:06 -08:00
|
|
|
|
2025-01-08 00:36:44 -08:00
|
|
|
/**
|
|
|
|
* @deprecated Use functional composables from @composables instead.
|
|
|
|
* If a composable doesn't exist for your use case, please create a new one in:
|
|
|
|
* cypress/composables
|
|
|
|
*
|
|
|
|
* This class-based approach is being phased out in favor of more modular functional composables.
|
|
|
|
* Each getter and action in this class should be moved to individual composable functions.
|
|
|
|
*/
|
2023-02-10 04:12:06 -08:00
|
|
|
export class PersonalSettingsPage extends BasePage {
|
|
|
|
url = '/settings/personal';
|
2024-06-10 06:49:50 -07:00
|
|
|
|
2023-08-23 19:59:16 -07:00
|
|
|
secret = '';
|
|
|
|
|
2023-02-10 04:12:06 -08:00
|
|
|
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(),
|
2023-07-28 00:51:07 -07:00
|
|
|
changePasswordLink: () => cy.getByTestId('change-password-link').first(),
|
2023-02-10 04:12:06 -08:00
|
|
|
saveSettingsButton: () => cy.getByTestId('save-settings-button'),
|
2023-08-23 19:59:16 -07:00
|
|
|
enableMfaButton: () => cy.getByTestId('enable-mfa-button'),
|
|
|
|
disableMfaButton: () => cy.getByTestId('disable-mfa-button'),
|
2024-12-03 04:15:29 -08:00
|
|
|
mfaCodeOrMfaRecoveryCodeInput: () => cy.getByTestId('mfa-code-or-recovery-code-input'),
|
|
|
|
mfaSaveButton: () => cy.getByTestId('mfa-save-button'),
|
2023-11-01 05:33:36 -07:00
|
|
|
themeSelector: () => cy.getByTestId('theme-select'),
|
|
|
|
selectOptionsVisible: () => cy.get('.el-select-dropdown:visible .el-select-dropdown__item'),
|
2023-02-10 04:12:06 -08:00
|
|
|
};
|
2024-06-10 06:49:50 -07:00
|
|
|
|
2023-02-10 04:12:06 -08:00
|
|
|
actions = {
|
2023-11-01 05:33:36 -07:00
|
|
|
changeTheme: (theme: 'System default' | 'Dark' | 'Light') => {
|
|
|
|
this.getters.themeSelector().click();
|
|
|
|
this.getters.selectOptionsVisible().should('have.length', 3);
|
|
|
|
this.getters.selectOptionsVisible().contains(theme).click();
|
2024-06-11 05:45:15 -07:00
|
|
|
this.getters.saveSettingsButton().realClick();
|
2023-11-01 05:33:36 -07:00
|
|
|
},
|
2023-02-10 04:12:06 -08:00
|
|
|
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);
|
2023-07-28 00:51:07 -07:00
|
|
|
changePasswordModal.getters
|
|
|
|
.newPasswordInputContainer()
|
|
|
|
.find('div[class^="_errorInput"]')
|
|
|
|
.should('exist');
|
2023-02-10 04:12:06 -08:00
|
|
|
},
|
|
|
|
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));
|
|
|
|
},
|
2023-08-23 19:59:16 -07:00
|
|
|
enableMfa: () => {
|
|
|
|
cy.visit(this.url);
|
|
|
|
this.getters.enableMfaButton().click();
|
2023-10-06 02:06:38 -07:00
|
|
|
cy.wait('@getMfaQrCode');
|
|
|
|
mfaSetupModal.getters.copySecretToClipboardButton().should('be.visible');
|
2023-08-23 19:59:16 -07:00
|
|
|
mfaSetupModal.getters.copySecretToClipboardButton().realClick();
|
|
|
|
cy.readClipboard().then((secret) => {
|
2023-09-01 04:29:31 -07:00
|
|
|
const token = generateOTPToken(secret);
|
2023-08-24 06:31:37 -07:00
|
|
|
|
|
|
|
mfaSetupModal.getters.tokenInput().type(token);
|
2023-10-06 02:06:38 -07:00
|
|
|
mfaSetupModal.getters.downloadRecoveryCodesButton().should('be.visible');
|
2023-08-24 06:31:37 -07:00
|
|
|
mfaSetupModal.getters.downloadRecoveryCodesButton().click();
|
|
|
|
mfaSetupModal.getters.saveButton().click();
|
2023-08-23 19:59:16 -07:00
|
|
|
});
|
|
|
|
},
|
2024-12-03 04:15:29 -08:00
|
|
|
disableMfa: (mfaCodeOrRecoveryCode: string) => {
|
2023-08-23 19:59:16 -07:00
|
|
|
cy.visit(this.url);
|
|
|
|
this.getters.disableMfaButton().click();
|
2024-12-03 04:15:29 -08:00
|
|
|
this.getters.mfaCodeOrMfaRecoveryCodeInput().type(mfaCodeOrRecoveryCode);
|
|
|
|
this.getters.mfaSaveButton().click();
|
2023-08-23 19:59:16 -07:00
|
|
|
},
|
2023-02-10 04:12:06 -08:00
|
|
|
};
|
|
|
|
}
|