summaryrefslogtreecommitdiffstats
path: root/toolkit/content/tests/widgets/test_bug1654500.html
blob: 9bb05ba9c86f0d93125e4a06b8dd6aeb0ccdaa5e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE html>
<meta charset="utf-8">
<title>Clear disabled/readonly datetime inputs</title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<script src="/tests/SimpleTest/EventUtils.js"></script>
<p>Disabled inputs should be able to be cleared just as they can be set with real values</p>
<input type="date" id="date1" value="2020-08-11" disabled>
<input type="date" id="date2" value="2020-08-11" readonly>
<input type="time" id="time1" value="07:01" disabled>
<input type="time" id="time2" value="07:01" readonly>
<script>
/* global date1, date2, time1, time2 */
function querySelectorAllShadow(parent, selector) {
  const shadowRoot = SpecialPowers.wrap(parent).openOrClosedShadowRoot;
  return shadowRoot.querySelectorAll(selector);
}
date1.value = date2.value = "";
time1.value = time2.value = "";
for (const date of [date1, date2]) {
  const fields = [...querySelectorAllShadow(date, ".datetime-edit-field")];
  is(fields.length, 3, "Three numeric fields are expected");
  for (const field of fields) {
    is(field.getAttribute("value"), "", "All fields should be cleared");
  }
}
for (const time of [time1, time2]) {
  const fields = [...querySelectorAllShadow(time, ".datetime-edit-field")];
  ok(fields.length >= 2, "At least two numeric fields are expected");
  for (const field of fields) {
    is(field.getAttribute("value"), "", "All fields should be cleared");
  }
}
</script>