mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-12-11 16:32:59 +00:00
Bug 1550467 - Add a test for event untransforms. r=botond
This exercises the transforms propagated in bug 1530661, which is WebRender-specific (because the events only have the target layers id set on them if WR is enabled). Differential Revision: https://phabricator.services.mozilla.com/D32189 --HG-- extra : moz-landing-system : lando
This commit is contained in:
parent
ff26c575c6
commit
37ebd39e5c
@ -4,12 +4,21 @@ add_task(async function test_main() {
|
||||
return chromeURL.replace("chrome://mochitests/content/", "http://mochi.test:8888/");
|
||||
}
|
||||
|
||||
var utils = SpecialPowers.getDOMWindowUtils(window);
|
||||
var isWebRender = (utils.layerManagerType == "WebRender");
|
||||
|
||||
// Each of these URLs will get opened in a new top-level browser window that
|
||||
// is fission-enabled.
|
||||
var test_urls = [
|
||||
httpURL("helper_fission_basic.html", null),
|
||||
// add additional tests here
|
||||
];
|
||||
if (isWebRender) {
|
||||
test_urls = test_urls.concat([
|
||||
httpURL("helper_fission_transforms.html", null),
|
||||
// add additional WebRender-specific tests here
|
||||
]);
|
||||
}
|
||||
|
||||
let fissionWindow = await BrowserTestUtils.openNewBrowserWindow({fission: true});
|
||||
|
||||
|
85
gfx/layers/apz/test/mochitest/helper_fission_transforms.html
Normal file
85
gfx/layers/apz/test/mochitest/helper_fission_transforms.html
Normal file
@ -0,0 +1,85 @@
|
||||
<!DOCTYPE HTML>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>Test to ensure events get untransformed properly for OOP iframes</title>
|
||||
<script src="/tests/SimpleTest/SimpleTest.js"></script>
|
||||
<script src="/tests/SimpleTest/paint_listener.js"></script>
|
||||
<script src="helper_fission_utils.js"></script>
|
||||
<script src="apz_test_utils.js"></script>
|
||||
<script src="apz_test_native_event_utils.js"></script>
|
||||
<script>
|
||||
|
||||
fission_subtest_init();
|
||||
|
||||
FissionTestHelper.startTestPromise
|
||||
.then(waitUntilApzStable)
|
||||
.then(loadOOPIFrame("testframe", "helper_fission_empty.html"))
|
||||
.then(waitUntilApzStable)
|
||||
.then(runAsyncContinuation(test))
|
||||
.then(FissionTestHelper.subtestDone, FissionTestHelper.subtestDone);
|
||||
|
||||
|
||||
let code_for_oopif_to_run = function() {
|
||||
document.addEventListener("click", function(e) {
|
||||
dump(`OOPIF got click at ${e.clientX},${e.clientY}\n`);
|
||||
let result = { x: e.clientX, y: e.clientY };
|
||||
FissionTestHelper.fireEventInEmbedder("OOPIF:ClickData", result);
|
||||
}, {once: true});
|
||||
dump("OOPIF registered click listener\n");
|
||||
return true;
|
||||
};
|
||||
|
||||
function failsafe() {
|
||||
// Catch and fail faster on the case where the click ends up not going to
|
||||
// the iframe like it should. Otherwise the test hangs until timeout which
|
||||
// is more painful.
|
||||
document.addEventListener("click", function(e) {
|
||||
dump(`${location.href} got click at ${e.clientX},${e.clientY}\n`);
|
||||
ok(false, "The OOPIF hosting page should not have gotten the click");
|
||||
setTimeout(FissionTestHelper.subtestDone, 0);
|
||||
}, {once: true});
|
||||
}
|
||||
|
||||
async function* test() {
|
||||
let iframeElement = document.getElementById("testframe");
|
||||
|
||||
let iframeResponse = await FissionTestHelper.sendToOopif(iframeElement, code_for_oopif_to_run.toSource() + "()");
|
||||
dump("OOPIF response: " + JSON.stringify(iframeResponse) + "\n");
|
||||
ok(iframeResponse, "code_for_oopif_to_run successfully installed");
|
||||
|
||||
iframePromise = promiseOneEvent("OOPIF:ClickData", null);
|
||||
synthesizeNativeClick(document.body, 200, 200, function() {
|
||||
dump("Finished synthesizing click, waiting for OOPIF message...\n");
|
||||
});
|
||||
iframeResponse = await iframePromise;
|
||||
dump("OOPIF response: " + JSON.stringify(iframeResponse.data) + "\n");
|
||||
|
||||
let expected_coord = 200 / Math.sqrt(2); // because the iframe is rotated 45 deg
|
||||
ok(Math.abs(iframeResponse.data.x - expected_coord) < 3,
|
||||
`x-coord ${iframeResponse.data.x} landed near expected value ${expected_coord}`);
|
||||
ok(Math.abs(iframeResponse.data.y - expected_coord) < 3,
|
||||
`y-coord ${iframeResponse.data.y} landed near expected value ${expected_coord}`);
|
||||
}
|
||||
|
||||
</script>
|
||||
<style>
|
||||
body, html {
|
||||
margin: 0;
|
||||
}
|
||||
div {
|
||||
transform-origin: top left;
|
||||
transform: translateX(200px) rotate(45deg);
|
||||
width: 500px;
|
||||
}
|
||||
iframe {
|
||||
width: 400px;
|
||||
height: 300px;
|
||||
border: solid 1px black;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body onload="failsafe()">
|
||||
<div><iframe id="testframe"></iframe></div>
|
||||
</body>
|
||||
</html>
|
Loading…
Reference in New Issue
Block a user