From 920ad9dd64575d2c7a4861b92b0cea6e3de5b778 Mon Sep 17 00:00:00 2001 From: Rory Doak Date: Tue, 22 Oct 2024 13:30:54 +0100 Subject: [PATCH] refactor: new test for label bug and naming refinement --- .../components/MapAndLabel/Public/Context.tsx | 1 + .../MapAndLabel/test/mocks/GenericValues.ts | 2 +- .../MapAndLabel/test/mocks/Trees.ts | 8 ++--- .../MapAndLabel/test/mocks/mockPayload.tsx | 8 ++--- .../test/public.backNavigation.test.tsx | 34 +++++++++++++++++-- 5 files changed, 42 insertions(+), 11 deletions(-) diff --git a/editor.planx.uk/src/@planx/components/MapAndLabel/Public/Context.tsx b/editor.planx.uk/src/@planx/components/MapAndLabel/Public/Context.tsx index 2f023e69a2..4c39177df2 100644 --- a/editor.planx.uk/src/@planx/components/MapAndLabel/Public/Context.tsx +++ b/editor.planx.uk/src/@planx/components/MapAndLabel/Public/Context.tsx @@ -83,6 +83,7 @@ export const MapAndLabelProvider: React.FC = ( const mergedProperties = { ...feature.properties, ...values.schemaData[i], + label: `${i + 1}`, }; feature["properties"] = mergedProperties; geojson.features.push(feature); 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 16c3737b3c..1ee9ab0758 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,7 +2,7 @@ export type TreeData = { species: string; work: string; justification: string; - urgency: "low" | "moderate" | "high" | "urgenct"; + urgency: "low" | "moderate" | "high" | "urgent"; label: string; }; diff --git a/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/Trees.ts b/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/Trees.ts index 8d79b1ad1f..a9cf990c0a 100644 --- a/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/Trees.ts +++ b/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/Trees.ts @@ -3,8 +3,8 @@ import { Schema } from "@planx/components/shared/Schema/model"; import { PresentationalProps } from "../../Public"; import { Trees } from "../../schemas/Trees"; import { - previouslySubmittedDoubleData, - previouslySubmittedSingleData, + previouslySubmittedDoubleFeature, + previouslySubmittedSingleFeature, } from "./mockPayload"; const mockTreeSchema: Schema = { @@ -27,10 +27,10 @@ export const props: PresentationalProps = { export const previousSingleDataProps: PresentationalProps = { ...props, - previouslySubmittedData: previouslySubmittedSingleData, + previouslySubmittedData: previouslySubmittedSingleFeature, }; export const previousDoubleDataProps: PresentationalProps = { ...props, - previouslySubmittedData: previouslySubmittedDoubleData, + previouslySubmittedData: previouslySubmittedDoubleFeature, }; diff --git a/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/mockPayload.tsx b/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/mockPayload.tsx index fa12d5dc6f..036e7bc719 100644 --- a/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/mockPayload.tsx +++ b/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/mockPayload.tsx @@ -27,7 +27,7 @@ export const mockSingleFeaturePayload: MockPayload = { }, }; -export const previousMockDoubleFeatureData: MockPayload = { +export const mockDoubleFeaturePayload: MockPayload = { data: { MockFn: { features: [ @@ -53,12 +53,12 @@ export const previousMockDoubleFeatureData: MockPayload = { }, }; -export const previouslySubmittedSingleData: PreviousData = { +export const previouslySubmittedSingleFeature: PreviousData = { auto: false, ...mockSingleFeaturePayload, }; -export const previouslySubmittedDoubleData: PreviousData = { +export const previouslySubmittedDoubleFeature: PreviousData = { auto: false, - ...previousMockDoubleFeatureData, + ...mockDoubleFeaturePayload, }; diff --git a/editor.planx.uk/src/@planx/components/MapAndLabel/test/public.backNavigation.test.tsx b/editor.planx.uk/src/@planx/components/MapAndLabel/test/public.backNavigation.test.tsx index 5e7b52db90..f0f0b9c697 100644 --- a/editor.planx.uk/src/@planx/components/MapAndLabel/test/public.backNavigation.test.tsx +++ b/editor.planx.uk/src/@planx/components/MapAndLabel/test/public.backNavigation.test.tsx @@ -9,7 +9,9 @@ import { previousDoubleDataProps, previousSingleDataProps, } from "./mocks/Trees"; -import { addMultipleFeatures } from "./utils"; +import { addFeaturesToMap, addMultipleFeatures, clickContinue } from "./utils"; +import { screen } from "@testing-library/react"; +import { userDataSchema } from "@planx/components/AddressInput/model"; beforeAll(() => { if (!window.customElements.get("my-map")) { @@ -40,11 +42,14 @@ describe("navigating back after adding single feature", () => { const firstTabPanel = getByTestId("vertical-tabpanel-0"); expect(firstTabPanel).toBeVisible(); - // point1 here needs to be reflected in the props you pass in at the start so labels match + // To properly add the features to the map, you need to pass all previous features as well addMultipleFeatures([point1, point2]); const secondTab = queryByRole("tab", { name: /Tree 2/ }); expect(secondTab).toBeVisible(); + + const secondTabPanel = getByTestId("vertical-tabpanel-1"); + expect(secondTabPanel).toBeVisible(); }); }); @@ -65,9 +70,34 @@ describe("navigating back after adding two features", () => { const secondTabPanel = getByTestId("vertical-tabpanel-1"); expect(secondTabPanel).toBeVisible(); + // To properly add the features to the map, you need to pass all previous features as well addMultipleFeatures([point1, point2, point3]); const thirdTab = queryByRole("tab", { name: /Tree 3/ }); expect(thirdTab).toBeVisible(); + + const thirdTabPanel = getByTestId("vertical-tabpanel-2"); + expect(thirdTabPanel).toBeVisible(); + }); + it.only("should maintain labelling when removing a feature", async () => { + const handleSubmit = vi.fn(); + const { getByRole, user } = setup( + , + ); + + const firstTab = getByRole("tab", { name: /Tree 1/ }); + + await user.click(firstTab); + + const removeButton = getByRole("button", { name: /remove/i }); + + await user.click(removeButton); + + await clickContinue(user); + + const output = + handleSubmit.mock.calls[0][0].data.MockFn.features[0].properties.label; + + expect(output).toEqual("1"); }); });