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

213 lines
5.4 KiB
JavaScript
Raw Normal View History

2020-06-09 13:52:00 +02:00
// ***********************************************
// This example commands.js shows you how to
// create various custom commands and overwrite
// existing commands.
//
// For more comprehensive examples of custom
// commands please read more here:
// https://on.cypress.io/custom-commands
// ***********************************************
//
//
// -- This is a parent command --
// Cypress.Commands.add("login", (email, password) => { ... })
//
//
// -- This is a child command --
// Cypress.Commands.add("drag", { prevSubject: 'element'}, (subject, options) => { ... })
//
//
// -- This is a dual command --
// Cypress.Commands.add("dismiss", { prevSubject: 'optional'}, (subject, options) => { ... })
//
//
// -- This will overwrite an existing command --
// Cypress.Commands.overwrite("visit", (originalFn, url, options) => { ... })
2021-04-15 14:23:42 +02:00
Cypress.Commands.add("login", () => {
2021-04-15 19:29:11 +02:00
cy.getCookie("budibase:auth").then(cookie => {
2021-04-15 19:34:49 +02:00
// Already logged in
2021-04-15 19:29:11 +02:00
if (cookie) return
2021-04-15 18:46:47 +02:00
2021-04-15 19:29:11 +02:00
cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
cy.contains("Create Test User").click()
cy.get("input")
.first()
.type("test@test.com")
cy.get('input[type="password"]').type("test")
2021-04-15 14:23:42 +02:00
2021-04-15 19:29:11 +02:00
cy.contains("Login").click()
})
})
Cypress.Commands.add("createApp", name => {
cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
// wait for init API calls on visit
cy.wait(100)
cy.contains("Create New Web App").click()
cy.get("body")
.then($body => {
if ($body.find("input[name=apiKey]").length) {
// input was found, do something else here
2020-10-28 18:40:14 +01:00
cy.get("input[name=apiKey]")
.type(name)
.should("have.value", name)
cy.contains("Next").click()
}
})
.then(() => {
cy.get("input[name=applicationName]")
.type(name)
.should("have.value", name)
cy.contains("Next").click()
cy.contains("Submit").click()
2020-10-27 16:26:07 +01:00
cy.get("[data-cy=new-table]", {
2020-09-05 01:03:08 +02:00
timeout: 20000,
}).should("be.visible")
})
})
Cypress.Commands.add("deleteApp", name => {
cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
cy.get(".apps").then($apps => {
cy.wait(1000)
if ($apps.find(`[data-cy="app-${name}"]`).length) {
cy.get(`[data-cy="app-${name}"] a`).click()
cy.get("[data-cy=settings-icon]").click()
cy.get(".modal-content").within(() => {
cy.contains("Danger Zone").click()
cy.get("input").type("DELETE")
cy.contains("Delete Entire App").click()
})
}
})
})
Cypress.Commands.add("createTestApp", () => {
const appName = "Cypress Tests"
cy.deleteApp(appName)
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")
})
2020-08-10 16:34:37 +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()
2020-10-08 12:36:16 +02:00
cy.get(".modal").within(() => {
2020-10-28 18:40:14 +01:00
cy.get("input")
.first()
.type(tableName)
cy.get(".buttons")
.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()
2020-08-10 18:51:30 +02:00
cy.contains("Create New Column").click()
2020-06-11 18:14:28 +02:00
// Configure column
2020-10-26 22:43:04 +01:00
cy.get(".actions").within(() => {
2020-10-28 18:40:14 +01:00
cy.get("input")
.first()
.type(columnName)
2020-10-15 09:17:26 +02:00
// Unset table display column
cy.contains("display column").click()
cy.get("select").select(type)
cy.contains("Save").click()
})
})
Cypress.Commands.add("addRow", values => {
2020-08-10 18:51:30 +02:00
cy.contains("Create New Row").click()
cy.get(".modal").within(() => {
for (let i = 0; i < values.length; i++) {
2020-10-28 18:40:14 +01:00
cy.get("input")
.eq(i)
.type(values[i])
}
2020-10-28 18:40:14 +01:00
cy.get(".buttons")
.contains("Create")
.click()
})
})
Cypress.Commands.add("createUser", (email, password, role) => {
2020-06-11 18:14:28 +02:00
// Create User
cy.contains("Users").click()
2020-12-14 14:33:34 +01:00
cy.contains("Create New User").click()
2020-11-27 14:17:31 +01:00
cy.get(".modal").within(() => {
cy.get("input")
.first()
.type(email)
2020-11-27 14:17:31 +01:00
cy.get("input")
.eq(1)
.type(password)
2020-11-27 14:17:31 +01:00
cy.get("select")
.first()
.select(role)
2020-11-27 14:17:31 +01:00
// Save
cy.get(".buttons")
.contains("Create User")
2020-11-27 14:17:31 +01:00
.click()
})
})
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)
cy.location().then(loc => {
const params = loc.pathname.split("/")
const componentId = params[params.length - 1]
cy.getComponent(componentId).should("exist")
return cy.wrap(componentId)
})
})
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", () => {
2020-10-27 16:26:07 +01:00
cy.contains("design").click()
2020-06-24 17:16:06 +02:00
})
Cypress.Commands.add("createScreen", (screenName, route) => {
2020-10-27 16:26:07 +01:00
cy.get("[data-cy=new-screen]").click()
2020-10-05 13:37:03 +02:00
cy.get(".modal").within(() => {
2020-10-28 18:40:14 +01:00
cy.get("input")
.eq(0)
.type(screenName)
2020-10-05 13:37:03 +02:00
if (route) {
2020-10-28 18:40:14 +01:00
cy.get("input")
.eq(1)
.type(route)
2020-10-05 13:37:03 +02:00
}
2020-06-24 17:20:58 +02:00
cy.contains("Create Screen").click()
})
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
})
})