| OLD | NEW |
| 1 <!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN"> | 1 <!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN"> |
| 2 <html> | 2 <html> |
| 3 <head> | 3 <head> |
| 4 <script src="../../resources/js-test.js"></script> | 4 <script src="../../resources/js-test.js"></script> |
| 5 </head> | 5 </head> |
| 6 <body> | 6 <body> |
| 7 <script src="script-tests/header-element.js"></script> | 7 <script> |
| 8 description('Various tests for the header element.'); |
| 9 |
| 10 var testParent = document.createElement('div'); |
| 11 document.body.appendChild(testParent); |
| 12 |
| 13 debug('<header> closes <p>:'); |
| 14 testParent.innerHTML = '<p>Test that <header id="header1">a header element</head
er> closes <p>.</p>'; |
| 15 var header1 = document.getElementById('header1'); |
| 16 shouldBeFalse('header1.parentNode.nodeName == "p"'); |
| 17 |
| 18 debug('<p> does not close <header>:'); |
| 19 testParent.innerHTML = '<header>Test that <p id="p1">a p element</p> does not cl
ose a header element.</header>'; |
| 20 var p1 = document.getElementById('p1'); |
| 21 shouldBe('p1.parentNode.nodeName', '"HEADER"'); |
| 22 |
| 23 debug('<header> can be nested inside <header> or <footer>:'); |
| 24 testParent.innerHTML = '<header id="header2">Test that <header id="header3">a he
ader element</header> can be nested inside another header element.</header>'; |
| 25 var header3 = document.getElementById('header3'); |
| 26 shouldBe('header3.parentNode.id', '"header2"'); |
| 27 testParent.innerHTML = '<footer id="footer1">Test that <header id="header5">a he
ader element</header> can be nested inside a footer element.</footer>'; |
| 28 var header5 = document.getElementById('header5'); |
| 29 shouldBe('header5.parentNode.id', '"footer1"'); |
| 30 |
| 31 debug('Residual style:'); |
| 32 testParent.innerHTML = '<b><header id="header4">This text should be bold.</heade
r> <span id="span1">This is also bold.</span></b>'; |
| 33 function getWeight(id) { |
| 34 return document.defaultView.getComputedStyle(document.getElementById(id), nu
ll).getPropertyValue('font-weight'); |
| 35 } |
| 36 shouldBe('getWeight("header4")', '"bold"'); |
| 37 shouldBe('getWeight("span1")', '"bold"'); |
| 38 document.body.removeChild(testParent); |
| 39 |
| 40 debug('FormatBlock:'); |
| 41 var editable = document.createElement('div'); |
| 42 editable.innerHTML = '[<span id="span2">The text will be a child of <header>.
</span>]'; |
| 43 document.body.appendChild(editable); |
| 44 editable.contentEditable = true; |
| 45 var selection = window.getSelection(); |
| 46 selection.selectAllChildren(editable); |
| 47 document.execCommand('FormatBlock', false, 'header'); |
| 48 selection.removeAllRanges(); |
| 49 shouldBe('document.getElementById("span2").parentNode.nodeName', '"HEADER"'); |
| 50 document.body.removeChild(editable); |
| 51 |
| 52 </script> |
| 8 </body> | 53 </body> |
| 9 </html> | 54 </html> |
| OLD | NEW |