mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
206 lines
5.2 KiB
TypeScript
206 lines
5.2 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
import React from "react";
|
|
import "@testing-library/jest-dom/extend-expect";
|
|
import type { SelectOption } from "./select";
|
|
import { Select } from "./select";
|
|
import { getDiForUnitTesting } from "../../getDiForUnitTesting";
|
|
import type { DiContainer } from "@ogre-tools/injectable";
|
|
import type { DiRender } from "../test-utils/renderFor";
|
|
import { renderFor } from "../test-utils/renderFor";
|
|
import mockFs from "mock-fs";
|
|
import directoryForUserDataInjectable from "../../../common/app-paths/directory-for-user-data/directory-for-user-data.injectable";
|
|
import rendererExtensionsInjectable from "../../../extensions/renderer-extensions.injectable";
|
|
import { computed } from "mobx";
|
|
import type { LensRendererExtension } from "../../../extensions/lens-renderer-extension";
|
|
import getConfigurationFileModelInjectable from "../../../common/get-configuration-file-model/get-configuration-file-model.injectable";
|
|
|
|
jest.mock("electron", () => ({
|
|
ipcRenderer: {
|
|
on: jest.fn(),
|
|
invoke: jest.fn(),
|
|
},
|
|
}));
|
|
|
|
describe("<Select />", () => {
|
|
let di: DiContainer;
|
|
let render: DiRender;
|
|
|
|
beforeEach(() => {
|
|
di = getDiForUnitTesting({ doGeneralOverrides: true });
|
|
render = renderFor(di);
|
|
|
|
mockFs();
|
|
|
|
di.override(directoryForUserDataInjectable, () => "some-directory-for-user-data");
|
|
di.override(rendererExtensionsInjectable, () => computed(() => [] as LensRendererExtension[]));
|
|
|
|
di.permitSideEffects(getConfigurationFileModelInjectable);
|
|
});
|
|
|
|
afterEach(() => {
|
|
mockFs.restore();
|
|
});
|
|
|
|
it("should render the select", async () => {
|
|
const options = [
|
|
{
|
|
label: "Option one label",
|
|
value: "optionOneValue",
|
|
},
|
|
{
|
|
label: "Option two label",
|
|
value: "optionTwoValue",
|
|
},
|
|
];
|
|
|
|
const onChange = jest.fn();
|
|
|
|
const { container } = render((
|
|
<Select
|
|
id="some-test-input"
|
|
onChange={onChange}
|
|
options={options}
|
|
/>
|
|
));
|
|
|
|
expect(container).toBeInstanceOf(HTMLElement);
|
|
});
|
|
|
|
it("should show selected option", async () => {
|
|
const options = [
|
|
{
|
|
label: "Option one label",
|
|
value: "optionOneValue",
|
|
},
|
|
{
|
|
label: "Option two label",
|
|
value: "optionTwoValue",
|
|
},
|
|
];
|
|
|
|
const onChange = jest.fn();
|
|
|
|
const { container } = render((
|
|
<Select
|
|
value={options[0].value}
|
|
onChange={onChange}
|
|
options={options}
|
|
/>
|
|
));
|
|
const selectedValueContainer = container.querySelector(".Select__single-value");
|
|
|
|
expect(selectedValueContainer?.textContent).toBe(options[0].label);
|
|
});
|
|
|
|
it("should reflect to change value", async () => {
|
|
const options = [
|
|
{
|
|
label: "Option one label",
|
|
value: "optionOneValue",
|
|
},
|
|
{
|
|
label: "Option two label",
|
|
value: "optionTwoValue",
|
|
},
|
|
];
|
|
|
|
const onChange = jest.fn();
|
|
|
|
const { container, rerender } = render((
|
|
<Select
|
|
value={options[0].value}
|
|
onChange={onChange}
|
|
options={options}
|
|
/>
|
|
));
|
|
const selectedValueContainer = container.querySelector(".Select__single-value");
|
|
|
|
expect(selectedValueContainer?.textContent).toBe(options[0].label);
|
|
|
|
rerender((
|
|
<Select
|
|
value={options[1].value}
|
|
onChange={onChange}
|
|
options={options}
|
|
/>
|
|
));
|
|
|
|
expect(container.querySelector(".Select__single-value")?.textContent).toBe(options[1].label);
|
|
});
|
|
|
|
it("should unselect value if null is passed as a value", async () => {
|
|
const options = [
|
|
{
|
|
label: "Option one label",
|
|
value: "optionOneValue",
|
|
},
|
|
{
|
|
label: "Option two label",
|
|
value: "optionTwoValue",
|
|
},
|
|
];
|
|
|
|
const onChange = jest.fn();
|
|
|
|
const { container, rerender } = render((
|
|
<Select
|
|
value={options[0].value}
|
|
onChange={onChange}
|
|
options={options}
|
|
/>
|
|
));
|
|
const selectedValueContainer = container.querySelector(".Select__single-value");
|
|
|
|
expect(selectedValueContainer?.textContent).toBe(options[0].label);
|
|
|
|
rerender((
|
|
<Select<string, SelectOption<string>>
|
|
value={null}
|
|
onChange={onChange}
|
|
options={options}
|
|
/>
|
|
));
|
|
|
|
expect(container.querySelector(".Select__single-value")).not.toBeInTheDocument();
|
|
});
|
|
|
|
it("should unselect value if undefined is passed as a value", async () => {
|
|
const options = [
|
|
{
|
|
label: "Option one label",
|
|
value: "optionOneValue",
|
|
},
|
|
{
|
|
label: "Option two label",
|
|
value: "optionTwoValue",
|
|
},
|
|
];
|
|
|
|
const onChange = jest.fn();
|
|
|
|
const { container, rerender } = render((
|
|
<Select
|
|
value={options[0].value}
|
|
onChange={onChange}
|
|
options={options}
|
|
/>
|
|
));
|
|
const selectedValueContainer = container.querySelector(".Select__single-value");
|
|
|
|
expect(selectedValueContainer?.textContent).toBe(options[0].label);
|
|
|
|
rerender((
|
|
<Select<string, SelectOption<string>>
|
|
value={undefined}
|
|
onChange={onChange}
|
|
options={options}
|
|
/>
|
|
));
|
|
|
|
expect(container.querySelector(".Select__single-value")).not.toBeInTheDocument();
|
|
});
|
|
});
|