Skip to content

Commit

Permalink
test(e2e): hide move dialog action if destination has no CREATE permi…
Browse files Browse the repository at this point in the history
…ssion

Signed-off-by: Maksim Sukharev <[email protected]>
(cherry picked from commit 868517f)
  • Loading branch information
Antreesy committed Jan 17, 2025
1 parent 03200b9 commit 21f0e61
Show file tree
Hide file tree
Showing 2 changed files with 162 additions and 0 deletions.
11 changes: 11 additions & 0 deletions cypress/e2e/files_sharing/FilesSharingUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,17 @@ export function updateShare(fileName: string, index: number, shareSettings: Part
}
}

if (shareSettings.create !== undefined) {
cy.get('[data-cy-files-sharing-share-permissions-checkbox="create"]').find('input').as('createCheckbox')
if (shareSettings.create) {
// Force:true because the checkbox is hidden by the pretty UI.
cy.get('@createCheckbox').check({ force: true, scrollBehavior: 'nearest' })
} else {
// Force:true because the checkbox is hidden by the pretty UI.
cy.get('@createCheckbox').uncheck({ force: true, scrollBehavior: 'nearest' })
}
}

if (shareSettings.delete !== undefined) {
cy.get('[data-cy-files-sharing-share-permissions-checkbox="delete"]').find('input').as('deleteCheckbox')
if (shareSettings.delete) {
Expand Down
151 changes: 151 additions & 0 deletions cypress/e2e/files_sharing/files-copy-move.cy.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,151 @@
/**
* SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
import type { User } from '@nextcloud/cypress'
import { createShare } from './FilesSharingUtils.ts'
import {
getRowForFile,
moveFile,
copyFile,
navigateToFolder,
triggerActionForFile,
} from '../files/FilesUtils.ts'

export const copyFileForbidden = (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')

const directories = dirPath.split('/')
directories.forEach((directory) => {
// select the folder
cy.get(`[data-filename="${CSS.escape(directory)}"]`).should('be.visible').click()
})

// check copy button
cy.contains('button', `Copy to ${directories.at(-1)}`).should('be.disabled')
})
}

export const moveFileForbidden = (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')

// select home folder
cy.get('button[title="Home"]').should('be.visible').click()

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('not.exist')
})
}

describe('files_sharing: Move or copy files', { testIsolation: true }, () => {
let user: User
let sharee: User

beforeEach(() => {
cy.createRandomUser().then(($user) => {
user = $user
})
cy.createRandomUser().then(($user) => {
sharee = $user
})
})


it('can create a file in a shared folder', () => {
// share the folder
cy.mkdir(user, '/folder')
cy.login(user)
cy.visit('/apps/files')
createShare('folder', sharee.userId, { read: true, download: true })
cy.logout()

// Now for the sharee
cy.uploadContent(sharee, new Blob([]), 'text/plain', '/folder/file.txt')
cy.login(sharee)
// visit shared files view
cy.visit('/apps/files')
// see the shared folder
getRowForFile('folder').should('be.visible')
navigateToFolder('folder')
// Content of the shared folder
getRowForFile('file.txt').should('be.visible')
})

it('can copy a file to a shared folder', () => {
// share the folder
cy.mkdir(user, '/folder')
cy.login(user)
cy.visit('/apps/files')
createShare('folder', sharee.userId, { read: true, download: true })
cy.logout()

// Now for the sharee
cy.uploadContent(sharee, new Blob([]), 'text/plain', '/file.txt')
cy.login(sharee)
// visit shared files view
cy.visit('/apps/files')
// see the shared folder
getRowForFile('folder').should('be.visible')
// copy file to a shared folder
copyFile('file.txt', 'folder')
// click on the folder should open it in files
navigateToFolder('folder')
// Content of the shared folder
getRowForFile('file.txt').should('be.visible')
})

it('can not copy a file to a shared folder with no create permissions', () => {
// share the folder
cy.mkdir(user, '/folder')
cy.login(user)
cy.visit('/apps/files')
createShare('folder', sharee.userId, { read: true, download: true, create: false })
cy.logout()

// Now for the sharee
cy.uploadContent(sharee, new Blob([]), 'text/plain', '/file.txt')
cy.login(sharee)
// visit shared files view
cy.visit('/apps/files')
// see the shared folder
getRowForFile('folder').should('be.visible')
copyFileForbidden('file.txt', 'folder')
})

it('can not move a file from a shared folder with no delete permissions', () => {
// share the folder
cy.mkdir(user, '/folder')
cy.uploadContent(user, new Blob([]), 'text/plain', '/folder/file.txt')
cy.login(user)
cy.visit('/apps/files')
createShare('folder', sharee.userId, { read: true, download: true, delete: false })
cy.logout()

// Now for the sharee
cy.mkdir(sharee, '/folder-own')
cy.login(sharee)
// visit shared files view
cy.visit('/apps/files')
// see the shared folder
getRowForFile('folder').should('be.visible')
navigateToFolder('folder')
getRowForFile('file.txt').should('be.visible')
moveFileForbidden('file.txt', 'folder-own')
})
})

0 comments on commit 21f0e61

Please sign in to comment.