summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--.drone.yml30
-rw-r--r--cypress/e2e/login/login.cy.ts5
-rw-r--r--cypress/e2e/settings/access-levels.cy.ts132
-rw-r--r--cypress/support/commonUtils.ts20
-rw-r--r--tests/acceptance/features/access-levels.feature23
5 files changed, 155 insertions, 55 deletions
diff --git a/.drone.yml b/.drone.yml
index 05397f49fb0..4b46b42249f 100644
--- a/.drone.yml
+++ b/.drone.yml
@@ -1563,36 +1563,6 @@ trigger:
---
kind: pipeline
-name: acceptance-access-levels
-
-steps:
-- name: submodules
- image: ghcr.io/nextcloud/continuous-integration-alpine-git:latest
- commands:
- - git submodule update --init
-- name: acceptance-access-levels
- image: ghcr.io/nextcloud/continuous-integration-acceptance-php8.0:latest
- commands:
- - tests/acceptance/run-local.sh --timeout-multiplier 10 --nextcloud-server-domain acceptance-access-levels --selenium-server selenium:4444 allow-git-repository-modifications features/access-levels.feature
-
-services:
-- name: selenium
- image: ghcr.io/nextcloud/continuous-integration-selenium:3.141.59
- environment:
- # Reduce default log level for Selenium server (INFO) as it is too
- # verbose.
- JAVA_OPTS: -Dselenium.LOGGER.level=WARNING
-
-trigger:
- branch:
- - master
- - stable*
- event:
- - pull_request
- - push
-
----
-kind: pipeline
name: acceptance-header
steps:
diff --git a/cypress/e2e/login/login.cy.ts b/cypress/e2e/login/login.cy.ts
index 133e56e0256..478512884f6 100644
--- a/cypress/e2e/login/login.cy.ts
+++ b/cypress/e2e/login/login.cy.ts
@@ -1,4 +1,5 @@
import type { User } from '@nextcloud/cypress'
+import { getNextcloudUserMenu, getNextcloudUserMenuToggle } from '../../support/commonUtils'
describe('Login', () => {
let user: User
@@ -137,8 +138,8 @@ describe('Login', () => {
cy.url().should('match', /apps\/dashboard(\/|$)/)
// When click logout
- cy.get('#user-menu > button').should('exist').click()
- cy.get('#logout a').should('contain.text', 'Log out').click()
+ getNextcloudUserMenuToggle().should('exist').click()
+ getNextcloudUserMenu().contains('a', 'Log out').click()
// Then I see that the current page is the Login page
cy.url().should('match', /\/login/)
diff --git a/cypress/e2e/settings/access-levels.cy.ts b/cypress/e2e/settings/access-levels.cy.ts
new file mode 100644
index 00000000000..1fb9efe8f03
--- /dev/null
+++ b/cypress/e2e/settings/access-levels.cy.ts
@@ -0,0 +1,132 @@
+/**
+ * @copyright Copyright (c) 2023 Ferdinand Thiessen <opensource@fthiessen.de>
+ *
+ * @author Ferdinand Thiessen <opensource@fthiessen.de>
+ *
+ * @license AGPL-3.0-or-later
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+import { User } from '@nextcloud/cypress'
+import { clearState } from './usersUtils'
+import { getNextcloudUserMenu, getNextcloudUserMenuToggle } from '../../support/commonUtils'
+
+const admin = new User('admin', 'admin')
+
+describe('Settings: Access levels', { testIsolation: true }, () => {
+ beforeEach(() => {
+ clearState()
+ })
+
+ 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 "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')
+
+ // 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('Regular users cannot see admin-level items on the Settings page', () => {
+ // Given I am logged in
+ cy.createRandomUser().then(($user) => {
+ cy.login($user)
+ cy.visit('/')
+ })
+
+ // I open the settings menu
+ getNextcloudUserMenuToggle().click()
+ // I navigate to the settings panel
+ getNextcloudUserMenu().find('#settings a').click()
+ cy.url().should('match', /\/settings\/user$/)
+
+ cy.get('#app-navigation').should('be.visible').within(() => {
+ // I see the personal section is NOT shown
+ cy.get('#app-navigation-caption-personal').should('not.exist')
+ // I see the admin section is NOT shown
+ cy.get('#app-navigation-caption-administration').should('not.exist')
+
+ // I see that the "Personal info" entry in the settings panel is shown
+ cy.get('[data-section-id="personal-info"]').should('exist').and('be.visible')
+ })
+ })
+
+ 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 "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 "Help" item in the Settings menu is shown
+ cy.contains('li', 'Help').should('be.visible')
+ // I see that the "Users" item in the Settings menu is shown
+ cy.contains('li', 'Users').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('Admin users can see admin-level items on the Settings page', () => {
+ // Given I am logged in
+ cy.login(admin)
+ cy.visit('/')
+
+ // I open the settings menu
+ getNextcloudUserMenuToggle().click()
+ // I navigate to the settings panel
+ getNextcloudUserMenu().find('#settings a').click()
+ cy.url().should('match', /\/settings\/user$/)
+
+ cy.get('#app-navigation').should('be.visible').within(() => {
+ // I see the personal section is shown
+ cy.get('#app-navigation-caption-personal').should('be.visible')
+ // I see the admin section is shown
+ cy.get('#app-navigation-caption-administration').should('be.visible')
+
+ // I see that the "Personal info" entry in the settings panel is shown
+ cy.get('[data-section-id="personal-info"]').should('exist').and('be.visible')
+ })
+ })
+})
diff --git a/cypress/support/commonUtils.ts b/cypress/support/commonUtils.ts
new file mode 100644
index 00000000000..4b201b38da5
--- /dev/null
+++ b/cypress/support/commonUtils.ts
@@ -0,0 +1,20 @@
+/**
+ * Get the header navigation bar
+ */
+export function getNextcloudHeader() {
+ return cy.get('#header')
+}
+
+/**
+ * Get user menu in the header navigation bar
+ */
+export function getNextcloudUserMenu() {
+ return getNextcloudHeader().find('#user-menu')
+}
+
+/**
+ * Get the user menu toggle in the header navigation bar
+ */
+export function getNextcloudUserMenuToggle() {
+ return getNextcloudUserMenu().find('.header-menu__trigger').should('have.length', 1)
+}
diff --git a/tests/acceptance/features/access-levels.feature b/tests/acceptance/features/access-levels.feature
deleted file mode 100644
index de34a17baea..00000000000
--- a/tests/acceptance/features/access-levels.feature
+++ /dev/null
@@ -1,23 +0,0 @@
-Feature: access-levels
-
- Scenario: regular users cannot see admin-level items in the Settings menu
- Given I am logged in
- When I open the Settings menu
- Then I see that the Settings menu is shown
- And I see that the "Settings" item in the Settings menu is shown
- And I see that the "Users" item in the Settings menu is not shown
- And I see that the "Help" item in the Settings menu is shown
- And I see that the "Log out" item in the Settings menu is shown
-
- Scenario: regular users cannot see admin-level items on the Settings page
- Given I am logged in
- When I visit the settings page
- Then I see that the "Personal info" entry in the settings panel is shown
- And I see that the "Personal" settings panel is not shown
- And I see that the "Administration" settings panel is not shown
-
- Scenario: admin users can see admin-level items on the Settings page
- Given I am logged in as the admin
- When I visit the admin settings page
- Then I see that the "Personal" settings panel is shown
- And I see that the "Administration" settings panel is shown