From f8dfadd4f8d40ccf6a6f3e2bc4676bedbb2c0577 Mon Sep 17 00:00:00 2001 From: Rory Doak <138574807+RODO94@users.noreply.github.com> Date: Thu, 19 Sep 2024 10:22:16 +0100 Subject: [PATCH] feat: Map and Label Payload Tests (#3698) --- .../MapAndLabel/Public/index.test.tsx | 123 +++++++++++++----- .../MapAndLabel/test/mocks/GenericValues.ts | 13 +- .../MapAndLabel/test/mocks/mockPayload.tsx | 21 +++ 3 files changed, 126 insertions(+), 31 deletions(-) create mode 100644 editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/mockPayload.tsx 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 5addd9b4c3..57b134f2a7 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 @@ -5,7 +5,6 @@ import React from "react"; import { setup } from "testUtils"; import { vi } from "vitest"; import { axe } from "vitest-axe"; - import { mockFeaturePointObj, point1, @@ -23,7 +22,11 @@ import { fillOutForm, fillOutSecondHalfOfForm, } from "../test/utils"; -import { mockTreeData } from "../test/mocks/GenericValues"; +import { mockTreeData, TreeData } from "../test/mocks/GenericValues"; +import { + MockPayload, + mockSingleFeaturePayload, +} from "../test/mocks/mockPayload"; beforeAll(() => { if (!window.customElements.get("my-map")) { @@ -60,14 +63,14 @@ describe("Basic UI", () => { await waitFor(() => expect( - queryByText("Plot a feature on the map to begin"), - ).not.toBeInTheDocument(), + queryByText("Plot a feature on the map to begin") + ).not.toBeInTheDocument() ); }); it("renders the schema name as the tab title", async () => { const { queryByText, getByRole, getByTestId } = setup( - , + ); expect(queryByText(/Tree 1/)).not.toBeInTheDocument(); @@ -81,7 +84,7 @@ describe("Basic UI", () => { it("should not have any accessibility violations", async () => { const { queryByText, getByTestId, container } = setup( - , + ); expect(queryByText(/Tree 1/)).not.toBeInTheDocument(); @@ -98,7 +101,7 @@ describe("Basic UI", () => { describe("validation and error handling", () => { it("shows all fields are required", async () => { const { getByTestId, user, queryByRole, getAllByTestId } = setup( - , + ); const map = getByTestId("map-and-label-map"); @@ -123,8 +126,6 @@ describe("validation and error handling", () => { expect(message).not.toBeEmptyDOMElement(); }); }); - - // it shows all fields are required in a tab it("should show all fields are required, for all feature tabs", async () => { const { getByTestId, getByRole, user } = setup(); @@ -157,8 +158,6 @@ describe("validation and error handling", () => { // error messages persist await checkErrorMessagesPopulated(); }); - - // it shows all fields are required across different tabs it("should show an error if the minimum number of items is not met", async () => { const { getByTestId, user } = setup(); @@ -169,10 +168,9 @@ describe("validation and error handling", () => { const errorMessage = within(errorWrapper).getByText(/You must plot /); expect(errorMessage).toBeVisible(); }); - // ?? it("an error state is applied to a tabpanel button, when it's associated feature is invalid", async () => { const { getByTestId, user, queryByRole } = setup( - , + ); const map = getByTestId("map-and-label-map"); @@ -188,13 +186,12 @@ describe("validation and error handling", () => { expect(tabOne).toHaveStyle("border-left: 5px solid #D4351C"); }); - // shows the error state on a tab when it's invalid }); it("does not trigger handleSubmit when errors exist", async () => { const handleSubmit = vi.fn(); const { getByTestId, user } = setup( - , + ); const map = getByTestId("map-and-label-map"); @@ -407,7 +404,9 @@ describe("copy feature select", () => { await user.click(listItemTwo); const urgencyDiv = getByTitle("Urgency"); - const urgencySelect = within(urgencyDiv).getByRole("combobox"); + const urgencyInput = within(urgencyDiv).getByRole("textbox", { + hidden: true, + }); expect(getByLabelText("Species")).toHaveDisplayValue(mockTreeData.species); expect(getByLabelText("Proposed work")).toHaveDisplayValue( @@ -416,7 +415,7 @@ describe("copy feature select", () => { expect(getByLabelText("Justification")).toHaveDisplayValue( mockTreeData.justification ); - expect(urgencySelect).toHaveTextContent(mockTreeData.urgency); + expect(urgencyInput).toHaveDisplayValue(mockTreeData.urgency); }); it("should not have any accessibility violations", async () => { @@ -489,19 +488,85 @@ describe("remove feature button", () => { `{"type":"FeatureCollection","features":[]}` ); }); - // click remove - feature is removed - // no map icon }); describe("payload generation", () => { - test.todo("a submitted payload contains a GeoJSON feature collection"); - // check payload contains GeoJSON feature collection - test.todo( - "the feature collection contains all geospatial data inputted by the user", - ); - // feature collection matches the mocked data - test.todo( - "each feature's properties correspond with the details entered for that feature", - ); - // feature properties contain the answers to inputs + it("a submitted payload contains a GeoJSON feature collection", async () => { + const handleSubmit = vi.fn(); + const { getByTestId, user } = setup( + + ); + + const map = getByTestId("map-and-label-map"); + + addFeaturesToMap(map, [point1]); + + const firstTabPanel = getByTestId("vertical-tabpanel-0"); + + expect(firstTabPanel).toBeVisible(); + + await fillOutForm(user); + + await clickContinue(user); + + await checkErrorMessagesEmpty(); + expect(handleSubmit).toHaveBeenCalled(); + const output = handleSubmit.mock.calls[0][0].data.MockFn.type; + + expect(output).toEqual("FeatureCollection"); + }); + + it("the feature collection contains all geospatial data inputted by the user", async () => { + const handleSubmit = vi.fn(); + const { getByTestId, user } = setup( + + ); + + const map = getByTestId("map-and-label-map"); + + addFeaturesToMap(map, [point1]); + + const firstTabPanel = getByTestId("vertical-tabpanel-0"); + + expect(firstTabPanel).toBeVisible(); + + await fillOutForm(user); + + await clickContinue(user); + + await checkErrorMessagesEmpty(); + expect(handleSubmit).toHaveBeenCalled(); + const output = + handleSubmit.mock.calls[0][0].data.MockFn.features[0].geometry + .coordinates; + + expect(output[0]).toEqual(point1.geometry.coordinates[0]); + expect(output[1]).toEqual(point1.geometry.coordinates[1]); + }); + + it("each feature's properties correspond with the details entered for that feature", async () => { + const handleSubmit = vi.fn(); + const { getByTestId, user } = setup( + + ); + + const map = getByTestId("map-and-label-map"); + + addFeaturesToMap(map, [point1]); + + const firstTabPanel = getByTestId("vertical-tabpanel-0"); + + expect(firstTabPanel).toBeVisible(); + + await fillOutForm(user); + + await clickContinue(user); + + await checkErrorMessagesEmpty(); + expect(handleSubmit).toHaveBeenCalled(); + const output = + handleSubmit.mock.calls[0][0].data.MockFn.features[0].properties; + + expect(output).toEqual(mockTreeData); + }); }); 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 a67af1c009..16c3737b3c 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 @@ -1,6 +1,15 @@ -export const mockTreeData = { +export type TreeData = { + species: string; + work: string; + justification: string; + urgency: "low" | "moderate" | "high" | "urgenct"; + label: string; +}; + +export const mockTreeData: TreeData = { species: "Larch", work: "Chopping it down", justification: "Cause I can", - urgency: "Low", + urgency: "low", + label: "1", }; 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 new file mode 100644 index 0000000000..6395d5453b --- /dev/null +++ b/editor.planx.uk/src/@planx/components/MapAndLabel/test/mocks/mockPayload.tsx @@ -0,0 +1,21 @@ +import { FeatureCollection } from "geojson"; +import { mockTreeData } from "./GenericValues"; +export type MockPayload = { data: { MockFn: FeatureCollection } }; + +export const mockSingleFeaturePayload: MockPayload = { + data: { + MockFn: { + features: [ + { + geometry: { + coordinates: [-3.685929607119201, 57.15301433687542], + type: "Point", + }, + properties: { mockTreeData }, + type: "Feature", + }, + ], + type: "FeatureCollection", + }, + }, +};