123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- /**
- * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- import type { User } from '@nextcloud/cypress'
- /**
- * Assert that `element` does not exist or is not visible
- * Useful in cases such as when NcModal is opened/closed rapidly
- * @param element Element that is inspected
- */
- export function assertNotExistOrNotVisible(element: JQuery<HTMLElement>) {
- const doesNotExist = element.length === 0
- const isNotVisible = !element.is(':visible')
- // eslint-disable-next-line no-unused-expressions
- expect(doesNotExist || isNotVisible, 'does not exist or is not visible').to.be.true
- }
- /**
- * Get the settings users list
- * @return Cypress chainable object
- */
- export function getUserList() {
- return cy.get('[data-cy-user-list]')
- }
- /**
- * Get the row entry for given userId within the settings users list
- *
- * @param userId the user to query
- * @return Cypress chainable object
- */
- export function getUserListRow(userId: string) {
- return getUserList().find(`[data-cy-user-row="${userId}"]`)
- }
- export function waitLoading(selector: string) {
- // We need to make sure the element is loading, otherwise the "done loading" will succeed even if we did not start loading.
- // But Cypress might also be simply too slow to catch the loading phase. Thats why we need to wait in this case.
- // eslint-disable-next-line cypress/no-unnecessary-waiting
- cy.get(`${selector}[data-loading]`).if().should('exist').else().wait(1000)
- // https://github.com/NoriSte/cypress-wait-until/issues/75#issuecomment-572685623
- cy.waitUntil(() => Cypress.$(selector).length > 0 && !Cypress.$(selector).attr('data-loading')?.length, { timeout: 10000 })
- }
- /**
- * Toggle the edit button of the user row
- * @param user The user row to edit
- * @param toEdit True if it should be switch to edit mode, false to switch to read-only
- */
- export function toggleEditButton(user: User, toEdit = true) {
- // see that the list of users contains the user
- getUserListRow(user.userId).should('exist')
- // toggle the edit mode for the user
- .find('[data-cy-user-list-cell-actions]')
- .find(`[data-cy-user-list-action-toggle-edit="${!toEdit}"]`)
- .if()
- .click({ force: true })
- .else()
- // otherwise ensure the button is already in edit mode
- .then(() => getUserListRow(user.userId)
- .find(`[data-cy-user-list-action-toggle-edit="${toEdit}"]`)
- .should('exist'),
- )
- }
- /**
- * Handle the confirm password dialog (if needed)
- * @param adminPassword The admin password for the dialog
- */
- export function handlePasswordConfirmation(adminPassword = 'admin') {
- const handleModal = (context: Cypress.Chainable) => {
- return context.contains('.modal-container', 'Confirm your password')
- .if()
- .within(() => {
- cy.get('input[type="password"]').type(adminPassword)
- cy.get('button').contains('Confirm').click()
- })
- }
- return cy.get('body')
- .if()
- .then(() => handleModal(cy.get('body')))
- .else()
- // Handle if inside a cy.within
- .root().closest('body')
- .then(($body) => handleModal(cy.wrap($body)))
- }
|