You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
nextcloud/cypress/e2e/settings/usersUtils.ts

91 lines
3.0 KiB
TypeScript

/**
* 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)))
}