diff options
Diffstat (limited to 'testing/web-platform/tests/html/semantics/forms/resetting-a-form')
5 files changed, 238 insertions, 0 deletions
diff --git a/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-event.html b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-event.html new file mode 100644 index 0000000000..f7d98f7216 --- /dev/null +++ b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-event.html @@ -0,0 +1,18 @@ +<!doctype html> +<title>Test aspects of the reset event</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<div id="log"></div> +<script> + async_test((t) => { + var form = document.createElement("form") + form.onreset = t.step_func_done((e) => { + assert_true(e.bubbles) + assert_true(e.cancelable) + assert_true(e.isTrusted) + assert_equals(e.target, form) + }) + form.reset() + assert_unreached() + }) +</script> diff --git a/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form-2.html b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form-2.html new file mode 100644 index 0000000000..6ce0040c4a --- /dev/null +++ b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form-2.html @@ -0,0 +1,61 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>Resetting a form integration test</title> +<link rel="author" title="Domenic Denicola" href="mailto:d@domenic.me"> +<link rel="help" href="https://html.spec.whatwg.org/multipage/#concept-form-reset"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> + +<script> +"use strict"; + +test(() => { + + const form = document.createElement("form"); + const text = document.createElement("input"); + text.type = "text"; + const checkbox = document.createElement("input"); + checkbox.type = "checkbox"; + const select = document.createElement("select"); + select.multiple = true; + const option = document.createElement("option"); + option.value = "option"; + const textarea = document.createElement("textarea"); + + form.appendChild(text); + form.appendChild(checkbox); + form.appendChild(textarea); + form.appendChild(select); + select.appendChild(option); + + text.defaultValue = "text default"; + checkbox.defaultChecked = true; + option.defaultSelected = true; + textarea.defaultValue = "textarea default"; + + text.value = "text new value"; + checkbox.checked = false; + option.selected = false; + textarea.value = "textarea new value"; + + form.reset(); + + assert_equals(text.value, "text default", "input should reset value to default"); + assert_equals(checkbox.checked, true, "input should reset checkedness to default"); + assert_equals(option.selected, true, "second option should reset selectedness to default"); + assert_equals(select.selectedIndex, 0, "second option should reset selectedness to default"); + assert_equals(textarea.value, "textarea default", "textarea should reset api value to default"); + + text.defaultValue = "text new default"; + checkbox.defaultChecked = false; + option.defaultSelected = false; + textarea.defaultValue = "textarea new default"; + + assert_equals(text.value, "text new default", "input should reset dirty value to false"); + assert_equals(checkbox.checked, false, "input should reset dirty checkedness to false"); + assert_equals(option.selected, false, "option should reset dirtyness to false"); + assert_equals(select.selectedIndex, -1, "option should reset dirtyness to false"); + assert_equals(textarea.value, "textarea new default", "textarea should reset dirty value to false"); + +}, "integration test on reset for a created-from-script form"); +</script> diff --git a/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form-event-realm.html b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form-event-realm.html new file mode 100644 index 0000000000..6c125c46d0 --- /dev/null +++ b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form-event-realm.html @@ -0,0 +1,38 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>reset() event firing realm</title> +<link rel="help" href="https://html.spec.whatwg.org/#resetting-a-form"> +<link rel="help" href="https://dom.spec.whatwg.org/#concept-event-fire"> +<link rel="author" title="Domenic Denicola" href="mailto:d@domenic.me"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> + +<iframe src="support/reset-form-event-realm.html"></iframe> +<iframe></iframe> + +<script> +"use strict"; + +async_test(t => { + window.onload = t.step_func_done(() => { + const frame0Form = frames[0].document.forms[0]; + const frame1Body = frames[1].document.body; + + frame1Body.appendChild(frame0Form); + + let resetCalled = false; + frame0Form.onreset = t.step_func(ev => { + resetCalled = true; + + const functionConstructorInEvRealm = ev.constructor.constructor; + const functionConstructorInFormRealm = frame0Form.constructor.constructor; + + assert_equals(functionConstructorInEvRealm, functionConstructorInFormRealm, + "the event must be created in the realm of the target"); + }); + + frame0Form.reset(); + assert_true(resetCalled, "The reset event handler must have been called"); + }); +}, "reset()'s event must be fired in the Realm of the target") +</script> diff --git a/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form.html b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form.html new file mode 100644 index 0000000000..c7ac3e085b --- /dev/null +++ b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/reset-form.html @@ -0,0 +1,118 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>HTML Test: Resetting a form</title> +<link rel="author" title="Intel" href="http://www.intel.com/"> +<link rel="help" href="https://html.spec.whatwg.org/multipage/#concept-form-reset"> +<link rel="help" href="https://html.spec.whatwg.org/multipage/#category-reset"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<div id="log"></div> +<form name="fm1" style="display:none"> + <input value="abc" id="ipt1" /> + <input id="ipt2" /> + <input type="radio" id="rd1" checked="checked" /> + <input type="radio" id="rd2"/> + <input type="checkbox" id="cb1" checked="checked" /> + <input type="checkbox" id="cb2" /> + <textarea id="ta">abc</textarea> + <output id="opt">5</output> + <select id="slt1"> + <option value="1">ITEM1</option> + <option value="2">ITEM2</option> + </select> + <select id="slt2"> + <option value="1">ITEM1</option> + <option value="2" selected>ITEM2</option> + </select> + <select id="slt3" multiple> + <option value="1">ITEM1</option> + <option value="2" selected>ITEM2</option> + <option value="3" selected>ITEM3</option> + </select> + <button id="rst1" type="reset">Reset1</button> + <input id="rst2" type="reset" value="Reset2" /> +</form> +<script> + +runTest(function() { + document.forms.fm1.reset(); +}, "by calling the reset() method"); + +runTest(function() { + document.getElementById("rst1").click(); +}, "by clicking the button in reset status"); + +runTest(function() { + document.getElementById("rst2").click(); +}, "by clicking the input in reset status"); + +function setPreconditions (arg) { + document.getElementById("ipt1").value = "123"; + document.getElementById("ipt2").value = "123"; + document.getElementById("rd1").checked = false; + document.getElementById("rd2").checked = true; + document.getElementById("cb1").checked = false; + document.getElementById("cb2").checked = true; + document.getElementById("ta").value = "123"; + document.getElementById("opt").textContent = "abc"; + document.getElementById("slt1").value = "2"; + document.getElementById("slt2").value = "1"; + document.getElementById("slt3").options[0].selected = true; + document.getElementById("slt3").options[1].selected = false; + document.getElementById("slt3").options[2].selected = false; + + assert_equals(document.getElementById("ipt1").value, "123", "Precondition 1"); + assert_equals(document.getElementById("ipt2").value, "123", "Precondition 2"); + assert_false(document.getElementById("rd1").checked, "Precondition 3"); + assert_true(document.getElementById("rd2").checked, "Precondition 4"); + assert_false(document.getElementById("cb1").checked, "Precondition 5"); + assert_true(document.getElementById("cb2").checked, "Precondition 6"); + assert_equals(document.getElementById("ta").value, "123", "Precondition 17"); + assert_equals(document.getElementById("opt").textContent, "abc", "Precondition 8"); + assert_true(document.getElementById("slt1").options[1].selected, "Precondition 9"); + assert_true(document.getElementById("slt2").options[0].selected, "Precondition 10"); + assert_true(document.getElementById("slt3").options[0].selected, "Precondition 11"); + assert_false(document.getElementById("slt3").options[1].selected, "Precondition 12"); + assert_false(document.getElementById("slt3").options[2].selected, "Precondition 13"); +} + +function runTest(reset, description) { + test(function() { + setPreconditions("Setting preconditions for resetting " + description); + reset(); + assert_equals(document.getElementById("ipt1").value, "abc", "The value of the input element in text status should be 'abc'."); + assert_equals(document.getElementById("ipt2").value, "", "The value of the input element in text status should be empty string."); + assert_true(document.getElementById("rd1").checked, "The checked attribute of the input element in radio should be true."); + assert_false(document.getElementById("rd2").checked, "The checked attribute of the input element in radio should be false."); + assert_true(document.getElementById("cb1").checked, "The checked attribute of the input element in checkbox should be true."); + assert_false(document.getElementById("cb2").checked, "The checked attribute of the input element in checkbox should be false."); + }, "Resetting <input> " + description); + + test(function() { + setPreconditions("Setting preconditions for resetting " + description); + reset(); + assert_equals(document.getElementById("ta").value, document.getElementById("ta").textContent, "The value attribute of the textarea element should be reset."); + assert_equals(document.getElementById("ta").value, "abc", "The value attribute of the textarea element should be 'abc'."); + }, "Resetting <textarea> " + description); + + test(function() { + setPreconditions("Setting preconditions for resetting " + description); + reset(); + assert_equals(document.getElementById("opt").textContent, document.getElementById("opt").defaultValue, "The textContent of the output element should be reset."); + assert_equals(document.getElementById("opt").textContent, "abc", "The textContent of the output element should be 'abc'."); + }, "Resetting <output> " + description); + + test(function() { + setPreconditions("Setting preconditions for resetting " + description); + reset(); + assert_true(document.getElementById("slt1").options[0].selected, "The first option in the select element should be selected."); + assert_false(document.getElementById("slt1").options[1].selected, "The second option in the select element should not be selected."); + assert_false(document.getElementById("slt2").options[0].selected, "The first option in the select element should not be selected."); + assert_true(document.getElementById("slt2").options[1].selected, "The second option in the select element should be selected."); + assert_false(document.getElementById("slt3").options[0].selected, "The first option in the select element with multiple attribute should not be selected."); + assert_true(document.getElementById("slt3").options[1].selected, "The second option in the select element with multiple attribute should be selected."); + assert_true(document.getElementById("slt3").options[2].selected, "The third option in the select element with multiple attribute should be selected."); + }, "Resetting <select> " + description); +} + +</script> diff --git a/testing/web-platform/tests/html/semantics/forms/resetting-a-form/support/reset-form-event-realm.html b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/support/reset-form-event-realm.html new file mode 100644 index 0000000000..f55c651b54 --- /dev/null +++ b/testing/web-platform/tests/html/semantics/forms/resetting-a-form/support/reset-form-event-realm.html @@ -0,0 +1,3 @@ +<!DOCTYPE html> + +<form></form> |