chromium/third_party/blink/web_tests/fast/dom/Range/range-extract-contents.html

<!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, '&lt;');
    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, '&lt;'));

    log('');
}

Markup.noAutoDump();

var test = document.getElementById('test');
log('test contents:\n' + Markup.get(test).replace(/</g, '&lt;') + '\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>