8e4ceb036b
In some cases Cypress is running too fast, meaning that the test runs ahead of what is actual seen on Budibase. This issue mainly occurs at the start of the smoke build and around logging in. I am attempting to combat this by ensuring the url includes 'apps' after logging in
45 lines
1.6 KiB
JavaScript
45 lines
1.6 KiB
JavaScript
import filterTests from "../support/filterTests"
|
|
const interact = require('../support/interact')
|
|
|
|
filterTests(['all'], () => {
|
|
context("Add Multi-Option Datatype", () => {
|
|
before(() => {
|
|
cy.login()
|
|
cy.createTestApp()
|
|
})
|
|
|
|
it("should create a new table, with data", () => {
|
|
cy.createTable("Multi Data")
|
|
cy.addColumn("Multi Data", "Test Data", "Multi-select", "1\n2\n3\n4\n5")
|
|
cy.addRowMultiValue(["1", "2", "3", "4", "5"])
|
|
})
|
|
|
|
it("should add form with multi select picker, containing 5 options", () => {
|
|
cy.navigateToFrontend()
|
|
// Add data provider
|
|
cy.searchAndAddComponent("Data Provider")
|
|
cy.get(interact.DATASOURCE_PROP_CONTROL).click()
|
|
cy.get(interact.DROPDOWN).contains("Multi Data").click()
|
|
// Add Form with schema to match table
|
|
cy.searchAndAddComponent("Form")
|
|
cy.get(interact.DATASOURCE_PROP_CONTROL).click()
|
|
cy.get(interact.DROPDOWN).contains("Multi Data").click()
|
|
// Add multi-select picker to form
|
|
cy.searchAndAddComponent("Multi-select Picker").then(componentId => {
|
|
cy.get(interact.DATASOURCE_FIELD_CONTROL).type("Test Data").type("{enter}")
|
|
cy.wait(1000)
|
|
cy.getComponent(componentId).contains("Choose some options").click()
|
|
// Check picker has 5 items
|
|
cy.getComponent(componentId).find("li").should("have.length", 5)
|
|
// Select all items
|
|
for (let i = 1; i < 6; i++) {
|
|
cy.getComponent(componentId).find("li").contains(i).click()
|
|
}
|
|
// Check items have been selected
|
|
cy.getComponent(componentId)
|
|
.find(interact.SPECTRUM_PICKER_LABEL)
|
|
.contains("(5)")
|
|
})
|
|
})
|
|
})
|
|
})
|