import React from "react"; import { render, waitFor, fireEvent } from "@testing-library/react"; import "@testing-library/jest-dom/extend-expect"; import { DeploymentScaleDialog } from "./deployment-scale-dialog"; jest.mock("../../api/endpoints"); import { deploymentApi } from "../../api/endpoints"; const dummyDeployment = { apiVersion: "v1", kind: "dummy", metadata: { uid: "dummy", name: "dummy", creationTimestamp: "dummy", resourceVersion: "dummy", selfLink: "link", }, selfLink: "link", spec: { replicas: 1, selector: { matchLabels: { dummy: "label" } }, template: { metadata: { labels: { dummy: "label" }, }, spec: { containers: [{ name: "dummy", image: "dummy", resources: { requests: { cpu: "1", memory: "10Mi", }, }, terminationMessagePath: "dummy", terminationMessagePolicy: "dummy", imagePullPolicy: "dummy", }], restartPolicy: "dummy", terminationGracePeriodSeconds: 10, dnsPolicy: "dummy", serviceAccountName: "dummy", serviceAccount: "dummy", securityContext: {}, schedulerName: "dummy", }, }, strategy: { type: "dummy", rollingUpdate: { maxUnavailable: 1, maxSurge: 10, }, }, }, status: { observedGeneration: 1, replicas: 1, updatedReplicas: 1, readyReplicas: 1, conditions: [{ type: "dummy", status: "dummy", lastUpdateTime: "dummy", lastTransitionTime: "dummy", reason: "dummy", message: "dummy", }], }, getConditions: jest.fn(), getConditionsText: jest.fn(), getReplicas: jest.fn(), getSelectors: jest.fn(), getTemplateLabels: jest.fn(), getAffinity: jest.fn(), getTolerations: jest.fn(), getNodeSelectors: jest.fn(), getAffinityNumber: jest.fn(), getId: jest.fn(), getResourceVersion: jest.fn(), getName: jest.fn(), getNs: jest.fn(), getAge: jest.fn(), getFinalizers: jest.fn(), getLabels: jest.fn(), getAnnotations: jest.fn(), getOwnerRefs: jest.fn(), getSearchFields: jest.fn(), toPlainObject: jest.fn(), update: jest.fn(), delete: jest.fn(), }; describe("", () => { it("renders w/o errors", () => { const { container } = render(); expect(container).toBeInstanceOf(HTMLElement); }); it("inits with a dummy deployment with mocked current/desired scale", async () => { // mock deploymentApi.getReplicas() which will be called // when rendered. const initReplicas = 3; deploymentApi.getReplicas = jest.fn().mockImplementationOnce(async () => initReplicas); const { getByTestId } = render(); DeploymentScaleDialog.open(dummyDeployment); // we need to wait for the DeploymentScaleDialog to show up // because there is an in which renders null at start. await waitFor(async () => { const [currentScale, desiredScale] = await Promise.all([ getByTestId("current-scale"), getByTestId("desired-scale"), ]); expect(currentScale).toHaveTextContent(`${initReplicas}`); expect(desiredScale).toHaveTextContent(`${initReplicas}`); }); }); it("changes the desired scale when clicking the icon buttons +/-", async () => { const initReplicas = 1; deploymentApi.getReplicas = jest.fn().mockImplementationOnce(async () => initReplicas); const component = render(); DeploymentScaleDialog.open(dummyDeployment); await waitFor(async () => { expect(await component.getByTestId("desired-scale")).toHaveTextContent(`${initReplicas}`); expect(await component.getByTestId("current-scale")).toHaveTextContent(`${initReplicas}`); expect((await component.baseElement.querySelector("input").value)).toBe(`${initReplicas}`); }); const up = await component.getByTestId("desired-replicas-up"); const down = await component.getByTestId("desired-replicas-down"); fireEvent.click(up); expect(await component.getByTestId("desired-scale")).toHaveTextContent(`${initReplicas + 1}`); expect(await component.getByTestId("current-scale")).toHaveTextContent(`${initReplicas}`); expect((await component.baseElement.querySelector("input").value)).toBe(`${initReplicas + 1}`); fireEvent.click(down); expect(await component.getByTestId("desired-scale")).toHaveTextContent(`${initReplicas}`); expect(await component.getByTestId("current-scale")).toHaveTextContent(`${initReplicas}`); expect((await component.baseElement.querySelector("input").value)).toBe(`${initReplicas}`); // edge case, desiredScale must = 0 let times = 10; for (let i = 0; i < times; i++) { fireEvent.click(down); } expect(await component.getByTestId("desired-scale")).toHaveTextContent("0"); expect((await component.baseElement.querySelector("input").value)).toBe("0"); // edge case, desiredScale must = 100 scaleMax (100) times = 120; for (let i = 0; i < times; i++) { fireEvent.click(up); } expect(await component.getByTestId("desired-scale")).toHaveTextContent("100"); expect((component.baseElement.querySelector("input").value)).toBe("100"); expect(await component.getByTestId("warning")) .toHaveTextContent("High number of replicas may cause cluster performance issues"); }); });