From: Christopher Ng Date: Wed, 2 Aug 2023 18:38:48 +0000 (-0700) Subject: fix(cypress): Show and hide columns X-Git-Tag: v28.0.0beta1~579^2 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=refs%2Fpull%2F39682%2Fhead;p=nextcloud-server.git fix(cypress): Show and hide columns Signed-off-by: Christopher Ng --- diff --git a/cypress/e2e/settings/usersUtils.ts b/cypress/e2e/settings/usersUtils.ts new file mode 100644 index 00000000000..60ca42db7d9 --- /dev/null +++ b/cypress/e2e/settings/usersUtils.ts @@ -0,0 +1,33 @@ +/** + * @copyright 2023 Christopher Ng + * + * @author Christopher Ng + * + * @license AGPL-3.0-or-later + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + * + */ + +/** + * Assert that `element` does not exist or is not visible + * + * Useful in cases such as when NcModal is opened/closed rapidly + */ +export function assertNotExistOrNotVisible(element: JQuery) { + const doesNotExist = element.length === 0 + const isNotVisible = !element.is(':visible') + + expect(doesNotExist || isNotVisible, 'does not exist or is not visible').to.be.true +} diff --git a/cypress/e2e/settings/users_columns.cy.ts b/cypress/e2e/settings/users_columns.cy.ts index 84222cc7477..67363fb578a 100644 --- a/cypress/e2e/settings/users_columns.cy.ts +++ b/cypress/e2e/settings/users_columns.cy.ts @@ -21,6 +21,7 @@ */ import { User } from '@nextcloud/cypress' +import { assertNotExistOrNotVisible } from './usersUtils.js' const admin = new User('admin', 'admin') @@ -43,7 +44,7 @@ describe('Settings: Show and hide columns', function() { // close the settings dialog cy.get('button.modal-container__close').click() }) - cy.waitUntil(() => cy.get('.modal-container').should('not.be.visible')) + cy.waitUntil(() => cy.get('.modal-container').should(el => assertNotExistOrNotVisible(el))) }) it('Can show a column', function() { @@ -68,7 +69,7 @@ describe('Settings: Show and hide columns', function() { // close the settings dialog cy.get('button.modal-container__close').click() }) - cy.waitUntil(() => cy.get('.modal-container').should('not.be.visible')) + cy.waitUntil(() => cy.get('.modal-container').should(el => assertNotExistOrNotVisible(el))) // see that the language column is in the header cy.get(`.user-list__header tr`).within(() => { @@ -103,7 +104,7 @@ describe('Settings: Show and hide columns', function() { // close the settings dialog cy.get('button.modal-container__close').click() }) - cy.waitUntil(() => cy.get('.modal-container').should('not.be.visible')) + cy.waitUntil(() => cy.get('.modal-container').should(el => assertNotExistOrNotVisible(el))) // see that the last login column is not in the header cy.get(`.user-list__header tr`).within(() => {