Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
- This WPT test may be referenced by the following Test IDs:
- /shadow-dom/untriaged/html-elements-in-shadow-trees/html-forms/test-001.html - WPT Dashboard Interop Dashboard
<!DOCTYPE html>
<html>
<head>
<title>Shadow DOM Test: A_08_02_01</title>
<link rel="author" title="Sergey G. Grekhov" href="mailto:sgrekhov@unipro.ru">
<meta name="assert" content="HTML Elements in shadow trees: Form elements and form-associated elements in shadow tree are not accessible using document DOM object's tree accessors">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="../../../../html/resources/common.js"></script>
</head>
<body>
<div id="log"></div>
<script>
//test form-associated elements
test(function () {
var d = newHTMLDocument();
var form = d.createElement('form');
form.setAttribute('id', 'form_id');
d.body.appendChild(form);
var div = d.createElement('div');
d.body.appendChild(div);
var s = div.attachShadow({mode: 'open'});
HTML5_FORM_ASSOCIATED_ELEMENTS.forEach(function (tagName) {
var el = d.createElement(tagName);
el.setAttribute('form', 'form_id');
el.setAttribute('id', tagName + '_id');
s.appendChild(el);
assert_equals(d.querySelector('#' + tagName + '_id'), null, 'Form-associated element ' + tagName +
' in shadow tree must not be accessible using owner\'s document tree accessors');
});
}, 'A_08_02_01_T01');
//test form elements
test(function () {
var d = newHTMLDocument();
var form = d.createElement('form');
d.body.appendChild(form);
var div = d.createElement('div');
form.appendChild(div);
s = div.attachShadow({mode: 'open'});
HTML5_FORM_ASSOCIATED_ELEMENTS.forEach(function (tagName) {
var el = d.createElement(tagName);
el.setAttribute('id', tagName + '_id');
s.appendChild(el);
assert_equals(d.querySelector('#' + tagName + '_id'), null, 'Form element ' + tagName +
' in shadow tree must not be accessible using owner\'s document tree accessors');
});
}, 'A_08_02_01_T02');
</script>
</body>
</html>