123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 |
- /**
- * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- export const getRowForFileId = (fileid: number) => cy.get(`[data-cy-files-list-row-fileid="${fileid}"]`)
- export const getRowForFile = (filename: string) => cy.get(`[data-cy-files-list-row-name="${CSS.escape(filename)}"]`)
- export const getActionsForFileId = (fileid: number) => getRowForFileId(fileid).find('[data-cy-files-list-row-actions]')
- export const getActionsForFile = (filename: string) => getRowForFile(filename).find('[data-cy-files-list-row-actions]')
- export const getActionButtonForFileId = (fileid: number) => getActionsForFileId(fileid).findByRole('button', { name: 'Actions' })
- export const getActionButtonForFile = (filename: string) => getActionsForFile(filename).findByRole('button', { name: 'Actions' })
- export const triggerActionForFileId = (fileid: number, actionId: string) => {
- getActionButtonForFileId(fileid).click()
- // Getting the last button to avoid the one from popup fading out
- cy.get(`[data-cy-files-list-row-action="${CSS.escape(actionId)}"] > button`).last()
- .should('exist').click()
- }
- export const triggerActionForFile = (filename: string, actionId: string) => {
- getActionButtonForFile(filename).click()
- // Getting the last button to avoid the one from popup fading out
- cy.get(`[data-cy-files-list-row-action="${CSS.escape(actionId)}"] > button`).last()
- .should('exist').click()
- }
- export const triggerInlineActionForFileId = (fileid: number, actionId: string) => {
- getActionsForFileId(fileid).find(`button[data-cy-files-list-row-action="${CSS.escape(actionId)}"]`).should('exist').click()
- }
- export const triggerInlineActionForFile = (filename: string, actionId: string) => {
- getActionsForFile(filename).get(`button[data-cy-files-list-row-action="${CSS.escape(actionId)}"]`).should('exist').click()
- }
- export const selectAllFiles = () => {
- 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, options: Partial<Cypress.ClickOptions> = {}) => {
- getRowForFile(filename)
- .find('[data-cy-files-list-row-checkbox]')
- .findByRole('checkbox')
- // 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)
- })
- }
- export const triggerSelectionAction = (actionId: string) => {
- cy.get(`button[data-cy-files-list-selection-action="${CSS.escape(actionId)}"]`).should('exist').click()
- }
- export const moveFile = (fileName: string, dirPath: string) => {
- getRowForFile(fileName).should('be.visible')
- triggerActionForFile(fileName, 'move-copy')
- cy.get('.file-picker').within(() => {
- // intercept the copy so we can wait for it
- cy.intercept('MOVE', /\/(remote|public)\.php\/dav\/files\//).as('moveFile')
- if (dirPath === '/') {
- // select home folder
- cy.get('button[title="Home"]').should('be.visible').click()
- // click move
- cy.contains('button', 'Move').should('be.visible').click()
- } else if (dirPath === '.') {
- // click move
- cy.contains('button', 'Copy').should('be.visible').click()
- } else {
- const directories = dirPath.split('/')
- directories.forEach((directory) => {
- // select the folder
- cy.get(`[data-filename="${directory}"]`).should('be.visible').click()
- })
- // click move
- cy.contains('button', `Move to ${directories.at(-1)}`).should('be.visible').click()
- }
- cy.wait('@moveFile')
- })
- }
- export const copyFile = (fileName: string, dirPath: string) => {
- getRowForFile(fileName).should('be.visible')
- triggerActionForFile(fileName, 'move-copy')
- cy.get('.file-picker').within(() => {
- // intercept the copy so we can wait for it
- cy.intercept('COPY', /\/(remote|public)\.php\/dav\/files\//).as('copyFile')
- if (dirPath === '/') {
- // select home folder
- cy.get('button[title="Home"]').should('be.visible').click()
- // click copy
- cy.contains('button', 'Copy').should('be.visible').click()
- } else if (dirPath === '.') {
- // click copy
- cy.contains('button', 'Copy').should('be.visible').click()
- } else {
- const directories = dirPath.split('/')
- directories.forEach((directory) => {
- // select the folder
- cy.get(`[data-filename="${CSS.escape(directory)}"]`).should('be.visible').click()
- })
- // click copy
- cy.contains('button', `Copy to ${directories.at(-1)}`).should('be.visible').click()
- }
- cy.wait('@copyFile')
- })
- }
- export const renameFile = (fileName: string, newFileName: string) => {
- getRowForFile(fileName)
- triggerActionForFile(fileName, 'rename')
- // intercept the move so we can wait for it
- cy.intercept('MOVE', /\/(remote|public)\.php\/dav\/files\//).as('moveFile')
- getRowForFile(fileName).find('[data-cy-files-list-row-name] input').clear()
- getRowForFile(fileName).find('[data-cy-files-list-row-name] input').type(`${newFileName}{enter}`)
- cy.wait('@moveFile')
- }
- export const navigateToFolder = (dirPath: string) => {
- const directories = dirPath.split('/')
- directories.forEach((directory) => {
- getRowForFile(directory).should('be.visible').find('[data-cy-files-list-row-name-link]').click()
- })
- }
- export const closeSidebar = () => {
- // {force: true} as it might be hidden behind toasts
- cy.get('[data-cy-sidebar] .app-sidebar__close').click({ force: true })
- }
- export const clickOnBreadcrumbs = (label: string) => {
- cy.intercept('PROPFIND', /\/remote.php\/dav\//).as('propfind')
- cy.get('[data-cy-files-content-breadcrumbs]').contains(label).click()
- cy.wait('@propfind')
- }
- export const createFolder = (folderName: string) => {
- cy.intercept('MKCOL', /\/remote.php\/dav\/files\//).as('createFolder')
- // TODO: replace by proper data-cy selectors
- cy.get('[data-cy-upload-picker] .action-item__menutoggle').first().click()
- cy.contains('.upload-picker__menu-entry button', 'New folder').click()
- cy.get('[data-cy-files-new-node-dialog]').should('be.visible')
- cy.get('[data-cy-files-new-node-dialog-input]').type(`{selectall}${folderName}`)
- cy.get('[data-cy-files-new-node-dialog-submit]').click()
- cy.wait('@createFolder')
- getRowForFile(folderName).should('be.visible')
- }
- /**
- * Check validity of an input element
- * @param validity The expected validity message (empty string means it is valid)
- * @example
- * ```js
- * cy.findByRole('textbox')
- * .should(haveValidity(/must not be empty/i))
- * ```
- */
- export const haveValidity = (validity: string | RegExp) => {
- if (typeof validity === 'string') {
- return (el: JQuery<HTMLElement>) => expect((el.get(0) as HTMLInputElement).validationMessage).to.equal(validity)
- }
- return (el: JQuery<HTMLElement>) => expect((el.get(0) as HTMLInputElement).validationMessage).to.match(validity)
- }
|