Skip to content

Commit

Permalink
test(renterd): directory rename and delete behaviour
Browse files Browse the repository at this point in the history
  • Loading branch information
alexfreska committed Nov 20, 2024
1 parent 01aa998 commit 08c2c06
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 27 deletions.
12 changes: 7 additions & 5 deletions apps/renterd-e2e/src/fixtures/files.ts
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,9 @@ export const openDirectory = step(
.getByText(name)
.click()
for (const dir of path.split('/').slice(0, -1)) {
await expect(page.getByTestId('navbar').getByText(dir)).toBeVisible()
await expect(
page.getByTestId('navbar').getByText(dir, { exact: true })
).toBeVisible()
}
}
)
Expand Down Expand Up @@ -216,12 +218,12 @@ async function simulateDragAndDropFile(

export const dragAndDropFileFromSystem = step(
'drag and drop file from system',
async (page: Page, systemFilePath: string, localFileName?: string) => {
async (page: Page, localFilePath: string, systemFile?: string) => {
await simulateDragAndDropFile(
page,
`[data-testid=filesDropzone]`,
join(__dirname, 'sample-files', systemFilePath),
'/' + (localFileName || systemFilePath)
join(__dirname, 'sample-files', systemFile || 'sample.txt'),
'/' + localFilePath
)
}
)
Expand All @@ -244,7 +246,7 @@ export const createFilesMap = step(
await fileInList(page, path + '/')
await create(map[name] as FileMap, stack.concat(name))
} else {
await dragAndDropFileFromSystem(page, 'sample.txt', name)
await dragAndDropFileFromSystem(page, name)
await fileInList(page, path)
}
}
Expand Down
90 changes: 70 additions & 20 deletions apps/renterd-e2e/src/specs/files.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import {
dragAndDropFileFromSystem,
createFilesMap,
expectFilesMap,
openDirectoryContextMenu,
} from '../fixtures/files'
import { afterTest, beforeTest } from '../fixtures/beforeTest'
import { clearToasts, fillTextInputByName } from '@siafoundation/e2e'
Expand Down Expand Up @@ -52,9 +53,7 @@ test('can create directory and delete a directory', async ({ page }) => {
await fileInList(page, dirPath2)
})

test('can create directory, upload file, rename file, navigate, delete a file, delete a directory', async ({
page,
}) => {
test('can upload, rename, and delete files', async ({ page }) => {
const bucketName = 'files-test'
const dirName = 'test-dir'
const originalFileName = 'sample.txt'
Expand All @@ -63,14 +62,10 @@ test('can create directory, upload file, rename file, navigate, delete a file, d
const originalFilePath = `${bucketName}/${dirName}/${originalFileName}`
const newFilePath = `${bucketName}/${dirName}/${newFileName}`

// Create bucket and directory.
await navigateToBuckets({ page })
await createBucket(page, bucketName)
await openBucket(page, bucketName)
await expect(
page.getByText('bucket does not contain any files')
).toBeVisible()

// Create directory.
await createDirectory(page, dirName)
await fileInList(page, dirPath)
await openDirectory(page, dirPath)
Expand All @@ -92,15 +87,18 @@ test('can create directory, upload file, rename file, navigate, delete a file, d
await expect(page.getByRole('dialog')).toBeHidden()
await fileInList(page, newFilePath)

// Delete file.
await deleteFile(page, newFilePath)
await fileNotInList(page, newFilePath)
await clearToasts({ page })

// Upload the file again.
await dragAndDropFileFromSystem(page, originalFileName)
await expect(page.getByText('100%')).toBeVisible()

// Both files exist.
await fileInList(page, originalFilePath)
await fileInList(page, newFilePath)

// Delete one of the files.
await deleteFile(page, newFilePath)
await fileNotInList(page, newFilePath)
await clearToasts({ page })

// Clean up the directory.
await navigateToParentDirectory(page)
Expand All @@ -113,17 +111,69 @@ test('can create directory, upload file, rename file, navigate, delete a file, d
await deleteBucket(page, bucketName)
})

test('can rename and delete a directory with contents', async ({ page }) => {
test.setTimeout(120_000)
const bucketName = 'files-test'
const dirName = 'a'
const newDirName = 'b'
const fileName = 'sample.txt'
const dirPath = `${bucketName}/${dirName}/`
const newDirPath = `${bucketName}/${newDirName}/`
const originalFilePath = `${bucketName}/${dirName}/${fileName}`
const newFilePath = `${bucketName}/${newDirName}/${fileName}`

// Create bucket and directory.
await navigateToBuckets({ page })
await createBucket(page, bucketName)
await openBucket(page, bucketName)
await createDirectory(page, dirName)
await fileInList(page, dirPath)
await openDirectory(page, dirPath)
await expect(
page.getByText('The current directory does not contain any files yet')
).toBeVisible()
await clearToasts({ page })

// Upload a file.
await dragAndDropFileFromSystem(page, fileName)
await expect(page.getByText('100%')).toBeVisible()
await fileInList(page, originalFilePath)

// Rename directory.
await navigateToParentDirectory(page)
await openDirectoryContextMenu(page, dirPath)
await page.getByRole('menuitem', { name: 'Rename directory' }).click()
await fillTextInputByName(page, 'name', newDirName)
await page.locator('input[name=name]').press('Enter')
await expect(page.getByRole('dialog')).toBeHidden()
await fileInList(page, newDirPath)

// File still inside renamed directory.
await openDirectory(page, newDirPath)
await fileInList(page, newFilePath)
await navigateToParentDirectory(page)

// Delete directory.
await deleteDirectory(page, newDirPath)
await fileNotInList(page, newDirPath)

// Confirm no files or directories remain.
await expect(
page.getByText('bucket does not contain any files')
).toBeVisible()
})

test('shows a new intermediate directory when uploading nested files', async ({
page,
}) => {
const bucketName = 'files-test'
const containerDir = 'test-dir'
const containerDirPath = `${bucketName}/${containerDir}/`
const systemDir = 'sample-files'
const systemFile = 'sample.txt'
const systemFilePath = `${systemDir}/${systemFile}`
const dirPath = `${bucketName}/${containerDir}/${systemDir}/`
const filePath = `${dirPath}${systemFile}`
const nestedDir = 'nested-files'
const fileName = 'sample.txt'
const nestedFilePath = `${nestedDir}/${fileName}`
const dirPath = `${bucketName}/${containerDir}/${nestedDir}/`
const filePath = `${dirPath}${fileName}`

await navigateToBuckets({ page })
await createBucket(page, bucketName)
Expand All @@ -142,14 +192,14 @@ test('shows a new intermediate directory when uploading nested files', async ({
await clearToasts({ page })

// Upload a nested file.
await dragAndDropFileFromSystem(page, systemFile, systemFilePath)
await dragAndDropFileFromSystem(page, nestedFilePath)
await fileInList(page, dirPath)
const dirRow = await getFileRowById(page, dirPath)
// The intermediate directory should show up before the file is finished uploading.
await expect(dirRow.getByText('0 B')).toBeVisible()
// Check that filtering the current directory works with the upload directory.
const filterInput = page.getByLabel('filter files in current directory')
await filterInput.fill(systemDir.slice(0, 2))
await filterInput.fill(nestedDir.slice(0, 2))
await expect(dirRow).toBeVisible()
await filterInput.fill('xxxxx')
await expect(dirRow).toBeHidden()
Expand Down
4 changes: 2 additions & 2 deletions apps/renterd/lib/rename.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import {

type Id = string | number

// Parameters for moving a directory or file to drag destination
// Parameters for moving a directory or file to drag destination.
export function getMoveFileRenameParams(
e: { active: { id: Id }; collisions: { id: Id }[] | null },
activeDirectory: FullPathSegments
Expand All @@ -39,7 +39,7 @@ export function getMoveFileRenameParams(
} as const
}

// Parameters for renaming the name of a file or directory
// Parameters for renaming the name of a file or directory.
export function getRenameFileRenameParams(path: FullPath, newName: string) {
let to = join(getParentDirectoryPath(path), newName)
const isDir = isDirectory(path)
Expand Down

0 comments on commit 08c2c06

Please sign in to comment.