File: form-elements-namedItem.html

package info (click to toggle)
firefox 143.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,617,328 kB
  • sloc: cpp: 7,478,492; javascript: 6,417,157; ansic: 3,720,058; python: 1,396,372; xml: 627,523; asm: 438,677; java: 186,156; sh: 63,477; makefile: 19,171; objc: 13,059; perl: 12,983; yacc: 4,583; cs: 3,846; pascal: 3,405; lex: 1,720; ruby: 1,003; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 53; csh: 10
file content (66 lines) | stat: -rw-r--r-- 3,545 bytes parent folder | download | duplicates (18)
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<!DOCTYPE html>
<body>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>

<script>
customElements.define('custom-input', class extends HTMLElement {
  static get formAssociated() {return true;}
});
</script>

<form id="custom-form">
  <custom-input id="custom-1" name="alone"></custom-input>
  <custom-input id="custom-2" name="group"></custom-input>
  <custom-input id="custom-3" name="group"></custom-input>
  <custom-button id="custom-4" name="upgrade"></custom-button>
</form>
<custom-input id="custom-5" name="group" form="custom-form"></custom-input>
<custom-button id="custom-6" name="group" form="custom-form"></custom-button>

<script>
test(() => {
  const formElements = document.forms[0].elements;
  assert_equals(formElements['invalid'],undefined);
  assert_equals(formElements['alone'],document.getElementById('custom-1'),'Single input should be returned as-is');
  assert_true(formElements['group'] instanceof RadioNodeList,'Repeated names should result in RadioNodeList');
  const expected = [document.getElementById('custom-2'),
                    document.getElementById('custom-3'),
                    document.getElementById('custom-5')];
  assert_array_equals(formElements['group'],expected,'Repeated names should be contained in RadioNodeList, in tree order');
}, 'Form associated custom elements should work with document.forms.elements.namedItem()');

test(() => {
  const formElements = document.forms[0].elements;
  assert_equals(formElements['upgrade'],undefined);
  customElements.define('custom-button', class extends HTMLElement {
    static get formAssociated() {return true;}
  });
  assert_equals(formElements['upgrade'],document.getElementById('custom-4'),'Single button should be returned after upgrading');
  const expected = [document.getElementById('custom-2'),
                    document.getElementById('custom-3'),
                    document.getElementById('custom-5'),
                    document.getElementById('custom-6')];
  assert_array_equals(formElements['group'],expected,'Repeated names should be contained in RadioNodeList, in tree order after upgrading');
}, 'Form associated custom elements should work with document.forms.elements.namedItem() after upgrading');

test(() => {
  const formElements = document.forms[0].elements;
  assert_equals(formElements['alone'],document.getElementById('custom-1'),'Single input should be returned as-is');
  const expected = [document.getElementById('custom-2'),
                    document.getElementById('custom-3'),
                    document.getElementById('custom-5'),
                    document.getElementById('custom-6')];
  assert_array_equals(formElements['group'],expected,'Repeated names should be contained in RadioNodeList, in tree order after upgrading');
  document.getElementById('custom-1').setAttribute("name", "group");
  assert_equals(formElements['alone'],undefined);
  const expectedNew = [document.getElementById('custom-1'),
                      document.getElementById('custom-2'),
                      document.getElementById('custom-3'),
                      document.getElementById('custom-5'),
                      document.getElementById('custom-6')];
  assert_array_equals(formElements['group'],expectedNew,'Repeated names should be contained in RadioNodeList, in tree order after updating name attribute');
}, 'Form associated custom elements should work with document.forms.elements.namedItem() after updating the name attribute');

</script>
</body>