]> source.dussan.org Git - nextcloud-server.git/commitdiff
fix(cypress): more stable navigation-bar-settings cypress tests
authorskjnldsv <skjnldsv@protonmail.com>
Thu, 22 Feb 2024 11:39:17 +0000 (12:39 +0100)
committerskjnldsv <skjnldsv@protonmail.com>
Thu, 22 Feb 2024 17:36:24 +0000 (18:36 +0100)
Signed-off-by: skjnldsv <skjnldsv@protonmail.com>
cypress/e2e/theming/navigation-bar-settings.cy.ts
cypress/fixtures/testapp/appinfo/info.xml
cypress/support/commonUtils.ts

index 442001c712ac2f5e55b317bc016888e1eef98980..4bea6225f7626db4ab48606d86beb539b9d6978b 100644 (file)
@@ -35,6 +35,8 @@ describe('Admin theming set default apps', () => {
        it('See the current default app is the dashboard', () => {
                cy.visit('/')
                cy.url().should('match', /apps\/dashboard/)
+
+               // Also check the top logo link
                cy.get('#nextcloud').click()
                cy.url().should('match', /apps\/dashboard/)
        })
@@ -54,9 +56,9 @@ describe('Admin theming set default apps', () => {
        })
 
        it('See the default app order selector', () => {
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
-                       else cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['dashboard', 'files'])
                })
        })
 
@@ -70,13 +72,17 @@ describe('Admin theming set default apps', () => {
        })
 
        it('See the default app is changed', () => {
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
-                       else cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['files', 'dashboard'])
                })
 
-               cy.get('#nextcloud').click()
-               cy.url().should('match', /apps\/files/)
+               // Check the redirect to the default app works
+               cy.request({ url: '/', followRedirect: false }).then((response) => {
+                       expect(response.status).to.eq(302)
+                       expect(response).to.have.property('headers')
+                       expect(response.headers.location).to.contain('/apps/files')
+               })
        })
 
        it('Toggle the "use custom default app" switch back to reset the default apps', () => {
@@ -89,9 +95,12 @@ describe('Admin theming set default apps', () => {
        })
 
        it('See the default app is changed back to default', () => {
-               cy.reload()
-               cy.get('#nextcloud').click()
-               cy.url().should('match', /apps\/dashboard/)
+               // Check the redirect to the default app works
+               cy.request({ url: '/', followRedirect: false }).then((response) => {
+                       expect(response.status).to.eq(302)
+                       expect(response).to.have.property('headers')
+                       expect(response.headers.location).to.contain('/apps/dashboard')
+               })
        })
 })
 
@@ -117,14 +126,16 @@ describe('User theming set app order', () => {
        })
 
        it('See that the dashboard app is the first one', () => {
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
-                       else cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
+               // Check the app order settings UI
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['dashboard', 'files'])
                })
 
-               cy.get('.app-menu-main .app-menu-entry').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-app-id', 'dashboard')
-                       else cy.wrap($el).should('have.attr', 'data-app-id', 'files')
+               // Check the top app menu order
+               cy.get('.app-menu-main .app-menu-entry').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-app-id')).get()
+                       expect(appIDs).to.deep.eq(['dashboard', 'files'])
                })
        })
 
@@ -133,17 +144,17 @@ describe('User theming set app order', () => {
                cy.get('[data-cy-app-order] [data-cy-app-order-element="files"] [data-cy-app-order-button="up"]').click()
                cy.get('[data-cy-app-order] [data-cy-app-order-element="files"] [data-cy-app-order-button="up"]').should('not.be.visible')
 
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
-                       else cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['files', 'dashboard'])
                })
        })
 
        it('See the app menu order is changed', () => {
                cy.reload()
-               cy.get('.app-menu-main .app-menu-entry').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-app-id', 'files')
-                       else cy.wrap($el).should('have.attr', 'data-app-id', 'dashboard')
+               cy.get('.app-menu-main .app-menu-entry').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-app-id')).get()
+                       expect(appIDs).to.deep.eq(['files', 'dashboard'])
                })
        })
 })
@@ -171,20 +182,21 @@ describe('User theming set app order with default app', () => {
        })
 
        it('See files is the default app', () => {
-               cy.visit('/')
-               cy.url().should('match', /apps\/files/)
-
-               cy.get('.app-menu-main .app-menu-entry').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-app-id', 'files')
+               // Check the redirect to the default app works
+               cy.request({ url: '/', followRedirect: false }).then((response) => {
+                       expect(response.status).to.eq(302)
+                       expect(response).to.have.property('headers')
+                       expect(response.headers.location).to.contain('/apps/files')
                })
        })
 
        it('See the app order settings: files is the first one', () => {
                cy.visit('/settings/user/theming')
                cy.get('[data-cy-app-order]').scrollIntoView()
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').should('have.length', 4).each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
-                       else if (idx === 1) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       expect(elements).to.have.length(4)
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['files', 'dashboard', 'testapp1', 'testapp'])
                })
        })
 
@@ -200,22 +212,31 @@ describe('User theming set app order with default app', () => {
        })
 
        it('Change the order of the other apps', () => {
+               cy.intercept('POST', '**/apps/provisioning_api/api/v1/config/users/core/apporder').as('setAppOrder')
+
+               // Move the testapp up twice, it should be the first one after files
+               cy.get('[data-cy-app-order] [data-cy-app-order-element="testapp"] [data-cy-app-order-button="up"]').click()
+               cy.wait('@setAppOrder')
                cy.get('[data-cy-app-order] [data-cy-app-order-element="testapp"] [data-cy-app-order-button="up"]').click()
+               cy.wait('@setAppOrder')
+
+               // Can't get up anymore, files is enforced as default app
                cy.get('[data-cy-app-order] [data-cy-app-order-element="testapp"] [data-cy-app-order-button="up"]').should('not.be.visible')
 
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
-                       else if (idx === 1) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'testapp')
-                       else if (idx === 2) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
+               // Check the final list order
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       expect(elements).to.have.length(4)
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['files', 'testapp', 'dashboard', 'testapp1'])
                })
        })
 
        it('See the app menu order is changed', () => {
                cy.reload()
-               cy.get('.app-menu-main .app-menu-entry').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-app-id', 'files')
-                       else if (idx === 1) cy.wrap($el).should('have.attr', 'data-app-id', 'testapp')
-                       else if (idx === 2) cy.wrap($el).should('have.attr', 'data-app-id', 'dashboard')
+               cy.get('.app-menu-main .app-menu-entry').then(elements => {
+                       expect(elements).to.have.length(4)
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-app-id')).get()
+                       expect(appIDs).to.deep.eq(['files', 'testapp', 'dashboard', 'testapp1'])
                })
        })
 })
@@ -289,14 +310,16 @@ describe('User theming reset app order', () => {
        })
 
        it('See that the dashboard app is the first one', () => {
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
-                       else cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
+               // Check the app order settings UI
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['dashboard', 'files'])
                })
 
-               cy.get('.app-menu-main .app-menu-entry').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-app-id', 'dashboard')
-                       else cy.wrap($el).should('have.attr', 'data-app-id', 'files')
+               // Check the top app menu order
+               cy.get('.app-menu-main .app-menu-entry').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-app-id')).get()
+                       expect(appIDs).to.deep.eq(['dashboard', 'files'])
                })
        })
 
@@ -310,9 +333,10 @@ describe('User theming reset app order', () => {
                cy.get('[data-cy-app-order] [data-cy-app-order-element="files"] [data-cy-app-order-button="up"]').click()
                cy.get('[data-cy-app-order] [data-cy-app-order-element="files"] [data-cy-app-order-button="up"]').should('not.be.visible')
 
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
-                       else cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
+               // Check the app order settings UI
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['files', 'dashboard'])
                })
        })
 
@@ -326,9 +350,9 @@ describe('User theming reset app order', () => {
        })
 
        it('See the app order is restored', () => {
-               cy.get('[data-cy-app-order] [data-cy-app-order-element]').each(($el, idx) => {
-                       if (idx === 0) cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'dashboard')
-                       else cy.wrap($el).should('have.attr', 'data-cy-app-order-element', 'files')
+               cy.get('[data-cy-app-order] [data-cy-app-order-element]').then(elements => {
+                       const appIDs = elements.map((idx, el) => el.getAttribute('data-cy-app-order-element')).get()
+                       expect(appIDs).to.deep.eq(['dashboard', 'files'])
                })
        })
 
index 2e4eecfbdcaf93b8c89b6aadb54d863749988782..a0deada5329c2ba32c4ceb0628e47ca3b7ee066a 100644 (file)
@@ -16,7 +16,7 @@
     <category>games</category>
     <bugs>https://github.com/nextcloud/server/issues</bugs>
     <dependencies>
-        <nextcloud min-version="28" max-version="28"/>
+        <nextcloud min-version="28" max-version="29"/>
     </dependencies>
     <navigations>
         <navigation>
index 82c55c8e91eef433417472b834da4d3c8c59a2dd..ce4556a9349a95adc7e5bce89e4bec52ae15515c 100644 (file)
@@ -46,7 +46,7 @@ export function installTestApp() {
                cy.wrap(version).should('not.be.undefined')
                cy.exec(`docker cp '${testAppPath}' nextcloud-cypress-tests-server:/var/www/html/apps`, { log: true })
                cy.exec(`docker exec nextcloud-cypress-tests-server sed -i -e 's|-version="[0-9]\\+|-version="${version}|g' apps/testapp/appinfo/info.xml`)
-               cy.runOccCommand('app:enable testapp')
+               cy.runOccCommand('app:enable --force testapp')
        })
 }