UNPKG

passbolt-styleguide

Version:

Passbolt styleguide contains common styling assets used by the different sites, plugin, etc.

157 lines (138 loc) 4.07 kB
/** * Passbolt ~ Open source password manager for teams * Copyright (c) 2020 Passbolt SA (https://www.passbolt.com) * * Licensed under GNU Affero General Public License version 3 of the or any later version. * For full copyright and license information, please see the LICENSE.txt * Redistributions of files must retain the above copyright notice. * * @copyright Copyright (c) 2020 Passbolt SA (https://www.passbolt.com) * @license https://opensource.org/licenses/AGPL-3.0 AGPL License * @link https://www.passbolt.com Passbolt(tm) * @since 3.0.0 */ import {fireEvent, render, waitFor} from "@testing-library/react"; import React from "react"; import CheckPassphrase from "./CheckPassphrase"; import MockTranslationProvider from "../../../test/mock/components/Internationalisation/MockTranslationProvider"; /** * The CheckPassphrase component represented as a page */ export default class CheckPassphrasePage { /** * Default constructor * @param props Props to attach */ constructor(props) { this._page = render( <MockTranslationProvider> <CheckPassphrase {...props}/> </MockTranslationProvider> ); } /** * Returns the passphrase value */ get passphrase() { return this.passphraseInput.value; } /** * REturns passphrase input */ get passphraseInput() { return this._page.container.querySelector('#passphrase'); } /** * Returns the token code value */ get rememberMe() { return this.rememberMeInput.value; } /** * Returns remember me input */ get rememberMeInput() { return this._page.container.querySelector('#remember-me'); } get canRememberMe() { return Boolean(this.rememberMeInput); } /** * Returns the verify button element */ get verifyButton() { return this._page.container.querySelector('.button.primary'); } /** * Returns the secondary action link element */ get secondaryActionLink() { return this._page.container.querySelector('.form-actions a'); } /** * Returns the warning message for powned password */ get warningMessage() { return this._page.container.querySelector('.warning-message'); } /** * Returns true if the user can change something like the token code */ get canChange() { const cannotChangePassphrase = this.passphraseInput.hasAttribute('disabled'); const cannotChangeRememberMe = this.rememberMeInput?.hasAttribute('disabled'); return !cannotChangePassphrase && !cannotChangeRememberMe; } /** * Returns true if one is processing */ get isProcessing() { return this.verifyButton.getAttribute('class').indexOf('processing') > -1; } /** * Returns true if the empty error message is displayed */ get hasEmptyPassphraseError() { return Boolean(this._page.container.querySelector('.empty-passphrase')); } /** * Returns true if the invalid passphrase error is displayed */ hasInvalidPassphraseError() { return Boolean(this._page.container.querySelector('.invalid-passphrase')); } /** * Toggle the remember me value */ async toggleRememberMe() { const leftClick = {button: 0}; fireEvent.click(this.rememberMeInput, leftClick); await waitFor(() => {}); } /** * Fill the passphrase with the given value * @param passphrase A passphrase */ async fillPassphrase(passphrase) { fireEvent.change(this.passphraseInput, {target: {value: passphrase}}); jest.runAllTimers(); await waitFor(() => {}); } /** * Verify the passphrase validity * @param inProgressFn The function called while saving */ async verify(inProgressFn = () => {}) { const leftClick = {button: 0}; fireEvent.click(this.verifyButton, leftClick); await waitFor(inProgressFn); } /** * Click on the secondary action link. */ async clickSecondaryActionLink(inProgressFn = () => {}) { const leftClick = {button: 0}; fireEvent.click(this.secondaryActionLink, leftClick); await waitFor(inProgressFn); } }