From 46ae0f3fd383b01933f280d2f84e85b876168f15 Mon Sep 17 00:00:00 2001 From: minnakt Date: Fri, 1 Sep 2023 11:06:07 -0400 Subject: [PATCH] EVG-19946: Add Docker to provider settings page --- .../distroSettings/provider_section.ts | 100 ++++++++++++---- .../SpruceForm/Widgets/LeafyGreenWidgets.tsx | 2 + src/gql/generated/types.ts | 94 +++++++++------ src/gql/queries/index.ts | 2 +- ...e-config.graphql => spruce-config.graphql} | 8 ++ .../tabs/ProviderTab/ProviderTab.tsx | 21 +++- .../tabs/ProviderTab/getFormSchema.ts | 88 +++++++++++++- .../tabs/ProviderTab/schemaFields.ts | 58 ++++++++- .../tabs/ProviderTab/transformerUtils.ts | 91 ++++++++++++-- .../tabs/ProviderTab/transformers.test.ts | 112 ++++++++++++++---- .../tabs/ProviderTab/transformers.ts | 40 +++++-- .../distroSettings/tabs/ProviderTab/types.ts | 25 +++- 12 files changed, 526 insertions(+), 115 deletions(-) rename src/gql/queries/{get-spruce-config.graphql => spruce-config.graphql} (79%) diff --git a/cypress/integration/distroSettings/provider_section.ts b/cypress/integration/distroSettings/provider_section.ts index 740ad09c89..6748ae1e31 100644 --- a/cypress/integration/distroSettings/provider_section.ts +++ b/cypress/integration/distroSettings/provider_section.ts @@ -1,38 +1,88 @@ import { save } from "./utils"; describe("provider section", () => { - beforeEach(() => { - cy.visit("/distro/localhost/settings/provider"); - }); + describe("static", () => { + beforeEach(() => { + cy.visit("/distro/localhost/settings/provider"); + }); + + it("successfully updates static provider fields", () => { + cy.dataCy("provider-select").contains("Static IP/VM"); + + // Correct fields are displayed + cy.dataCy("provider-settings").within(() => { + cy.get("button").should("have.length", 1); + cy.get("textarea").should("have.length", 1); + cy.get("input[type=checkbox]").should("have.length", 1); + cy.get("input[type=text]").should("have.length", 0); + }); + + cy.getInputByLabel("User Data").type("my user data"); + cy.getInputByLabel("Merge with existing user data").check({ + force: true, + }); + cy.contains("button", "Add security group").click(); + cy.getInputByLabel("Security Group ID").type("group-1234"); + + save(); + cy.validateToast("success"); - it("successfully updates static provider fields", () => { - cy.dataCy("provider-select").contains("Static IP/VM"); + cy.getInputByLabel("User Data").clear(); + cy.getInputByLabel("Merge with existing user data").uncheck({ + force: true, + }); + cy.dataCy("delete-item-button").click(); - // Correct fields are displayed - cy.dataCy("provider-settings").within(() => { - cy.get("button").should("have.length", 1); - cy.get("textarea").should("have.length", 1); - cy.get("input[type=checkbox]").should("have.length", 1); - cy.get("input[type=text]").should("have.length", 0); + save(); + cy.validateToast("success"); }); + }); - cy.getInputByLabel("User Data").type("my user data"); - cy.getInputByLabel("Merge with existing user data").check({ - force: true, + describe.only("docker", () => { + beforeEach(() => { + cy.visit("/distro/ubuntu1604-container-test/settings/provider"); }); - cy.contains("button", "Add security group").click(); - cy.getInputByLabel("Security Group ID").type("group-1234"); - save(); - cy.validateToast("success"); + it("successfully updates docker provider fields", () => { + cy.dataCy("provider-select").contains("Docker"); - cy.getInputByLabel("User Data").clear(); - cy.getInputByLabel("Merge with existing user data").uncheck({ - force: true, - }); - cy.dataCy("delete-item-button").click(); + // Correct fields are displayed + cy.dataCy("provider-settings").within(() => { + cy.getInputByLabel("Docker Image URL").should("exist"); + cy.getInputByLabel("Image Build Method").should("exist"); + cy.getInputByLabel("Username for Registries").should("exist"); + cy.getInputByLabel("Password for Registries").should("exist"); + cy.getInputByLabel("Container Pool ID").should("exist"); + cy.getInputByLabel("Pool Mapping Information").should("exist"); + cy.getInputByLabel("User Data").should("exist"); + cy.getInputByLabel("Merge with existing user data").should("exist"); + cy.contains("button", "Add security group").should("exist"); + }); + + // Change field values. + cy.selectLGOption("Image Build Method", "Pull"); + cy.selectLGOption("Container Pool ID", /^test-pool$/); + cy.getInputByLabel("Username for Registries").type("username"); + cy.getInputByLabel("Password for Registries").type("password"); + cy.getInputByLabel("User Data").type("my user data"); + cy.getInputByLabel("Merge with existing user data").check({ + force: true, + }); + save(); + cy.validateToast("success"); - save(); - cy.validateToast("success"); + // Revert fields to original values. + cy.selectLGOption("Image Build Method", "Import"); + cy.selectLGOption("Container Pool ID", "ubuntu-test-pool"); + cy.getInputByLabel("Username for Registries").clear(); + cy.getInputByLabel("Password for Registries").clear(); + cy.getInputByLabel("User Data").clear(); + cy.getInputByLabel("Merge with existing user data").uncheck({ + force: true, + }); + + save(); + cy.validateToast("success"); + }); }); }); diff --git a/src/components/SpruceForm/Widgets/LeafyGreenWidgets.tsx b/src/components/SpruceForm/Widgets/LeafyGreenWidgets.tsx index acc89574e9..0ff8389d33 100644 --- a/src/components/SpruceForm/Widgets/LeafyGreenWidgets.tsx +++ b/src/components/SpruceForm/Widgets/LeafyGreenWidgets.tsx @@ -339,6 +339,7 @@ export const LeafyGreenTextArea: React.FC = ({ label, onChange, options, + placeholder, rawErrors, readonly, value, @@ -368,6 +369,7 @@ export const LeafyGreenTextArea: React.FC = ({