<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
<html lang="en">
<head>
<style>
div { width: 60px; text-align: center;
position: relative; }
div#a { background: green; }
div#b { background: yellow; }
div#a:hover { background: red; }
div#b:hover { background: green; }
span#c:hover { color: red; }
</style>
<script src="../../resources/js-test.js"></script>
</head>
<body onload="runtest()">
<p><b>BUG ID:</b> <a href="http://bugs.webkit.org/show_bug.cgi?id=6821">Bugzilla bug 6821</a> Fix for 5983 will not always update hover correctly.</p>
<p>To run manually, move your mouse over the black box. You should see a green box. If you see any other color, the test fails.</p>
<script type="text/javascript">
function finish()
{
var expectedBackgroundColor = "rgb(0, 128, 0)";
// This test was failing on slower machines, so we give it more time to try to apply the hover state.
var timeSinceStartedCheckingMs = Date.now() - window.startCheckingForHoverMs;
if (timeSinceStartedCheckingMs < 200 && getComputedStyle(document.getElementById('b')).backgroundColor != expectedBackgroundColor) {
setTimeout(finish, 10);
return;
}
shouldBeEqualToString("window.getComputedStyle(document.getElementById('b'), null).backgroundColor", expectedBackgroundColor);
shouldBeEqualToString("window.getComputedStyle(document.getElementById('a'), null).backgroundColor", expectedBackgroundColor);
if (window.testRunner)
testRunner.notifyDone();
}
function hideC()
{
c.style.display = 'none';
document.body.offsetLeft;
window.startCheckingForHoverMs = Date.now();
window.setTimeout(finish, 0);
}
function hoveredC()
{
window.setTimeout(hideC, 0);
}
function runtest()
{
if (!window.testRunner)
return;
debug('Hover color before test: ' + getComputedStyle(document.getElementById("b")).backgroundColor);
testRunner.waitUntilDone();
var target = document.getElementById('target');
var x = target.offsetParent.offsetLeft + target.offsetLeft + target.offsetWidth / 2;
var y = target.offsetParent.offsetTop + target.offsetTop + target.offsetHeight / 2;
eventSender.mouseMoveTo(x, y);
}
</script>
<div id="a">
<div style="height: 20px;"></div>
<span id="c" onmouseover="hoveredC()">Hover here<br><span id="target" style="background: black;"> Wait </span></span>
</div>
<div id="b">
Only green now
</div>
<div id="console"></div>
</body>
</html>