diff options
Diffstat (limited to 'testing/web-platform/tests/custom-elements/v0/registering/unresolved-element-pseudoclass/unresolved-element-pseudoclass-matching-query-selector-all.html')
-rw-r--r-- | testing/web-platform/tests/custom-elements/v0/registering/unresolved-element-pseudoclass/unresolved-element-pseudoclass-matching-query-selector-all.html | 190 |
1 files changed, 190 insertions, 0 deletions
diff --git a/testing/web-platform/tests/custom-elements/v0/registering/unresolved-element-pseudoclass/unresolved-element-pseudoclass-matching-query-selector-all.html b/testing/web-platform/tests/custom-elements/v0/registering/unresolved-element-pseudoclass/unresolved-element-pseudoclass-matching-query-selector-all.html new file mode 100644 index 000000000..2ddc2afc2 --- /dev/null +++ b/testing/web-platform/tests/custom-elements/v0/registering/unresolved-element-pseudoclass/unresolved-element-pseudoclass-matching-query-selector-all.html @@ -0,0 +1,190 @@ +<!DOCTYPE html> +<html> +<head> +<title>The :unresolved pseudoclass matching with Document.querySelectorAll()</title> +<meta name="author" title="Aleksei Yu. Semenov" href="mailto:a.semenov@unipro.ru"> +<meta name="author" title="Sergey G. Grekhov" href="mailto:sgrekhov@unipro.ru"> +<meta name="assert" content="The :unresolved pseudoclass must match all custom elements whose created callback has not yet been invoked"> +<link rel="help" href="http://www.w3.org/TR/custom-elements/#unresolved-element-pseudoclass"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="../../testcommon.js"></script> +</head> +<body> +<div id="log"></div> +<script> +test(function() { + var doc = newHTMLDocument(); + doc.body.innerHTML = '<x-a></x-a>'; + var queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 1, + 'Unresolved custom element should be accessible by :unresolved pseudoclass'); + assert_equals(queryResult.item(0).localName, 'x-a', + 'Document.querySelectorAll(\':unresolved\') should return x-a element'); +}, 'Test that single unresolved custom element is accessible ' + + 'by Document.querySelectorAll(\':unresolved\')'); + + +test(function() { + var doc = newHTMLDocument(); + doc.body.innerHTML = '<x-b></x-b>'; + var queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 1, + 'Unresolved custom element should be accessible by :unresolved pseudoclass'); + assert_equals(queryResult.item(0).localName, 'x-b', + 'Document.querySelectorAll(\':unresolved\') should return x-b element'); + + doc.registerElement('x-b'); + queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 0, + 'Registered custom element should not be accessible by :unresolved pseudoclass'); +}, 'Test that single registered custom element is not accessible by :unresolved'); + + +test(function() { + var doc = newHTMLDocument(); + doc.body.innerHTML = '<x-c></x-c><x-d></x-d>'; + var queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 2, + 'All unresolved custom element should be accessible by :unresolved pseudoclass'); + assert_equals(queryResult.item(0).localName, 'x-c', + 'First custom element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be x-c'); + assert_equals(queryResult.item(1).localName, 'x-d', + 'Second custom element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be x-d'); + + doc.registerElement('x-c'); + queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 1, + 'Only unresolved custom elements should be accessible by :unresolved pseudoclass'); + assert_equals(queryResult.item(0).localName, 'x-d', + 'Custom element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be x-d'); +}, 'If there are more than one unresolved custom element then all of them accessible ' + + 'by Document.querySelectorAll(\':unresolved\')'); + + +test(function() { + var doc = newHTMLDocument(); + var customElement = doc.createElement('x-e'); + doc.body.appendChild(customElement); + var queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 1, + 'Unresolved custom element should be accessible by :unresolved pseudoclass'); + assert_equals(queryResult.item(0).localName, 'x-e', + 'Custom element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be x-e'); +}, 'Unresolved custom element, created via Document.createElement(), should be ' + + 'accessible by Document.querySelectorAll(\':unresolved\')'); + + +test(function() { + var doc = newHTMLDocument(); + doc.body.innerHTML = '<x-f><x-g></x-g></x-f>'; + var queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 2, + 'All unresolved custom element should be accessible by :unresolved pseudoclass'); + assert_equals(queryResult.item(0).localName, 'x-f', + 'First custom element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be x-f'); + assert_equals(queryResult.item(1).localName, 'x-g', + 'Second custom element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be x-g'); + + doc.registerElement('x-g'); + queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 1, + 'Only unresolved custom elements should be accessible by :unresolved pseudoclass'); + assert_equals(queryResult.item(0).localName, 'x-f', + 'Custom element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be x-f'); +}, 'All unresolved custom element including nested ones are accessible ' + + 'by Document.querySelectorAll(\':unresolved\')'); + + +testInIFrame('../../resources/x-element.html', function(doc) { + var queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 1, + 'Unresolved custom element should be accessible by ' + + 'Document.querySelectorAll(\':unresolved\')'); + assert_equals(queryResult.item(0).localName, 'x-element', + 'Custom element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be x-element'); +}, 'Unresolved custom element should be accessible by ' + + 'Document.querySelectorAll(\':unresolved\') in a loaded document'); + + +test(function() { + var doc = newHTMLDocument(); + + HTML5_ELEMENTS.forEach(function(tagName) { + if (HTML5_DOCUMENT_ELEMENTS.indexOf(tagName) === -1) { + var obj = doc.createElement(tagName); + var name = 'x-h-' + tagName; + var id = 'x-h-' + tagName + '-id'; + if (HTML5_TABLE_ELEMENTS.indexOf(tagName) !== -1) { + doc.body.innerHTML = + '<table>' + + '<' + tagName + ' id="' + id + '" is="' + name + '"></' + tagName + '>' + + '</table>'; + } else { + doc.body.innerHTML = + '<' + tagName + ' id="' + id + '" is="' + name + '"></' + tagName + '>'; + } + var queryResult = doc.querySelectorAll(':unresolved'); + + assert_not_equals(queryResult, null, + 'Unresolved custom element should be accessible by :unresolved pseudoclass'); + assert_equals(queryResult.item(0).id, id, + 'ID of element returned by Document.querySelectorAll(\':unresolved\') ' + + 'should be ' + id); + + var proto = Object.create(obj.constructor.prototype); + doc.registerElement(name, {prototype: proto, extends: tagName}); + var queryResult2 = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult2.length, 0, + 'Registered custom element should not be accessible by :unresolved pseudoclass'); + } + }); +}, 'Test that Document.querySelectorAll(\':unresolved\') returns unresolved custom elements, ' + + 'extending HTML elements by IS attribute'); + + +test(function() { + var doc = newHTMLDocument(); + doc.body.innerHTML = '<x-i><a is="x-j"></a></x-i><x-k></x-k><b is="x-l"/>'; + var queryResult = doc.querySelectorAll(':unresolved'); + + assert_equals(queryResult.length, 4, + 'All unresolved custom element should be accessible by :unresolved pseudoclass'); + + var elementNames = [ + queryResult.item(0).localName, + queryResult.item(1).localName, + queryResult.item(2).localName, + queryResult.item(3).localName]; + assert_array_equals(elementNames, ['x-i', 'a', 'x-k', 'b'], + 'Document.querySelectorAll(\':unresolved\') return unexpected result'); + + var isAttributes = [ + queryResult.item(0).getAttribute('is'), + queryResult.item(1).getAttribute('is'), + queryResult.item(2).getAttribute('is'), + queryResult.item(3).getAttribute('is')]; + assert_array_equals(isAttributes, [null, 'x-j', null, 'x-l'], + 'Document.querySelectorAll(\':unresolved\') return unexpected result'); +}, 'Test Document.querySelectorAll(\':unresolved\') returns mix of custom elements of different types'); +</script> +</body> +</html> |