aboutsummaryrefslogtreecommitdiffstats
path: root/cypress/e2e/core/header_access-levels.cy.ts
diff options
context:
space:
mode:
Diffstat (limited to 'cypress/e2e/core/header_access-levels.cy.ts')
-rw-r--r--cypress/e2e/core/header_access-levels.cy.ts101
1 files changed, 101 insertions, 0 deletions
diff --git a/cypress/e2e/core/header_access-levels.cy.ts b/cypress/e2e/core/header_access-levels.cy.ts
new file mode 100644
index 00000000000..b0e9ab8bac1
--- /dev/null
+++ b/cypress/e2e/core/header_access-levels.cy.ts
@@ -0,0 +1,101 @@
+/**
+ * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
+ */
+
+import { User } from '@nextcloud/cypress'
+import { clearState, getNextcloudUserMenu, getNextcloudUserMenuToggle } from '../../support/commonUtils'
+
+const admin = new User('admin', 'admin')
+
+describe('Header: Ensure regular users do not have admin settings in the Settings menu', { testIsolation: true }, () => {
+ beforeEach(() => {
+ clearState()
+ })
+
+ it('Regular users can see basic items in the Settings menu', () => {
+ // Given I am logged in
+ cy.createRandomUser().then(($user) => {
+ cy.login($user)
+ cy.visit('/')
+ })
+ // I open the settings menu
+ getNextcloudUserMenuToggle().click()
+
+ getNextcloudUserMenu().find('ul').within(($el) => {
+ // I see the settings menu is open
+ cy.wrap($el).should('be.visible')
+
+ // I see that the Settings menu has only 6 items
+ cy.get('li').should('have.length', 6)
+ // I see that the "View profile" item in the Settings menu is shown
+ cy.contains('li', 'View profile').should('be.visible')
+ // I see that the "Set status" item in the Settings menu is shown
+ cy.contains('li', 'Set status').should('be.visible')
+ // I see that the "Appearance and accessibility" item in the Settings menu is shown
+ cy.contains('li', 'Appearance and accessibility').should('be.visible')
+ // I see that the "Settings" item in the Settings menu is shown
+ cy.contains('li', 'Settings').should('be.visible')
+ // I see that the "Help" item in the Settings menu is shown
+ cy.contains('li', 'Help').should('be.visible')
+ // I see that the "Log out" item in the Settings menu is shown
+ cy.contains('li', 'Log out').should('be.visible')
+ })
+ })
+
+ it('Regular users cannot see admin-level items in the Settings menu', () => {
+ // Given I am logged in
+ cy.createRandomUser().then(($user) => {
+ cy.login($user)
+ cy.visit('/')
+ })
+ // I open the settings menu
+ getNextcloudUserMenuToggle().click()
+
+ getNextcloudUserMenu().find('ul').within(($el) => {
+ // I see the settings menu is open
+ cy.wrap($el).should('be.visible')
+
+ // I see that the "Users" item in the Settings menu is NOT shown
+ cy.contains('li', 'Users').should('not.exist')
+ // I see that the "Administration settings" item in the Settings menu is NOT shown
+ cy.contains('li', 'Administration settings').should('not.exist')
+ cy.get('#admin_settings').should('not.exist')
+ })
+ })
+
+ it('Admin users can see admin-level items in the Settings menu', () => {
+ // Given I am logged in
+ cy.login(admin)
+ cy.visit('/')
+
+ // I open the settings menu
+ getNextcloudUserMenuToggle().click()
+
+ getNextcloudUserMenu().find('ul').within(($el) => {
+ // I see the settings menu is open
+ cy.wrap($el).should('be.visible')
+
+ // I see that the Settings menu has only 9 items
+ cy.get('li').should('have.length', 9)
+ // I see that the "Set status" item in the Settings menu is shown
+ cy.contains('li', 'View profile').should('be.visible')
+ // I see that the "Set status" item in the Settings menu is shown
+ cy.contains('li', 'Set status').should('be.visible')
+ // I see that the "Appearance and accessibility" item in the Settings menu is shown
+ cy.contains('li', 'Appearance and accessibility').should('be.visible')
+ // I see that the "Personal Settings" item in the Settings menu is shown
+ cy.contains('li', 'Personal settings').should('be.visible')
+ // I see that the "Administration settings" item in the Settings menu is shown
+ cy.contains('li', 'Administration settings').should('be.visible')
+ // I see that the "Apps" item in the Settings menu is shown
+ cy.contains('li', 'Apps').should('be.visible')
+ // I see that the "Users" item in the Settings menu is shown
+ cy.contains('li', 'Accounts').should('be.visible')
+ // I see that the "Help" item in the Settings menu is shown
+ cy.contains('li', 'Help').should('be.visible')
+ // I see that the "Log out" item in the Settings menu is shown
+ cy.contains('li', 'Log out').should('be.visible')
+ })
+ })
+})