Skip to content

Commit

Permalink
refactor: new test for label bug and naming refinement
Browse files Browse the repository at this point in the history
  • Loading branch information
RODO94 committed Oct 22, 2024
1 parent 407e57e commit 920ad9d
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@ export const MapAndLabelProvider: React.FC<MapAndLabelProviderProps> = (
const mergedProperties = {
...feature.properties,
...values.schemaData[i],
label: `${i + 1}`,
};
feature["properties"] = mergedProperties;
geojson.features.push(feature);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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;
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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 = {
Expand All @@ -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,
};
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ export const mockSingleFeaturePayload: MockPayload = {
},
};

export const previousMockDoubleFeatureData: MockPayload = {
export const mockDoubleFeaturePayload: MockPayload = {
data: {
MockFn: {
features: [
Expand All @@ -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,
};
Original file line number Diff line number Diff line change
Expand Up @@ -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")) {
Expand Down Expand Up @@ -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();
});
});

Expand All @@ -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(
<MapAndLabel {...previousDoubleDataProps} handleSubmit={handleSubmit} />,
);

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");
});
});

0 comments on commit 920ad9d

Please sign in to comment.