diff --git a/setupTests.js b/setupTests.js index 980252d..9f2c116 100644 --- a/setupTests.js +++ b/setupTests.js @@ -199,6 +199,7 @@ window.profileList = [ slug: "custom", }, { + slug: "build-custom-environment", description: "Dynamic Image building + unlisted choice", display_name: "Build custom environment", profile_options: { @@ -220,4 +221,15 @@ window.profileList = [ }, }, }, + { + slug: "empty-options", + description: "Profile with empty options", + display_name: "Empty Options", + profile_options: {}, + }, + { + slug: "no-options", + description: "Profile with no options", + display_name: "No Options", + }, ]; diff --git a/src/ProfileForm.test.js b/src/ProfileForm.test.js index 34614b2..ab55146 100644 --- a/src/ProfileForm.test.js +++ b/src/ProfileForm.test.js @@ -234,4 +234,22 @@ describe("Profile form with URL Params", () => { expect(screen.getByLabelText("Repository").value).toEqual("org/repo"); expect(screen.getByLabelText("Git Ref").value).toEqual("v1.0"); }); + + test("no-option profiles are rendered", () => { + render( + + + , + ); + + const empty = screen.queryByRole("radio", { + name: "Empty Options Profile with empty options", + }); + expect(empty).toBeInTheDocument(); + + const noObject = screen.queryByRole("radio", { + name: "No Options Profile with no options", + }); + expect(noObject).toBeInTheDocument(); + }); }); diff --git a/src/state.js b/src/state.js index 5d261c1..f217caa 100644 --- a/src/state.js +++ b/src/state.js @@ -5,6 +5,9 @@ export const SpawnerFormContext = createContext(); function isDynamicImageProfile(profile) { const { profile_options } = profile; + + if (!profile_options) return false; + return Object.entries(profile_options).some(([key, option]) => hasDynamicImageBuilding(key, option), );