budibase/packages/builder/cypress/support/commands.js

181 lines
5.1 KiB
JavaScript
Raw Normal View History

2020-06-09 13:52:00 +02:00
// ***********************************************
// For more comprehensive examples of custom
// commands please read more here:
// https://on.cypress.io/custom-commands
// ***********************************************
//
export function checkIfElementExists(el) {
return new Promise(resolve => {
/// here if ele exists or not
cy.get("body").then(body => {
if (body.find(el).length > 0) {
resolve(true)
} else {
resolve(false)
}
})
})
}
async function isFirstApp() {
return checkIfElementExists(".empty-wrapper")
}
2021-04-15 14:23:42 +02:00
Cypress.Commands.add("login", () => {
2021-05-25 14:25:42 +02:00
cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
cy.wait(500)
2021-05-25 14:25:42 +02:00
cy.url().then(url => {
if (url.includes("builder/admin")) {
// create admin user
cy.get("input").first().type("test@test.com")
cy.get('input[type="password"]').first().type("test")
cy.get('input[type="password"]').eq(1).type("test")
cy.contains("Create super admin user").click()
}
if (url.includes("builder/auth/login") || url.includes("builder/admin")) {
// login
cy.contains("Sign in to Budibase").then(() => {
cy.get("input").first().type("test@test.com")
cy.get('input[type="password"]').type("test")
cy.get("button").first().click()
})
}
2021-04-15 19:29:11 +02:00
})
})
2021-05-04 12:32:22 +02:00
Cypress.Commands.add("createApp", name => {
cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
cy.wait(500)
isFirstApp().then(isFirst => {
const buttonText = isFirst ? "Create app" : "Create new app"
cy.contains(buttonText).click()
cy.get("body").then(() => {
cy.get(".spectrum-Modal")
.within(() => {
cy.get("input").eq(0).type(name).should("have.value", name).blur()
cy.contains("Create app").click()
})
.then(() => {
cy.get("[data-cy=new-table]", {
timeout: 20000,
}).should("be.visible")
})
})
2021-05-25 14:25:42 +02:00
})
})
Cypress.Commands.add("deleteApp", () => {
cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
cy.wait(1000)
isFirstApp().then(isFirst => {
if (!isFirst) {
cy.get(".hoverable > use").click()
cy.contains("Delete").click()
cy.get(".spectrum-Button--warning").click()
}
})
})
Cypress.Commands.add("createTestApp", () => {
const appName = "Cypress Tests"
cy.deleteApp()
cy.createApp(appName, "This app is used for Cypress testing.")
})
Cypress.Commands.add("createTestTableWithData", () => {
cy.createTable("dog")
cy.addColumn("dog", "name", "Text")
cy.addColumn("dog", "age", "Number")
})
2021-05-04 12:32:22 +02:00
Cypress.Commands.add("createTable", tableName => {
// Enter table name
2020-10-27 16:26:07 +01:00
cy.get("[data-cy=new-table]").click()
cy.get(".spectrum-Modal").within(() => {
2021-05-03 09:31:09 +02:00
cy.get("input").first().type(tableName).blur()
cy.get(".spectrum-ButtonGroup").contains("Create").click()
2020-10-08 12:36:16 +02:00
})
2020-08-10 16:34:37 +02:00
cy.contains(tableName).should("be.visible")
})
2020-06-11 18:14:28 +02:00
2020-08-10 16:34:37 +02:00
Cypress.Commands.add("addColumn", (tableName, columnName, type) => {
// Select Table
2020-10-27 16:26:07 +01:00
cy.contains(".nav-item", tableName).click()
cy.contains("Create column").click()
2020-06-11 18:14:28 +02:00
// Configure column
cy.get(".spectrum-Modal").within(() => {
2021-05-03 09:31:09 +02:00
cy.get("input").first().type(columnName).blur()
2020-10-15 09:17:26 +02:00
// Unset table display column
cy.contains("display column").click({ force: true })
cy.get(".spectrum-Picker-label").click()
cy.contains(type).click()
cy.contains("Save Column").click()
})
})
2021-05-04 12:32:22 +02:00
Cypress.Commands.add("addRow", values => {
cy.contains("Create row").click()
cy.get(".spectrum-Modal").within(() => {
for (let i = 0; i < values.length; i++) {
2021-05-03 09:31:09 +02:00
cy.get("input").eq(i).type(values[i]).blur()
}
2021-05-03 09:31:09 +02:00
cy.get(".spectrum-ButtonGroup").contains("Create").click()
})
})
Cypress.Commands.add("createUser", email => {
// quick hacky recorded way to create a user
cy.contains("Users").click()
cy.get(".spectrum-Button--primary").click()
cy.get(".spectrum-Picker-label").click()
cy.get(".spectrum-Menu-item:nth-child(2) > .spectrum-Menu-itemLabel").click()
cy.get(".spectrum-Modal input").eq(1).type(email, { force: true })
cy.get(".spectrum-Button--cta").click({ force: true })
})
Cypress.Commands.add("addComponent", (category, component) => {
if (category) {
cy.get(`[data-cy="category-${category}"]`).click()
}
cy.get(`[data-cy="component-${component}"]`).click()
2021-04-01 11:08:58 +02:00
cy.wait(1000)
2021-05-04 12:32:22 +02:00
cy.location().then(loc => {
const params = loc.pathname.split("/")
const componentId = params[params.length - 1]
cy.getComponent(componentId).should("exist")
return cy.wrap(componentId)
})
})
2021-05-04 12:32:22 +02:00
Cypress.Commands.add("getComponent", componentId => {
return cy
.get("iframe")
.its("0.contentDocument")
.should("exist")
.its("body")
.should("not.be.null")
.then(cy.wrap)
.find(`[data-component-id=${componentId}]`)
2020-06-11 18:14:28 +02:00
})
2020-06-24 17:16:06 +02:00
2020-06-24 17:20:58 +02:00
Cypress.Commands.add("navigateToFrontend", () => {
2021-05-25 17:52:35 +02:00
cy.contains("Design").click()
2020-06-24 17:16:06 +02:00
})
Cypress.Commands.add("createScreen", (screenName, route) => {
2021-05-25 17:52:35 +02:00
cy.get("[aria-label=AddCircle]").click()
cy.get(".spectrum-Modal").within(() => {
2021-05-25 17:52:35 +02:00
cy.get("input").first().type(screenName)
cy.get("input").eq(1).type(route)
cy.get(".spectrum-Button--cta").click()
2020-06-24 17:20:58 +02:00
})
cy.get(".nav-items-container").within(() => {
2020-11-20 12:41:17 +01:00
cy.contains(route).should("exist")
2020-06-24 17:20:58 +02:00
})
})