You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
252 lines
6.7 KiB
252 lines
6.7 KiB
import React from "react";
|
|
import { render, cleanup, fireEvent } from "@testing-library/react";
|
|
import "@testing-library/jest-dom/extend-expect";
|
|
import userEvent from "../../src";
|
|
|
|
afterEach(cleanup);
|
|
|
|
describe("userEvent.selectOptions", () => {
|
|
it.each(["select", "select multiple"])(
|
|
"should fire the correct events for <%s>",
|
|
type => {
|
|
const events = [];
|
|
const eventsHandler = jest.fn(evt => events.push(evt.type));
|
|
const multiple = type === "select multiple";
|
|
const eventHandlers = {
|
|
onMouseOver: eventsHandler,
|
|
onMouseMove: eventsHandler,
|
|
onMouseDown: eventsHandler,
|
|
onFocus: eventsHandler,
|
|
onMouseUp: eventsHandler,
|
|
onClick: eventsHandler
|
|
};
|
|
|
|
const { getByTestId } = render(
|
|
<select {...{ ...eventHandlers, multiple }} data-testid="element">
|
|
<option value="1">1</option>
|
|
<option value="2">2</option>
|
|
<option value="3">3</option>
|
|
</select>
|
|
);
|
|
|
|
userEvent.selectOptions(getByTestId("element"), "1");
|
|
|
|
expect(events).toEqual([
|
|
"mouseover",
|
|
"mousemove",
|
|
"mousedown",
|
|
"focus",
|
|
"mouseup",
|
|
"click",
|
|
"mouseover", // The events repeat because we click on the child OPTION too
|
|
"mousemove", // But these specifically are the events bubbling up to the <select>
|
|
"mousedown",
|
|
"focus",
|
|
"mouseup",
|
|
"click"
|
|
]);
|
|
}
|
|
);
|
|
|
|
it("should fire the correct events on selected OPTION child with <select>", () => {
|
|
function handleEvent(evt) {
|
|
const optValue = parseInt(evt.target.value);
|
|
events[optValue] = [...(events[optValue] || []), evt.type];
|
|
}
|
|
|
|
const events = [];
|
|
const eventsHandler = jest.fn(handleEvent);
|
|
const eventHandlers = {
|
|
onMouseOver: eventsHandler,
|
|
onMouseMove: eventsHandler,
|
|
onMouseDown: eventsHandler,
|
|
onFocus: eventsHandler,
|
|
onMouseUp: eventsHandler,
|
|
onClick: eventsHandler
|
|
};
|
|
|
|
const { getByTestId } = render(
|
|
<select data-testid="element">
|
|
<option {...eventHandlers} value="1">
|
|
1
|
|
</option>
|
|
<option {...eventHandlers} value="2">
|
|
2
|
|
</option>
|
|
<option {...eventHandlers} value="3">
|
|
3
|
|
</option>
|
|
</select>
|
|
);
|
|
|
|
userEvent.selectOptions(getByTestId("element"), ["2"]);
|
|
|
|
expect(events[1]).toBe(undefined);
|
|
expect(events[3]).toBe(undefined);
|
|
expect(events[2]).toEqual([
|
|
"mouseover",
|
|
"mousemove",
|
|
"mousedown",
|
|
"focus",
|
|
"mouseup",
|
|
"click"
|
|
]);
|
|
});
|
|
|
|
it("should fire the correct events on selected OPTION children with <select multiple>", () => {
|
|
function handleEvent(evt) {
|
|
const optValue = parseInt(evt.target.value);
|
|
events[optValue] = [...(events[optValue] || []), evt.type];
|
|
}
|
|
|
|
const events = [];
|
|
const eventsHandler = jest.fn(handleEvent);
|
|
const eventHandlers = {
|
|
onMouseOver: eventsHandler,
|
|
onMouseMove: eventsHandler,
|
|
onMouseDown: eventsHandler,
|
|
onFocus: eventsHandler,
|
|
onMouseUp: eventsHandler,
|
|
onClick: eventsHandler
|
|
};
|
|
|
|
const { getByTestId } = render(
|
|
<select multiple data-testid="element">
|
|
<option {...eventHandlers} value="1">
|
|
1
|
|
</option>
|
|
<option {...eventHandlers} value="2">
|
|
2
|
|
</option>
|
|
<option {...eventHandlers} value="3">
|
|
3
|
|
</option>
|
|
</select>
|
|
);
|
|
|
|
userEvent.selectOptions(getByTestId("element"), ["1", "3"]);
|
|
|
|
expect(events[2]).toBe(undefined);
|
|
expect(events[1]).toEqual([
|
|
"mouseover",
|
|
"mousemove",
|
|
"mousedown",
|
|
"focus",
|
|
"mouseup",
|
|
"click"
|
|
]);
|
|
|
|
expect(events[3]).toEqual([
|
|
"mouseover",
|
|
"mousemove",
|
|
"mousedown",
|
|
"focus",
|
|
"mouseup",
|
|
"click"
|
|
]);
|
|
});
|
|
|
|
it("sets the selected prop on the selected OPTION", () => {
|
|
const onSubmit = jest.fn();
|
|
|
|
const { getByTestId } = render(
|
|
<form onSubmit={onSubmit}>
|
|
<select multiple data-testid="element">
|
|
<option data-testid="val1" value="1">
|
|
1
|
|
</option>
|
|
<option data-testid="val2" value="2">
|
|
2
|
|
</option>
|
|
<option data-testid="val3" value="3">
|
|
3
|
|
</option>
|
|
</select>
|
|
</form>
|
|
);
|
|
|
|
userEvent.selectOptions(getByTestId("element"), ["1", "3"]);
|
|
|
|
expect(getByTestId("val1").selected).toBe(true);
|
|
expect(getByTestId("val2").selected).toBe(false);
|
|
expect(getByTestId("val3").selected).toBe(true);
|
|
});
|
|
|
|
it("sets the selected prop on the selected OPTION using htmlFor", () => {
|
|
const onSubmit = jest.fn();
|
|
|
|
const { getByTestId } = render(
|
|
<form onSubmit={onSubmit}>
|
|
<label htmlFor="select">Example Select</label>
|
|
<select id="select" data-testid="element">
|
|
<option data-testid="val1" value="1">
|
|
1
|
|
</option>
|
|
<option data-testid="val2" value="2">
|
|
2
|
|
</option>
|
|
<option data-testid="val3" value="3">
|
|
3
|
|
</option>
|
|
</select>
|
|
</form>
|
|
);
|
|
|
|
userEvent.selectOptions(getByTestId("element"), "2");
|
|
|
|
expect(getByTestId("val1").selected).toBe(false);
|
|
expect(getByTestId("val2").selected).toBe(true);
|
|
expect(getByTestId("val3").selected).toBe(false);
|
|
});
|
|
|
|
it("should fire onChange event on a SELECT element", () => {
|
|
const onChangeHandler = jest.fn();
|
|
|
|
const { getByTestId } = render(
|
|
<select data-testid="element" onChange={onChangeHandler}>
|
|
<option data-testid="val1" value="1">
|
|
1
|
|
</option>
|
|
<option data-testid="val2" value="2">
|
|
2
|
|
</option>
|
|
<option data-testid="val3" value="3">
|
|
3
|
|
</option>
|
|
</select>
|
|
);
|
|
|
|
userEvent.selectOptions(getByTestId("element"), "2");
|
|
|
|
expect(onChangeHandler).toBeCalled();
|
|
});
|
|
|
|
it("sets the selected prop on the selected OPTION using nested SELECT", () => {
|
|
const onSubmit = jest.fn();
|
|
|
|
const { getByTestId } = render(
|
|
<form onSubmit={onSubmit}>
|
|
<label>
|
|
Example Select
|
|
<select data-testid="element">
|
|
<option data-testid="val1" value="1">
|
|
1
|
|
</option>
|
|
<option data-testid="val2" value="2">
|
|
2
|
|
</option>
|
|
<option data-testid="val3" value="3">
|
|
3
|
|
</option>
|
|
</select>
|
|
</label>
|
|
</form>
|
|
);
|
|
|
|
userEvent.selectOptions(getByTestId("element"), "2");
|
|
|
|
expect(getByTestId("val1").selected).toBe(false);
|
|
expect(getByTestId("val2").selected).toBe(true);
|
|
expect(getByTestId("val3").selected).toBe(false);
|
|
});
|
|
});
|
|
|