// TODO for now components are skipped, might not be good to keep doing this import filterTests from "../support/filterTests" const interact = require('../support/interact') filterTests(['all'], () => { xcontext("Create Components", () => { let headlineId before(() => { cy.login() cy.createTestApp() cy.createTable("dog") cy.addColumn("dog", "name", "Text") cy.addColumn("dog", "age", "Number") cy.addColumn("dog", "type", "Options") cy.navigateToFrontend() }) it("should add a container", () => { cy.addComponent(null, "Container").then(componentId => { cy.getComponent(componentId).should("exist") }) }) it("should add a headline", () => { cy.addComponent("Elements", "Headline").then(componentId => { headlineId = componentId cy.getComponent(headlineId).should("exist") }) }) it("should change the text of the headline", () => { const text = "Lorem ipsum dolor sit amet." cy.get(interact.DATA_CY_SETTINGS).click() cy.get(interact.SETTINGS_INPUT) .type(text) .blur() cy.getComponent(headlineId).should("have.text", text) }) it("should change the size of the headline", () => { cy.get(interact.DATA_CY_DESIGN).click() cy.contains("Typography").click() cy.get(interact.DATA_CY_FSPCONTROL).click() cy.contains("60px").click() cy.getComponent(headlineId).should("have.css", "font-size", "60px") }) it("should create a form and reset to match schema", () => { cy.addComponent("Form", "Form").then(() => { cy.get(interact.DATA_CY_SETTINGS).click() cy.get(interact.DATA_CY_DATASOURCE) .contains("Choose option") .click() cy.get(interact.DROPDOWN) .contains("dog") .click() cy.addComponent("Form", "Field Group").then(fieldGroupId => { cy.get(interact.DATA_CY_SETTINGS).click() cy.contains("Update Form Fields").click() cy.get(".modal") .get("button.primary") .click() cy.getComponent(fieldGroupId).within(() => { cy.contains("name").should("exist") cy.contains("age").should("exist") cy.contains("type").should("exist") }) cy.getComponent(fieldGroupId) .find("input") .should("have.length", 2) cy.getComponent(fieldGroupId) .find(".spectrum-Picker") .should("have.length", 1) }) }) }) it("deletes a component", () => { cy.addComponent("Elements", "Paragraph").then(componentId => { cy.get("[data-cy=setting-_instanceName] input") .type(componentId) .blur() cy.get(".ui-nav ul .nav-item.selected .ri-more-line").click({ force: true, }) cy.get(interact.DROPDOWN_CONTAINER) .contains("Delete") .click() cy.get(".modal") .contains("Delete Component") .click() cy.getComponent(componentId).should("not.exist") }) }) }) })