aboutsummaryrefslogtreecommitdiffstats
path: root/cypress/e2e/files/files-sidebar.cy.ts
blob: f5c4205c462851240a766c0e3a8ac66bb71b56b4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/**
 * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */

import type { User } from '@nextcloud/cypress'
import { getRowForFile, navigateToFolder, triggerActionForFile } from './FilesUtils'
import { assertNotExistOrNotVisible } from '../settings/usersUtils'

describe('Files: Sidebar', { testIsolation: true }, () => {
	let user: User
	let fileId: number = 0

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

		cy.mkdir(user, '/folder')
		cy.uploadContent(user, new Blob([]), 'text/plain', '/file').then((response) => {
			fileId = Number.parseInt(response.headers['oc-fileid'] ?? '0')
		})
		cy.login(user)
	}))

	it('opens the sidebar', () => {
		cy.visit('/apps/files')
		getRowForFile('file').should('be.visible')

		triggerActionForFile('file', 'details')

		cy.get('[data-cy-sidebar]')
			.should('be.visible')
			.findByRole('heading', { name: 'file' })
			.should('be.visible')
	})

	it('changes the current fileid', () => {
		cy.visit('/apps/files')
		getRowForFile('file').should('be.visible')

		triggerActionForFile('file', 'details')

		cy.get('[data-cy-sidebar]').should('be.visible')
		cy.url().should('contain', `apps/files/files/${fileId}`)
	})

	it('changes the sidebar content on other file', () => {
		cy.visit('/apps/files')
		getRowForFile('file').should('be.visible')

		triggerActionForFile('file', 'details')

		cy.get('[data-cy-sidebar]')
			.should('be.visible')
			.findByRole('heading', { name: 'file' })
			.should('be.visible')

		triggerActionForFile('folder', 'details')
		cy.get('[data-cy-sidebar]')
			.should('be.visible')
			.findByRole('heading', { name: 'folder' })
			.should('be.visible')
	})

	it('closes the sidebar on navigation', () => {
		cy.visit('/apps/files')

		getRowForFile('file').should('be.visible')
		getRowForFile('folder').should('be.visible')

		// open the sidebar
		triggerActionForFile('file', 'details')
		// validate it is open
		cy.get('[data-cy-sidebar]')
			.should('be.visible')

		// if we navigate to the folder
		navigateToFolder('folder')
		// the sidebar should not be visible anymore
		cy.get('[data-cy-sidebar]')
			.should(assertNotExistOrNotVisible)
	})

	it('closes the sidebar on delete', () => {
		cy.intercept('DELETE', `**/remote.php/dav/files/${user.userId}/file`).as('deleteFile')
		// visit the files app
		cy.visit('/apps/files')
		getRowForFile('file').should('be.visible')
		// open the sidebar
		triggerActionForFile('file', 'details')
		// validate it is open
		cy.get('[data-cy-sidebar]').should('be.visible')
		// delete the file
		triggerActionForFile('file', 'delete')
		cy.wait('@deleteFile', { timeout: 10000 })
		// see the sidebar is closed
		cy.get('[data-cy-sidebar]')
			.should(assertNotExistOrNotVisible)
	})

	it('changes the fileid on delete', () => {
		cy.intercept('DELETE', `**/remote.php/dav/files/${user.userId}/folder/other`).as('deleteFile')

		cy.uploadContent(user, new Blob([]), 'text/plain', '/folder/other').then((response) => {
			const otherFileId = Number.parseInt(response.headers['oc-fileid'] ?? '0')
			cy.login(user)
			cy.visit('/apps/files')

			getRowForFile('folder').should('be.visible')
			navigateToFolder('folder')
			getRowForFile('other').should('be.visible')

			// open the sidebar
			triggerActionForFile('other', 'details')
			// validate it is open
			cy.get('[data-cy-sidebar]').should('be.visible')
			cy.url().should('contain', `apps/files/files/${otherFileId}`)

			triggerActionForFile('other', 'delete')
			cy.wait('@deleteFile')

			cy.get('[data-cy-sidebar]').should('not.exist')
			// Ensure the URL is changed
			cy.url().should('not.contain', `apps/files/files/${otherFileId}`)
		})
	})
})