blob: 1b9556a1064078301f01825ad481e977851751bd [file] [log] [blame]
<!DOCTYPE html>
<html>
<head>
<script src="../../resources/js-test-pre.js"></script>
</head>
<body>
<p id="description"></p>
<div id="console"></div>
<form id=f action="interactive-validation-prevented.html">
<input type=hidden name=submitted value=true>
<input name=i0 required id=i0 value="abc">
<input name=i1 required id=i1 style="display:none">
<input name=i2 required id=i2>
<input type=submit id=s>
</form>
<script>
description('Test if an invalid control prevents interactive form submission, and the first invalid focusable control gets focus.');
function startOrVerify() {
var query = window.location.search;
if (query.indexOf('submitted=true') != -1) {
testFailed('The form should not be submitted.');
} else {
// Force to render the form.
document.getElementById("f").offsetWidth;
// HTMLFormElement::submit() skips validation. Use the submit button.
document.getElementById('s').click();
testPassed('The form was not submitted');
shouldBe('document.activeElement', 'document.getElementById("i2")');
document.getElementById('i2').value = 'foo'; // Close the invalidation bubble.
debug('TEST COMPLETE');
}
if (window.testRunner)
testRunner.notifyDone();
}
if (window.testRunner)
testRunner.waitUntilDone();
window.onload = startOrVerify;
</script>
</body>
</html>