Skip to content

Commit

Permalink
♻️🧪 Refactor time_input_test's querySelector/querySelectorAll with sa…
Browse files Browse the repository at this point in the history
…feQuerySelector/safeQuerySelectorAll to ensure element existence

- This change prevents tests from passing with unexpected null elements, enhancing test reliability and catching potential issues earlier.

Closes Hacker0x01#5038
  • Loading branch information
Balaji Sridharan committed Aug 19, 2024
1 parent 7daa8a8 commit f6a4c8d
Showing 1 changed file with 18 additions and 17 deletions.
35 changes: 18 additions & 17 deletions src/test/time_input_test.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import DatePicker from "../index";
import InputTimeComponent from "../input_time";

import CustomTimeInput from "./helper_components/custom_time_input";
import { safeQuerySelector } from "./test_utils";

describe("timeInput", () => {
afterEach(() => {
Expand All @@ -30,40 +31,40 @@ describe("timeInput", () => {
it("should trigger onChange event", () => {
const onChangeSpy = jest.fn();
const { container } = render(<InputTimeComponent onChange={onChangeSpy} />);
const input = container.querySelector("input");
fireEvent.change(input ?? new HTMLElement(), {
const input = safeQuerySelector<HTMLInputElement>(container, "input");
fireEvent.change(input, {
target: { value: "13:00" },
});
expect(input?.value).toEqual("13:00");
expect(input.value).toEqual("13:00");
});

it("should retain the focus on onChange event", () => {
const onChangeSpy = jest.fn();
const { container } = render(
<DatePicker showTimeInput onChange={onChangeSpy} />,
);
const input = container.querySelector("input");
const input = safeQuerySelector<HTMLInputElement>(container, "input");

act(() => {
input?.focus();
});
expect(document.activeElement).toBe(input);

fireEvent.change(input ?? new HTMLElement(), {
fireEvent.change(input, {
target: { value: "13:00" },
});

expect(input?.value).toEqual("13:00");
expect(input.value).toEqual("13:00");
expect(document.activeElement).toBe(input);
});

it("should trigger onChange event and set the value as last valid timeString if empty string is passed as time input value", () => {
const { container } = render(
<InputTimeComponent timeString="13:00" onChange={() => {}} />,
);
const input = container.querySelector("input");
fireEvent.change(input ?? new HTMLElement(), { target: { value: "" } });
expect(input?.value).toEqual("13:00");
const input = safeQuerySelector<HTMLInputElement>(container, "input");
fireEvent.change(input, { target: { value: "" } });
expect(input.value).toEqual("13:00");
});

it("should trigger onChange event on a custom time input without using the last valid timeString", () => {
Expand All @@ -79,8 +80,8 @@ describe("timeInput", () => {
);

const newTime = "14:00";
const input = container.querySelector("input");
fireEvent.change(input ?? new HTMLElement(), {
const input = safeQuerySelector<HTMLInputElement>(container, "input");
fireEvent.change(input, {
target: { value: newTime },
});

Expand All @@ -104,8 +105,8 @@ describe("timeInput", () => {
);

const newTime = "14:00";
const input = container.querySelector("input");
fireEvent.change(input ?? new HTMLElement(), {
const input = safeQuerySelector<HTMLInputElement>(container, "input");
fireEvent.change(input, {
target: { value: newTime },
});

Expand All @@ -121,8 +122,8 @@ describe("timeInput", () => {
);

const newTime = "13:00";
const input = container.querySelector("input");
fireEvent.change(input ?? new HTMLElement(), {
const input = safeQuerySelector<HTMLInputElement>(container, "input");
fireEvent.change(input, {
target: { value: newTime },
});

Expand All @@ -146,8 +147,8 @@ describe("timeInput", () => {
);

const newTime = "13:00";
const input = container.querySelector("input");
fireEvent.change(input ?? new HTMLElement(), {
const input = safeQuerySelector<HTMLInputElement>(container, "input");
fireEvent.change(input, {
target: { value: newTime },
});

Expand Down

0 comments on commit f6a4c8d

Please sign in to comment.