From b248eccb2e7d6cd02ecf4319a84b4a00ff5ef37f Mon Sep 17 00:00:00 2001 From: Rory Doak <138574807+RODO94@users.noreply.github.com> Date: Wed, 18 Sep 2024 09:11:44 +0100 Subject: [PATCH] feat: Map and Label Copy Tests (#3695) --- .../MapAndLabel/Public/index.test.tsx | 104 ++++++++++++++++-- .../MapAndLabel/test/mocks/GenericValues.ts | 3 +- 2 files changed, 93 insertions(+), 14 deletions(-) diff --git a/editor.planx.uk/src/@planx/components/MapAndLabel/Public/index.test.tsx b/editor.planx.uk/src/@planx/components/MapAndLabel/Public/index.test.tsx index c79f02117e..58ce130ef2 100644 --- a/editor.planx.uk/src/@planx/components/MapAndLabel/Public/index.test.tsx +++ b/editor.planx.uk/src/@planx/components/MapAndLabel/Public/index.test.tsx @@ -18,6 +18,7 @@ import { fillOutForm, fillOutSecondHalfOfForm, } from "../test/utils"; +import { mockTreeData } from "../test/mocks/GenericValues"; beforeAll(() => { if (!window.customElements.get("my-map")) { @@ -332,18 +333,97 @@ describe("basic interactions - happy path", () => { }); describe("copy feature select", () => { - it.todo("is disabled if only a single feature is present"); - // no copy select if only one feature - it.todo("is enabled once multiple features are present"); - // copy select enabled once you add more features - it.todo( - "lists all other features as options (the current feature is not listed)" - ); - // current tree is not an option in the copy select - it.todo("copies all data from one feature to another"); - // all data fields are populated from one field to another - it.todo("should not have any accessibility violations"); - // axe checks + it("is disabled if only a single feature is present", async () => { + const { getByTestId, getByTitle } = setup(); + const map = getByTestId("map-and-label-map"); + + addFeaturesToMap(map, [point1]); + + const copyTitle = getByTitle("Copy from"); + + const copyInput = within(copyTitle).getByRole("combobox"); + + expect(copyInput).toHaveAttribute("aria-disabled", "true"); + }); + + it("is enabled once multiple features are present", async () => { + const { getByTitle } = setup(); + + addMultipleFeatures([point1, point2]); + + const copyTitle = getByTitle("Copy from"); + + const copyInput = within(copyTitle).getByRole("combobox"); + + expect(copyInput).not.toHaveAttribute("aria-disabled", "true"); + }); + + it("lists all other features as options (the current feature is not listed)", async () => { + const { getByTitle, user, queryByRole } = setup(); + addMultipleFeatures([point1, point2]); + + const copyTitle = getByTitle("Copy from"); + + const copyInput = within(copyTitle).getByRole("combobox"); + + expect(copyInput).not.toHaveAttribute("aria-disabled", "true"); + + await user.click(copyInput); + + // Current item would be Tree 2 since we added two points + const listItemTwo = queryByRole("option", { name: "Tree 2" }); + + expect(listItemTwo).not.toBeInTheDocument(); + }); + + it("copies all data from one feature to another", async () => { + const { getByTitle, user, getByLabelText, getByRole } = setup( + + ); + addMultipleFeatures([point1, point2]); + const tabOne = getByRole("tab", { name: /Tree 1/ }); + + await fillOutForm(user); + + await user.click(tabOne); + + const copyTitle = getByTitle("Copy from"); + const copyInput = within(copyTitle).getByRole("combobox", { + name: "Copy from", + }); + + await user.click(copyInput); + + const listItemTwo = getByRole("option", { name: "Tree 2" }); + + await user.click(listItemTwo); + + const urgencyDiv = getByTitle("Urgency"); + const urgencySelect = within(urgencyDiv).getByRole("combobox"); + + expect(getByLabelText("Species")).toHaveDisplayValue(mockTreeData.species); + expect(getByLabelText("Proposed work")).toHaveDisplayValue( + mockTreeData.work + ); + expect(getByLabelText("Justification")).toHaveDisplayValue( + mockTreeData.justification + ); + expect(urgencySelect).toHaveTextContent(mockTreeData.urgency); + }); + + it("should not have any accessibility violations", async () => { + const { getByTitle, user, container } = setup(); + addMultipleFeatures([point1, point2]); + + const copyTitle = getByTitle("Copy from"); + + const copyInput = within(copyTitle).getByRole("combobox"); + + await user.click(copyInput); + + const results = await axe(container); + expect(results).toHaveNoViolations(); + }); }); describe("remove feature button", () => { diff --git a/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/GenericValues.ts b/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/GenericValues.ts index 61912b194d..a67af1c009 100644 --- a/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/GenericValues.ts +++ b/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/GenericValues.ts @@ -2,6 +2,5 @@ export const mockTreeData = { species: "Larch", work: "Chopping it down", justification: "Cause I can", - urgency: "High", - completionDate: { day: "", month: "", year: "" }, + urgency: "Low", };