import filterTests from "../support/filterTests" const interact = require('../support/interact') filterTests(['all'], () => { xcontext("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)") }) }) }) })