blob: 4438d225779f91a3d57e8ff2c88fdf736394626b [file] [log] [blame]
<!DOCTYPE html>
<html>
<head>
<script src="../../../../resources/js-test-pre.js"></script>
<script src="resources/gesture-helpers.js"></script>
<style type="text/css">
::-webkit-scrollbar {
width: 0px;
height: 0px;
}
#bluebox {
width: 100px;
height: 100px;
background: blue;
padding: 0px;
margin: 0px;
}
#container {
width: 150px;
height: 150px;
overflow-y: scroll;
overflow-x: scroll;
}
#outerdiv {
width: 200px;
height: 200px;
overflow-y: scroll;
overflow-x: scroll;
}
td {
padding: 0px;
}
</style>
</head>
<body style="margin:0" >
<div id="outerdiv">
<table border="0" cellspacing="0px" >
<tr><td>
<div id="container">
<iframe id="touchtargetiframe" src="resources/scroll-inside-editable-iframe.html"></iframe>
</div>
</td></tr>
<tr><td>
<div id="bluebox"></div>
</td></tr>
</table>
</div>
<p id="description"></p>
<div id="console"></div>
<script type="text/javascript">
var movedbox;
var touchtarget;
var expectedGesturesTotal = 2;
var gesturesOccurred = 0;
var scrollAmountX = ['0', '0'];
var scrollAmountY = ['0', '0'];
var wheelEventsOccurred = 0;
var expectedWheelEventsOccurred = ['0', '0'];
var scrollEventsOccurred = 0;
var scrolledElement = 'movedbox'
var scrollEventsOccurred = 0;
var expectedScrollEventsOccurred = '1';
function firstGestureScroll()
{
debug("first gesture");
eventSender.gestureScrollBegin(10, 72);
eventSender.gestureScrollUpdateWithoutPropagation(0, -700);
eventSender.gestureScrollEnd(0, 0);
// Wait for layout.
checkScrollOffset();
}
function secondGestureScroll()
{
debug("second gesture");
eventSender.gestureScrollBegin(12, 40);
eventSender.gestureScrollUpdateWithoutPropagation(0, -10);
eventSender.gestureScrollUpdateWithoutPropagation(0, -50);
eventSender.gestureScrollEnd(0, 0);
// Wait for layout.
checkScrollOffset();
}
if (window.testRunner)
testRunner.waitUntilDone();
function runTest()
{
movedbox = document.getElementById("outerdiv");
touchtarget = document.getElementById("touchtargetiframe");
touchtarget.contentDocument.addEventListener("scroll", recordScroll);
touchtarget.contentDocument.body.addEventListener("mousewheel", recordWheel);
if (window.eventSender) {
description('This tests that a gesture scroll is not propagated from an ' +
'iframe to an outer div when the iframe has no remaining ' +
'scroll offset when the gesture type GestureScrollUpdateWithoutPropagation is used.');
if (checkTestDependencies() && window.eventSender.gestureScrollUpdateWithoutPropagation)
firstGestureScroll();
else
exitIfNecessary();
} else {
debug("This test requires DumpRenderTree. Gesture-scroll the page to validate the implementation.");
}
}
</script>
</body>
</html>