diff options
Diffstat (limited to 'widget/tests/test_contextmenu_by_mouse_on_unix.html')
-rw-r--r-- | widget/tests/test_contextmenu_by_mouse_on_unix.html | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/widget/tests/test_contextmenu_by_mouse_on_unix.html b/widget/tests/test_contextmenu_by_mouse_on_unix.html new file mode 100644 index 0000000000..2b1f643dfc --- /dev/null +++ b/widget/tests/test_contextmenu_by_mouse_on_unix.html @@ -0,0 +1,105 @@ +<!DOCTYPE html> +<html> +<head> +<title>Test to fire contextmenu event by widget level</title> +<script src="/tests/SimpleTest/EventUtils.js"></script> +<script src="/tests/SimpleTest/SimpleTest.js"></script> +<script src="/tests/SimpleTest/SpecialPowers.js"></script> +<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"> +<style> +#target { + width: 100px; + height: 100px; + background-color: blue; +} +</style> +<script> +"use strict"; +add_task(async function test_fire_contextmenu_by_mousedown() { + await SpecialPowers.pushPrefEnv({ + set: [["ui.context_menus.after_mouseup", false]], + }); + await SimpleTest.promiseFocus(); + + // contextmenu event is fired by mouse down. + await process_contextmenu_event({ isMousedown: true, preventEvent: false }); + // contextmenu event is fired by mouse down even if mouse handler calls preventDefault. + await process_contextmenu_event({ isMousedown: true, preventEvent: true }); +}); + +add_task(async function test_fire_contextmenu_by_mouseup() { + await SpecialPowers.pushPrefEnv({ + set: [["ui.context_menus.after_mouseup", true]], + }); + await SimpleTest.promiseFocus(); + + // contextmenu event is fired by mouse up. + await process_contextmenu_event({ isMousedown: false, preventEvent: false }); + // contextmenu event is fired by mouse up even if mouse handler calls preventDefault. + await process_contextmenu_event({ isMousedown: false, preventEvent: true }); +}); + +async function process_contextmenu_event({ isMousedown, preventEvent }) { + await SpecialPowers.contentTransformsReceived(window); + + const target = document.getElementById("target"); + + let count = 0; + + const promise = new Promise(resolve => { + target.addEventListener("mousedown", e => { + is(e.buttons, 2, "The right button down should be fired"); + is(count++, 0, "The first event is mousedown"); + if (isMousedown && preventEvent) { + e.preventDefault(); + } + }, { once: true }); + + if (isMousedown) { + target.addEventListener("contextmenu", e => { + is(count++, 1, "The second event is contextmenu"); + e.preventDefault(); + }, { once: true }); + target.addEventListener("mouseup", e => { + is(count++, 2, "The third event is mouseup"); + resolve(); + }, { once: true} ); + } else { + target.addEventListener("mouseup", e => { + is(count++, 1, "The second event is mouseup"); + if (preventEvent) { + e.preventDefault(); + } + }, { once: true }); + target.addEventListener("contextmenu", e => { + is(count++, 2, "The third event is contextmenu"); + e.preventDefault(); + resolve(); + }, { once: true }); + } + }); + + synthesizeNativeMouseEvent({ + type: "mousedown", + target, + offsetX: 10, + offsetY: 10, + button: 2, + }); + + synthesizeNativeMouseEvent({ + type: "mouseup", + target, + offsetX: 10, + offsetY: 10, + button: 2, + }); + + await promise; +} +</script> +</head> +<body> +<div id="target"></div> +</body> +</html> |