| OLD | NEW |
| (Empty) |
| 1 <!DOCTYPE html> | |
| 2 <html> | |
| 3 <head> | |
| 4 <title>HTML Templates: Parsing XHTML: Node's node document</title> | |
| 5 <meta name="author" title="Sergey G. Grekhov" href="mailto:sgrekhov@unipro.ru"> | |
| 6 <meta name="author" title="Aleksei Yu. Semenov" href="mailto:a.semenov@unipro.ru
"> | |
| 7 <meta name="assert" content="Parsing XHTML: Node's node document must be set to
that of the element to which it will be appended"> | |
| 8 <link rel="help" href="http://www.w3.org/TR/2013/WD-html-templates-20130214/#par
sing-xhtml-documents"> | |
| 9 <script src="../../../../../../../resources/testharness.js"></script> | |
| 10 <script src="../../../../../../../resources/testharnessreport.js"></script> | |
| 11 <script src='/html/resources/common.js'></script> | |
| 12 <link rel="stylesheet" href="../../../../../../../resources/testharness.css"> | |
| 13 </head> | |
| 14 <body> | |
| 15 <div id="log"></div> | |
| 16 <script type="text/javascript"> | |
| 17 | |
| 18 | |
| 19 | |
| 20 test(function() { | |
| 21 var doc = newXHTMLDocument(); | |
| 22 doc.body = doc.createElement('body'); | |
| 23 doc.body.innerHTML = '<template id="tmpl"></template>'; | |
| 24 | |
| 25 var template = doc.querySelector('#tmpl'); | |
| 26 | |
| 27 assert_not_equals(template, null, 'Template element should not be null'); | |
| 28 assert_not_equals(template.content, undefined, | |
| 29 'Content attribute of template element should not be undefined'); | |
| 30 assert_not_equals(template.content, null, | |
| 31 'Content attribute of template element should not be null'); | |
| 32 | |
| 33 assert_equals(template.ownerDocument, doc.body.ownerDocument, | |
| 34 'Wrong template node owner document'); | |
| 35 assert_equals(template.content.ownerDocument, doc, | |
| 36 'Wrong template content owner document'); | |
| 37 | |
| 38 }, 'Parsing XHTML: Node\'s node document must be set to that of the element ' | |
| 39 + 'to which it will be appended. Test empty template'); | |
| 40 | |
| 41 | |
| 42 | |
| 43 test(function() { | |
| 44 var doc = newXHTMLDocument(); | |
| 45 | |
| 46 doc.body = doc.createElement('body'); | |
| 47 doc.body.innerHTML = '<template id="tmpl"><div>Div content</div></template>'
; | |
| 48 | |
| 49 var template = doc.querySelector('#tmpl'); | |
| 50 | |
| 51 assert_equals(template.ownerDocument, doc.body.ownerDocument, | |
| 52 'Wrong template node owner document'); | |
| 53 | |
| 54 assert_not_equals(template, null, 'Template element should not be null'); | |
| 55 assert_not_equals(template.content, undefined, | |
| 56 'Content attribute of template element should not be undefined'); | |
| 57 assert_not_equals(template.content, null, | |
| 58 'Content attribute of template element should not be null'); | |
| 59 | |
| 60 var div = template.content.querySelector('div'); | |
| 61 assert_equals(template.content.ownerDocument, div.ownerDocument, | |
| 62 'Wrong DIV node owner document'); | |
| 63 | |
| 64 }, 'Parsing XHTML: Node\'s node document must be set to that of the element ' | |
| 65 + 'to which it will be appended. Test not empty template'); | |
| 66 | |
| 67 | |
| 68 | |
| 69 test(function() { | |
| 70 var doc = newXHTMLDocument(); | |
| 71 doc.body = doc.createElement('body'); | |
| 72 doc.body.innerHTML = '' | |
| 73 + '<template id="tmpl"><div>Div content</div> And some more text' | |
| 74 + '<template id="tmpl2"><div>Template content</div></template>' | |
| 75 + '</template>'; | |
| 76 | |
| 77 var template = doc.querySelector('#tmpl'); | |
| 78 assert_not_equals(template, null, 'Template element should not be null'); | |
| 79 assert_equals(template.ownerDocument, doc, 'Wrong template node owner docume
nt'); | |
| 80 assert_not_equals(template.content, undefined, | |
| 81 'Content attribute of template element should not be undefined'); | |
| 82 assert_not_equals(template.content, null, | |
| 83 'Content attribute of template element should not be null'); | |
| 84 | |
| 85 var nestedTemplate = template.content.querySelector('#tmpl2'); | |
| 86 assert_not_equals(nestedTemplate, null, 'Nested template element should not
be null'); | |
| 87 assert_not_equals(nestedTemplate.content, undefined, | |
| 88 'Content attribute of nested template element should not be undefine
d'); | |
| 89 assert_not_equals(nestedTemplate.content, null, | |
| 90 'Content attribute of nested template element should not be null'); | |
| 91 | |
| 92 assert_equals(nestedTemplate.ownerDocument, template.content.ownerDocument, | |
| 93 'Wrong nested template node owner document'); | |
| 94 | |
| 95 | |
| 96 var div = nestedTemplate.content.querySelector('div'); | |
| 97 assert_equals(nestedTemplate.content.ownerDocument, div.ownerDocument, | |
| 98 'Wrong DIV node owner document'); | |
| 99 | |
| 100 }, 'Parsing XHTML: Node\'s node document must be set to that of the element ' | |
| 101 + 'to which it will be appended. Test nested templates'); | |
| 102 | |
| 103 | |
| 104 | |
| 105 testInIFrame('../resources/template-child-nodes-div.xhtml', function(context) { | |
| 106 var doc = context.iframes[0].contentDocument; | |
| 107 | |
| 108 var template = doc.querySelector('template'); | |
| 109 | |
| 110 assert_equals(template.ownerDocument, doc, 'Wrong template node owner docume
nt'); | |
| 111 | |
| 112 assert_not_equals(template.content, undefined, | |
| 113 'Content attribute of template element should not be undefined'); | |
| 114 assert_not_equals(template.content, null, | |
| 115 'Content attribute of template element should not be null'); | |
| 116 | |
| 117 var div = template.content.querySelector('div'); | |
| 118 assert_equals(template.content.ownerDocument, div.ownerDocument, | |
| 119 'Wrong DIV node owner document'); | |
| 120 | |
| 121 }, 'Parsing XHTML: Node\'s node document must be set to that of the element ' | |
| 122 + 'to which it will be appended. Test loading XHTML document from a file'); | |
| 123 | |
| 124 | |
| 125 | |
| 126 testInIFrame('../resources/template-child-nodes-nested.xhtml', function(context)
{ | |
| 127 var doc = context.iframes[0].contentDocument; | |
| 128 | |
| 129 var template = doc.querySelector('template'); | |
| 130 | |
| 131 assert_equals(template.ownerDocument, doc, 'Wrong template node owner docume
nt'); | |
| 132 | |
| 133 var nestedTemplate = template.content.querySelector('template'); | |
| 134 | |
| 135 assert_equals(nestedTemplate.ownerDocument, template.content.ownerDocument, | |
| 136 'Wrong template node owner document'); | |
| 137 | |
| 138 var div = nestedTemplate.content.querySelector('div'); | |
| 139 assert_equals(nestedTemplate.content.ownerDocument, div.ownerDocument, | |
| 140 'Wrong DIV node owner document'); | |
| 141 | |
| 142 }, 'Parsing XHTML: Node\'s node document must be set to that of the element ' | |
| 143 + 'to which it will be appended. Test loading of XHTML document ' | |
| 144 + 'with nested templates from a file'); | |
| 145 | |
| 146 </script> | |
| 147 </body> | |
| 148 </html> | |
| OLD | NEW |