442 lines
15 KiB
JavaScript
442 lines
15 KiB
JavaScript
import filterTests from "../support/filterTests"
|
|
import clientPackage from "@budibase/client/package.json"
|
|
|
|
filterTests(["all"], () => {
|
|
context("Application Overview screen", () => {
|
|
before(() => {
|
|
cy.login()
|
|
cy.deleteAllApps()
|
|
cy.createApp("Cypress Tests")
|
|
})
|
|
|
|
it("Should be accessible from the applications list", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .title")
|
|
.eq(0)
|
|
.invoke("attr", "data-cy")
|
|
.then($dataCy => {
|
|
const dataCy = $dataCy
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.click({ force: true })
|
|
|
|
cy.location().should(loc => {
|
|
expect(loc.pathname).to.eq("/builder/portal/overview/" + dataCy)
|
|
})
|
|
})
|
|
})
|
|
|
|
// Find a more suitable place for this.
|
|
it("Should allow unlocking in the app list", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
|
|
cy.get(".appTable .lock-status").eq(0).contains("Locked by you").click()
|
|
|
|
cy.unlockApp({ owned: true })
|
|
|
|
cy.get(".appTable").should("exist")
|
|
cy.get(".lock-status").should("not.be.visible")
|
|
})
|
|
|
|
it("Should allow unlocking in the app overview screen", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Edit")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.wait(1000)
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".lock-status").eq(0).contains("Locked by you").click()
|
|
|
|
cy.unlockApp({ owned: true })
|
|
|
|
cy.get(".lock-status").should("not.be.visible")
|
|
})
|
|
|
|
it("Should reflect the deploy state of an app that hasn't been published.", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".header-right button.spectrum-Button[data-cy='view-app']").should(
|
|
"be.disabled"
|
|
)
|
|
|
|
cy.get(".spectrum-Tabs-item.is-selected").contains("Overview")
|
|
cy.get(".overview-tab").should("be.visible")
|
|
|
|
cy.get(".overview-tab [data-cy='app-status']").within(() => {
|
|
cy.get(".status-display").contains("Unpublished")
|
|
cy.get(".status-display .icon svg[aria-label='GlobeStrike']").should(
|
|
"exist"
|
|
)
|
|
cy.get(".status-text").contains("-")
|
|
})
|
|
})
|
|
|
|
it("Should reflect the app deployment state", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`, { timeout: 5000 })
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Edit")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
|
|
cy.wait(500)
|
|
cy.get(".toprightnav button.spectrum-Button", { timeout: 2000 })
|
|
.contains("Publish")
|
|
.click({ force: true })
|
|
cy.get(".spectrum-Modal [data-cy='deploy-app-modal']")
|
|
.should("be.visible")
|
|
.within(() => {
|
|
cy.get(".spectrum-Button").contains("Publish").click({ force: true })
|
|
cy.wait(1000)
|
|
})
|
|
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".header-right button.spectrum-Button[data-cy='view-app']").should(
|
|
"not.be.disabled"
|
|
)
|
|
|
|
cy.get(".overview-tab [data-cy='app-status']").within(() => {
|
|
cy.get(".status-display").contains("Published")
|
|
cy.get(".status-display .icon svg[aria-label='GlobeCheck']").should(
|
|
"exist"
|
|
)
|
|
cy.get(".status-text").contains("Last published a few seconds ago")
|
|
})
|
|
})
|
|
|
|
it("Should reflect an application that has been unpublished", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Edit")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
|
|
cy.get(".deployment-top-nav svg[aria-label='Globe']").click({
|
|
force: true,
|
|
})
|
|
|
|
cy.get("[data-cy='publish-popover-menu']").should("be.visible")
|
|
cy.get(
|
|
"[data-cy='publish-popover-menu'] [data-cy='publish-popover-action']"
|
|
).click({ force: true })
|
|
|
|
cy.get("[data-cy='unpublish-modal']")
|
|
.should("be.visible")
|
|
.within(() => {
|
|
cy.get(".confirm-wrap button").click({ force: true })
|
|
})
|
|
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".overview-tab [data-cy='app-status']").within(() => {
|
|
cy.get(".status-display").contains("Unpublished")
|
|
cy.get(".status-display .icon svg[aria-label='GlobeStrike']").should(
|
|
"exist"
|
|
)
|
|
cy.get(".status-text").contains("Last published a few seconds ago")
|
|
})
|
|
})
|
|
|
|
it("Should allow the editing of the application icon and colour", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".edit-hover", { timeout: 1000 }).eq(0).click({ force: true })
|
|
// Select random icon
|
|
cy.wait(400)
|
|
cy.get(".grid").within(() => {
|
|
cy.get(".icon-item")
|
|
.eq(Math.floor(Math.random() * 23) + 1)
|
|
.click()
|
|
})
|
|
// Select random colour
|
|
cy.get(".fill").click()
|
|
cy.get(".colors").within(() => {
|
|
cy.get(".color")
|
|
.eq(Math.floor(Math.random() * 33) + 1)
|
|
.click()
|
|
})
|
|
cy.intercept("**/applications/**").as("iconChange")
|
|
cy.get(".spectrum-Button").contains("Save").click({ force: true })
|
|
cy.wait("@iconChange")
|
|
cy.get("@iconChange").its("response.statusCode").should("eq", 200)
|
|
// Confirm icon has changed from default
|
|
// Confirm colour has been applied
|
|
cy.get(".spectrum-ActionButton-label").contains("Back").click({ force: true })
|
|
cy.get(".appTable", { timeout: 2000 }).within(() => {
|
|
cy.get("[aria-label]")
|
|
.eq(0)
|
|
.children()
|
|
.should("have.attr", "xlink:href")
|
|
.and("not.contain", "#spectrum-icon-18-Apps")
|
|
cy.get(".title")
|
|
.children()
|
|
.children()
|
|
.should("have.attr", "style")
|
|
.and("contains", "color")
|
|
})
|
|
})
|
|
|
|
it("Should reflect the last time the application was edited", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".header-right button").contains("Edit").click({ force: true })
|
|
|
|
cy.navigateToFrontend()
|
|
|
|
cy.addComponent("Elements", "Headline").then(componentId => {
|
|
cy.getComponent(componentId).should("exist")
|
|
})
|
|
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".overview-tab [data-cy='edited-by']").within(() => {
|
|
cy.get(".editor-name").contains("You")
|
|
cy.get(".last-edit-text").contains("Last edited a few seconds ago")
|
|
})
|
|
})
|
|
|
|
it("Should reflect application version is up-to-date", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".overview-tab [data-cy='app-version']").within(() => {
|
|
cy.get(".version-status").contains("You're running the latest!")
|
|
})
|
|
})
|
|
|
|
it("Should navigate to the settings tab when clicking the App Version card header", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".spectrum-Tabs-item.is-selected").contains("Overview")
|
|
cy.get(".overview-tab").should("be.visible")
|
|
|
|
cy.get(".overview-tab [data-cy='app-version'] .dash-card-header").click({
|
|
force: true,
|
|
})
|
|
|
|
cy.get(".spectrum-Tabs-item.is-selected").contains("Settings")
|
|
cy.get(".settings-tab").should("be.visible")
|
|
cy.get(".overview-tab").should("not.exist")
|
|
})
|
|
|
|
it("Should allow the upgrading of an application, if available.", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.wait(500)
|
|
|
|
cy.location().then(loc => {
|
|
const params = loc.pathname.split("/")
|
|
const appId = params[params.length - 1]
|
|
cy.log(appId)
|
|
//Downgrade the app for the test
|
|
cy.alterAppVersion(appId, "0.0.1-alpha.0").then(() => {
|
|
cy.reload()
|
|
cy.log("Current deployment version: " + clientPackage.version)
|
|
|
|
cy.get(".version-status a", { timeout: 1000 }).contains("Update").click()
|
|
cy.get(".spectrum-Tabs-item.is-selected").contains("Settings")
|
|
|
|
cy.get(".version-section .page-action button")
|
|
.contains("Update")
|
|
.click({ force: true })
|
|
|
|
cy.intercept("POST", "**/applications/**/client/update").as(
|
|
"updateVersion"
|
|
)
|
|
cy.get(".spectrum-Modal.is-open button")
|
|
.contains("Update")
|
|
.click({ force: true })
|
|
|
|
cy.wait("@updateVersion")
|
|
.its("response.statusCode")
|
|
.should("eq", 200)
|
|
.then(() => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".spectrum-Tabs-item")
|
|
.contains("Overview")
|
|
.click({ force: true })
|
|
cy.get(".overview-tab [data-cy='app-version']").within(() => {
|
|
cy.get(".spectrum-Heading").contains(clientPackage.version)
|
|
cy.get(".version-status").contains("You're running the latest!")
|
|
})
|
|
})
|
|
})
|
|
})
|
|
})
|
|
|
|
it("Should allow editing of the app details.", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`, { timeout: 5000 })
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".spectrum-Tabs-item").contains("Settings").click()
|
|
cy.get(".spectrum-Tabs-item.is-selected").contains("Settings")
|
|
cy.get(".settings-tab").should("be.visible")
|
|
|
|
cy.get(".details-section .page-action button")
|
|
.contains("Edit")
|
|
.click({ force: true })
|
|
cy.updateAppName("sample name")
|
|
|
|
//publish and check its disabled
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`, { timeout: 5000 })
|
|
cy.wait(500)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Edit")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
|
|
cy.get(".toprightnav button.spectrum-Button")
|
|
.contains("Publish")
|
|
.click({ force: true })
|
|
cy.get(".spectrum-Modal [data-cy='deploy-app-modal']")
|
|
.should("be.visible")
|
|
.within(() => {
|
|
cy.get(".spectrum-Button").contains("Publish").click({ force: true })
|
|
cy.wait(1000)
|
|
})
|
|
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`, { timeout: 10000 })
|
|
cy.get(".appTable .app-row-actions button", { timeout: 5000 })
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".spectrum-Tabs-item").contains("Settings").click()
|
|
cy.get(".spectrum-Tabs-item.is-selected").contains("Settings")
|
|
|
|
cy.get(".details-section .page-action .spectrum-Button").scrollIntoView()
|
|
cy.get(".details-section .page-action .spectrum-Button", { timeout: 1000 }).should(
|
|
"be.disabled"
|
|
)
|
|
})
|
|
|
|
xit("Should allow copying of the published application Id", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions")
|
|
.eq(0)
|
|
.within(() => {
|
|
cy.get(".spectrum-Button").contains("Edit").click({ force: true })
|
|
})
|
|
|
|
cy.publishApp("sample-name")
|
|
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".app-overview-actions-icon > .icon").click({ force: true })
|
|
|
|
cy.get("[data-cy='app-overview-menu-popover']")
|
|
.eq(0)
|
|
.within(() => {
|
|
cy.get(".spectrum-Menu-item")
|
|
.contains("Copy App ID")
|
|
.click({ force: true })
|
|
})
|
|
|
|
cy.get(".spectrum-Toast-content")
|
|
.contains("App ID copied to clipboard.")
|
|
.should("be.visible")
|
|
})
|
|
|
|
it("Should allow unpublishing of the application via the Unpublish link", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
|
|
cy.get(`[data-cy="app-status"]`).within(() => {
|
|
cy.contains("Unpublish").click({ force: true })
|
|
})
|
|
|
|
cy.get("[data-cy='unpublish-modal']")
|
|
.should("be.visible")
|
|
.within(() => {
|
|
cy.get(".confirm-wrap button").click({ force: true })
|
|
})
|
|
|
|
cy.get(".overview-tab [data-cy='app-status']").within(() => {
|
|
cy.get(".status-display").contains("Unpublished")
|
|
cy.get(".status-display .icon svg[aria-label='GlobeStrike']")
|
|
.should("exist")
|
|
})
|
|
})
|
|
|
|
it("Should allow deleting of the application", () => {
|
|
cy.visit(`${Cypress.config().baseUrl}/builder`)
|
|
cy.get(".appTable .app-row-actions button")
|
|
.contains("Manage")
|
|
.eq(0)
|
|
.click({ force: true })
|
|
cy.get(".app-overview-actions-icon > .icon").click({ force: true })
|
|
|
|
cy.get("[data-cy='app-overview-menu-popover']")
|
|
.eq(0)
|
|
.within(() => {
|
|
cy.get(".spectrum-Menu-item")
|
|
.contains("Delete")
|
|
.click({ force: true })
|
|
cy.wait(500)
|
|
})
|
|
|
|
//The test application was renamed earlier in the spec
|
|
cy.get(".spectrum-Dialog-grid").within(() => {
|
|
cy.get("input").type("sample name")
|
|
cy.get(".spectrum-Button--warning").click()
|
|
})
|
|
|
|
cy.location().should(loc => {
|
|
expect(loc.pathname).to.eq("/builder/portal/apps")
|
|
})
|
|
|
|
cy.get(".appTable").should("not.exist")
|
|
|
|
cy.get(".welcome .container h1").contains("Let's create your first app!")
|
|
})
|
|
|
|
after(() => {
|
|
cy.deleteAllApps()
|
|
})
|
|
})
|
|
})
|