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.
230 lines
6.4 KiB
230 lines
6.4 KiB
5 years ago
|
import { render, cleanup } from "@testing-library/vue";
|
||
|
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 = {
|
||
|
mouseover: eventsHandler,
|
||
|
mousemove: eventsHandler,
|
||
|
mousedown: eventsHandler,
|
||
|
focus: eventsHandler,
|
||
|
mouseup: eventsHandler,
|
||
|
click: eventsHandler
|
||
|
};
|
||
|
|
||
|
const { getByTestId } = render({
|
||
|
render: function(h) {
|
||
|
return h(
|
||
|
"select",
|
||
|
{
|
||
|
attrs: {
|
||
|
"data-testid": "element",
|
||
|
...(multiple && { multiple: true })
|
||
|
},
|
||
|
on: eventHandlers
|
||
|
},
|
||
|
[
|
||
|
h("option", { attrs: { value: "1" } }, "1"),
|
||
|
h("option", { attrs: { value: "2" } }, "2"),
|
||
|
h("option", { attrs: { value: "3" } }, "3")
|
||
|
]
|
||
|
);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
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", // Focus event isn't being emitted?
|
||
|
"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 = {
|
||
|
mouseover: eventsHandler,
|
||
|
mousemove: eventsHandler,
|
||
|
mousedown: eventsHandler,
|
||
|
focus: eventsHandler,
|
||
|
mouseup: eventsHandler,
|
||
|
click: eventsHandler
|
||
|
};
|
||
|
|
||
|
const { getByTestId } = render({
|
||
|
render: function(h) {
|
||
|
return h(
|
||
|
"select",
|
||
|
{
|
||
|
attrs: {
|
||
|
"data-testid": "element"
|
||
|
}
|
||
|
},
|
||
|
[
|
||
|
h("option", { attrs: { value: "1" }, on: eventHandlers }, "1"),
|
||
|
h("option", { attrs: { value: "2" }, on: eventHandlers }, "2"),
|
||
|
h("option", { attrs: { value: "3" }, on: eventHandlers }, "3")
|
||
|
]
|
||
|
);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
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 = {
|
||
|
mouseover: eventsHandler,
|
||
|
mousemove: eventsHandler,
|
||
|
mousedown: eventsHandler,
|
||
|
focus: eventsHandler,
|
||
|
mouseup: eventsHandler,
|
||
|
click: eventsHandler
|
||
|
};
|
||
|
|
||
|
const { getByTestId } = render({
|
||
|
render: function(h) {
|
||
|
return h(
|
||
|
"select",
|
||
|
{
|
||
|
attrs: {
|
||
|
"data-testid": "element",
|
||
|
multiple: true
|
||
|
}
|
||
|
},
|
||
|
[
|
||
|
h("option", { attrs: { value: "1" }, on: eventHandlers }, "1"),
|
||
|
h("option", { attrs: { value: "2" }, on: eventHandlers }, "2"),
|
||
|
h("option", { attrs: { value: "3" }, on: eventHandlers }, "3")
|
||
|
]
|
||
|
);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
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 { getByTestId } = render({
|
||
|
template: `
|
||
|
<form>
|
||
|
<select data-testid="element" multiple>
|
||
|
<option value="1" data-testid="val1">1</option>
|
||
|
<option value="2" data-testid="val2">2</option>
|
||
|
<option value="3" data-testid="val3">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 { getByTestId } = render({
|
||
|
template: `
|
||
|
<form>
|
||
|
<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("sets the selected prop on the selected OPTION using nested SELECT", () => {
|
||
|
const { getByTestId } = render({
|
||
|
template: `
|
||
|
<form>
|
||
|
<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);
|
||
|
});
|
||
|
});
|