change-to-empty-value.html (1340B)
1 <!doctype html> 2 <meta charset="utf-8"> 3 <title>Change event when clearing an input</title> 4 <link rel="author" href="mailto:emilio@crisal.io" title="Emilio Cobos Álvarez"> 5 <link rel="author" href="https://mozilla.org" title="Mozilla"> 6 <link rel="help" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1881457"> 7 <script src="/resources/testharness.js"></script> 8 <script src="/resources/testharnessreport.js"></script> 9 <script src="/resources/testdriver.js"></script> 10 <script src="/resources/testdriver-actions.js"></script> 11 <script src="/resources/testdriver-vendor.js"></script> 12 <input type="text" value="abc"> 13 <script> 14 promise_test(async function() { 15 let input = document.querySelector("input"); 16 let changeFired = false; 17 input.addEventListener("change", () => { 18 changeFired = true; 19 }, { once: true }); 20 input.focus(); 21 assert_equals(document.activeElement, input, "Should focus input"); 22 assert_false(changeFired, "Shouldn't have fired change event after focus"); 23 input.select(); 24 const kBackspaceKey = "\uE003"; 25 await test_driver.send_keys(input, kBackspaceKey) 26 assert_false(changeFired, "Shouldn't have fired change event after select"); 27 input.blur(); 28 assert_true(changeFired, "Should've have fired change event after blur"); 29 assert_equals(input.value, "", "Should've have cleared the value"); 30 }); 31 </script>