| <!DOCTYPE html> |
| <html> |
| <body> |
| <div id="test">hello world<span style="font-weight: bold;">WebKit</span><em><script>var i=0;</script><b><code>This</code> is</u></b> a <tt>test <wbr>of <blockquote>Range's extractContents.</blockquote></tt></em><q><dfn>This</dfn></q><!-- test --> <header><h3>test</header> also works in Firefox.</h3></div> |
| <div id="expectations"> |
| <div id="test_empty"></div> |
| <div id="test_text">hello world</div> |
| <div id="test_substring">llo</div> |
| <div id="test_text_with_start_tag">hello world<span style="font-weight: bold;"></span></div> |
| <div id="test_text_and_span">hello world<span style="font-weight: bold;">WebKit</span></div> |
| <div id="test_span_b"><span style="font-weight: bold;">WebKit</span><em><script>var i=0;</script><b></b></em></div> |
| <div id="test_code_blockquote"><b><code>This</code> is</u></b> a <tt>test <wbr>of <blockquote>Range's extractContents.</blockquote></tt></div> |
| <div id="test_wbr_blockquote"><wbr>of <blockquote>Range's extractContents.</blockquote></div> |
| <div id="test_q_header"><q><dfn>This</dfn></q><!-- test --> <header><h3>test</h3></header></div> |
| <div id="test_script_dfn"><em><script>var i=0;</script><b><code>This</code> is</u></b> a <tt>test <wbr>of <blockquote>Range's extractContents.</blockquote></tt></em><q><dfn>This</dfn></div> |
| <div id="test_blockquote_em"><tt><blockquote>Range's extractContents.</blockquote></tt></div> |
| </div> |
| <pre id="console"></pre> |
| <script src="../../../resources/dump-as-markup.js"></script> |
| <script> |
| |
| function log(message) { |
| document.getElementById('console').innerHTML += message + '\n'; |
| } |
| |
| function testExtractContents(description, startContainer, startOffset, endContainer, endOffset, expectedContentsId) { |
| var testContents = document.getElementById('test').innerHTML; |
| |
| var range = document.createRange(); |
| range.setStart(startContainer, startOffset); |
| range.setEnd(endContainer, endOffset); |
| var actualContents = range.extractContents(); |
| |
| document.getElementById('test').innerHTML = testContents; |
| |
| var action = description + ' yields:\n' + Markup.get(actualContents).replace(/</g, '<'); |
| var expectedContents = document.getElementById(expectedContentsId); |
| if (Markup.get(actualContents) == Markup.get(expectedContents)) |
| log('PASS: ' + action); |
| else |
| log('FAIL: ' + action + '\n but expected:\n' + Markup.get(expectedContents).replace(/</g, '<')); |
| |
| log(''); |
| } |
| |
| Markup.noAutoDump(); |
| |
| var test = document.getElementById('test'); |
| log('test contents:\n' + Markup.get(test).replace(/</g, '<') + '\n') |
| |
| function firstElement(name) { |
| return test.getElementsByTagName(name)[0]; |
| } |
| |
| testExtractContents('Extracting empty contents', test, 0, test, 0, 'test_empty'); |
| testExtractContents('Extracting entire contents', test, 0, test, test.childNodes.length, 'test'); |
| testExtractContents('Extracting single text node', test, 0, test, 1, 'test_text') |
| testExtractContents('Extracting substring of a text node (2, 5)', test.firstChild, 2, test.firstChild, 5, 'test_substring'); |
| testExtractContents('Extracting single text node and start of span', test, 0, test.childNodes[1], 0, 'test_text_with_start_tag'); |
| testExtractContents('Extracting single text node and a span', test, 0, test, 2, 'test_text_and_span'); |
| testExtractContents('Extracting span through first b', firstElement('span'), 0, firstElement('b'), 0, 'test_span_b'); |
| testExtractContents('Extracting code through blockquote', firstElement('code'), 0, firstElement('blockquote'), 1, 'test_code_blockquote'); |
| testExtractContents('Extracting wbr through blockquote', firstElement('wbr'), 0, firstElement('blockquote'), 1, 'test_wbr_blockquote'); |
| testExtractContents('Extracting q through header', firstElement('q'), 0, firstElement('header'), 1, 'test_q_header'); |
| testExtractContents('Extracting q through header using node index', test, 3, test, 7, 'test_q_header'); |
| testExtractContents('Extracting dfn through header', firstElement('dfn'), 0, firstElement('header'), 1, 'test_q_header'); |
| testExtractContents('Extracting script through dfn', firstElement('script'), 0, firstElement('dfn'), 1, 'test_script_dfn'); |
| testExtractContents('Extracting blockquote through em', firstElement('blockquote'), 0, firstElement('em'), firstElement('em').childNodes.length, 'test_blockquote_em'); |
| |
| test.style.display = 'none'; |
| document.getElementById('expectations').style.display = 'none'; |
| |
| log('DONE'); |
| |
| </script> |
| </body> |
| </html> |