diff options
author | skjnldsv <skjnldsv@protonmail.com> | 2024-11-07 19:00:35 +0100 |
---|---|---|
committer | skjnldsv <skjnldsv@protonmail.com> | 2024-11-07 19:01:59 +0100 |
commit | 54954bf934cf11e484ef586ad726a50b7ec99a84 (patch) | |
tree | f529ae9fc4ecf031d512fc6c426fbc6963e39492 /cypress/e2e/files | |
parent | 268e68eb95b5be9fa4215160bb3a4629bc3345fe (diff) | |
download | nextcloud-server-54954bf934cf11e484ef586ad726a50b7ec99a84.tar.gz nextcloud-server-54954bf934cf11e484ef586ad726a50b7ec99a84.zip |
chore(files): add selection cypress tests
Signed-off-by: skjnldsv <skjnldsv@protonmail.com>
Diffstat (limited to 'cypress/e2e/files')
-rw-r--r-- | cypress/e2e/files/FilesUtils.ts | 15 | ||||
-rw-r--r-- | cypress/e2e/files/files-copy-move.cy.ts (renamed from cypress/e2e/files/files_copy-move.cy.ts) | 0 | ||||
-rw-r--r-- | cypress/e2e/files/files-selection.cy.ts | 77 | ||||
-rw-r--r-- | cypress/e2e/files/files-sorting.cy.ts (renamed from cypress/e2e/files/files_sorting.cy.ts) | 0 |
4 files changed, 89 insertions, 3 deletions
diff --git a/cypress/e2e/files/FilesUtils.ts b/cypress/e2e/files/FilesUtils.ts index 182972ee44c..f435272b9a2 100644 --- a/cypress/e2e/files/FilesUtils.ts +++ b/cypress/e2e/files/FilesUtils.ts @@ -33,13 +33,22 @@ export const triggerInlineActionForFile = (filename: string, actionId: string) = } export const selectAllFiles = () => { - cy.get('[data-cy-files-list-selection-checkbox]').findByRole('checkbox').click({ force: true }) + cy.get('[data-cy-files-list-selection-checkbox]') + .findByRole('checkbox', { checked: false }) + .click({ force: true }) +} +export const deselectAllFiles = () => { + cy.get('[data-cy-files-list-selection-checkbox]') + .findByRole('checkbox', { checked: true }) + .click({ force: true }) } -export const selectRowForFile = (filename: string) => { + +export const selectRowForFile = (filename: string, options: Partial<Cypress.ClickOptions> = {}) => { getRowForFile(filename) .find('[data-cy-files-list-row-checkbox]') .findByRole('checkbox') - .click({ force: true }) + // don't use click to avoid triggering side effects events + .trigger('change', { ...options, force: true }) .should('be.checked') cy.get('[data-cy-files-list-selection-checkbox]').findByRole('checkbox').should('satisfy', (elements) => { return elements.length === 1 && (elements[0].checked === true || elements[0].indeterminate === true) diff --git a/cypress/e2e/files/files_copy-move.cy.ts b/cypress/e2e/files/files-copy-move.cy.ts index 086248eef3c..086248eef3c 100644 --- a/cypress/e2e/files/files_copy-move.cy.ts +++ b/cypress/e2e/files/files-copy-move.cy.ts diff --git a/cypress/e2e/files/files-selection.cy.ts b/cypress/e2e/files/files-selection.cy.ts new file mode 100644 index 00000000000..04991b74fb8 --- /dev/null +++ b/cypress/e2e/files/files-selection.cy.ts @@ -0,0 +1,77 @@ +/** + * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors + * SPDX-License-Identifier: AGPL-3.0-or-later + */ + +import type { User } from '@nextcloud/cypress' +import { deselectAllFiles, selectAllFiles, selectRowForFile } from './FilesUtils' + +const files = { + 'image.jpg': 'image/jpeg', + 'document.pdf': 'application/pdf', + 'archive.zip': 'application/zip', + 'audio.mp3': 'audio/mpeg', + 'video.mp4': 'video/mp4', + 'readme.md': 'text/markdown', + 'welcome.txt': 'text/plain', +} +const filesCount = Object.keys(files).length + +describe('files: Select all files', { testIsolation: true }, () => { + let user: User + + before(() => { + cy.createRandomUser().then(($user) => { + user = $user + Object.keys(files).forEach((file) => { + cy.uploadContent(user, new Blob(), files[file], '/' + file) + }) + }) + }) + + beforeEach(() => { + cy.login(user) + cy.visit('/apps/files') + }) + + it('Can select and unselect all files', () => { + cy.get('[data-cy-files-list-row-fileid]').should('have.length', filesCount) + cy.get('[data-cy-files-list-row-checkbox]').should('have.length', filesCount) + + selectAllFiles() + + cy.get('.files-list__selected').should('have.text', '7 selected') + cy.get('[data-cy-files-list-row-checkbox]').findByRole('checkbox').should('be.checked') + + deselectAllFiles() + + cy.get('.files-list__selected').should('not.exist') + cy.get('[data-cy-files-list-row-checkbox]').findByRole('checkbox').should('not.be.checked') + }) + + it('Can select some files randomly', () => { + const randomFiles = Object.keys(files).reduce((acc, file) => { + if (Math.random() > 0.1) { + acc.push(file) + } + return acc + }, [] as string[]) + + randomFiles.forEach(name => selectRowForFile(name)) + + cy.get('.files-list__selected').should('have.text', `${randomFiles.length} selected`) + cy.get('[data-cy-files-list-row-checkbox] input[type="checkbox"]:checked').should('have.length', randomFiles.length) + }) + + it('Can select range of files with shift key', () => { + cy.get('[data-cy-files-list-row-checkbox]').should('have.length', filesCount) + selectRowForFile('audio.mp3') + cy.window().trigger('keydown', { shiftKey: true }) + selectRowForFile('readme.md', { shiftKey: true }) + cy.window().trigger('keyup', { shiftKey: false }) + + cy.get('.files-list__selected').should('have.text', '4 selected') + cy.get('[data-cy-files-list-row-checkbox] input[type="checkbox"]:checked').should('have.length', 4) + + }) +}) diff --git a/cypress/e2e/files/files_sorting.cy.ts b/cypress/e2e/files/files-sorting.cy.ts index 250c5f195a6..250c5f195a6 100644 --- a/cypress/e2e/files/files_sorting.cy.ts +++ b/cypress/e2e/files/files-sorting.cy.ts |