Skip to content

Commit

Permalink
mousemove_prevent_default_action.tentative.html unnecessarily listens…
Browse files Browse the repository at this point in the history
… for selectionchange events when asserting dragstart is fired (#42471)

Since the two subtests in
mousemove_prevent_default_action.tentative.html assert that either a
selectionchange or a dragstart event is fired on a cancelled
mousemove event by comparing a set of logged events (obtained from
respective event listeners) against a static set of expected events, it
is important to not listen for events a subtest does not care about, as
that may produce an unnecessary test failure.

For example, we should not care whether or not a selectionchange event
was fired in the second subtest, since we only want to assert that a
dragstart event fires from a cancelled mousemove event on a draggable
element. These two events are not mutually exclusive in any manner
relevant to this WPT.

Thus, this commit makes sure we follow the invariant of listening only
for selectionchange events, and not also dragstart events, in the first
subtest, and similarly listening only for dragstart events, and not also
selectionchange events, in the second subtest.

Signed-off-by: Abrar Rahman Protyasha <[email protected]>
  • Loading branch information
aprotyas authored Oct 11, 2023
1 parent d13f0b1 commit 08b5fe9
Showing 1 changed file with 8 additions and 5 deletions.
13 changes: 8 additions & 5 deletions uievents/mouse/mousemove_prevent_default_action.tentative.html
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,13 @@

// Deliberately avoiding mouseup here because the last selectionchange
// may be fired before or after the mouseup.
["mousedown", "mousemove", "selectionchange", "dragstart"].forEach(ename => {
document.addEventListener(ename, logEvents);
});
document.addEventListener("mousedown", logEvents);
document.addEventListener("mousemove", logEvents);
document.addEventListener("mousemove", e => e.preventDefault());

promise_test(async () => {
promise_test(async test => {
document.addEventListener("selectionchange", logEvents);
test.add_cleanup(() => { document.removeEventListener("selectionchange", logEvents); });
event_log = [];

const a = document.getElementById("a");
Expand Down Expand Up @@ -60,7 +61,9 @@
"received events");
}, "selectionchange event firing when mousemove event is prevented");

promise_test(async () => {
promise_test(async test => {
document.addEventListener("dragstart", logEvents);
test.add_cleanup(() => { document.removeEventListener("dragstart", logEvents); });
event_log = [];

const b = document.getElementById("b");
Expand Down

0 comments on commit 08b5fe9

Please sign in to comment.