123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- <!DOCTYPE HTML>
- <html>
- <!--
- https://bugzilla.mozilla.org/show_bug.cgi?id=561636
- -->
- <head>
- <title>Test for Bug 561636</title>
- <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
- <script type="application/javascript" src="/tests/SimpleTest/EventUtils.js"></script>
- <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
- </head>
- <body>
- <a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=561636">Mozilla Bug 561636</a>
- <p id="display"></p>
- <iframe style='width:50px; height: 50px;' name='t'></iframe>
- <iframe style='width:50px; height: 50px;' name='t2' id='i'></iframe>
- <div id="content">
- <form target='t' action='data:text/html,'>
- <input required>
- <input id='a' type='submit'>
- </form>
- <form target='t' action='data:text/html,'>
- <input type='checkbox' required>
- <button id='b' type='submit'></button>
- </form>
- <form target='t' action='data:text/html,'>
- <input id='c' required>
- </form>
- <form target='t' action='data:text/html,'>
- <input>
- <input id='s2' type='submit'>
- </form>
- <form target='t2' action='data:text/html,'>
- <input required>
- </form>
- </div>
- <pre id="test">
- <script type="application/javascript">
- /** Test for Bug 561636 **/
- SimpleTest.waitForExplicitFinish();
- addLoadEvent(runTest);
- function runTest()
- {
- var formSubmitted = [ false, false ];
- var invalidHandled = false;
- var os = SpecialPowers.Cc['@mozilla.org/observer-service;1']
- .getService(SpecialPowers.Ci.nsIObserverService);
- var observers = os.enumerateObservers("invalidformsubmit");
- // The following test should not be done if there is no observer for
- // "invalidformsubmit" because the form submission will not be canceled in that
- // case.
- if (!observers.hasMoreElements()) {
- SimpleTest.finish();
- return;
- }
- // Initialize
- document.forms[0].addEventListener('submit', function(aEvent) {
- aEvent.target.removeEventListener('submit', arguments.callee, false);
- formSubmitted[0] = true;
- }, false);
- document.forms[1].addEventListener('submit', function(aEvent) {
- aEvent.target.removeEventListener('submit', arguments.callee, false);
- formSubmitted[1] = true;
- }, false);
- document.forms[2].addEventListener('submit', function(aEvent) {
- aEvent.target.removeEventListener('submit', arguments.callee, false);
- formSubmitted[2] = true;
- }, false);
- document.forms[3].addEventListener('submit', function(aEvent) {
- aEvent.target.removeEventListener('submit', arguments.callee, false);
- formSubmitted[3] = true;
- ok(!formSubmitted[0], "Form 1 should not have been submitted because invalid");
- ok(!formSubmitted[1], "Form 2 should not have been submitted because invalid");
- ok(!formSubmitted[2], "Form 3 should not have been submitted because invalid");
- ok(formSubmitted[3], "Form 4 should have been submitted because valid");
- // Next test.
- document.forms[4].submit();
- }, false);
- document.forms[4].elements[0].addEventListener('invalid', function(aEvent) {
- aEvent.target.removeEventListener('invalid', arguments.callee, false);
- invalidHandled = true;
- }, false);
- document.getElementById('i').addEventListener('load', function(aEvent) {
- aEvent.target.removeEventListener('load', arguments.callee, false);
- SimpleTest.executeSoon(function () {
- ok(true, "Form 5 should have been submitted because submit() has been used even if invalid");
- ok(!invalidHandled, "Invalid event should not have been sent");
- SimpleTest.finish();
- });
- }, false);
- document.getElementById('a').click();
- document.getElementById('b').click();
- var c = document.getElementById('c');
- c.focus();
- synthesizeKey("KEY_Enter", { code: "Enter" });
- document.getElementById('s2').click();
- }
- </script>
- </pre>
- </body>
- </html>
|