|  | <!DOCTYPE html> | 
|  | <meta charset=utf-8> | 
|  | <title>ChildNode.replaceWith</title> | 
|  | <link rel=help href="https://dom.spec.whatwg.org/#dom-childnode-replaceWith"> | 
|  | <script src="/resources/testharness.js"></script> | 
|  | <script src="/resources/testharnessreport.js"></script> | 
|  | <script> | 
|  |  | 
|  | function test_replaceWith(child, nodeName, innerHTML) { | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | parent.appendChild(child); | 
|  | child.replaceWith(); | 
|  | assert_equals(parent.innerHTML, ''); | 
|  | }, nodeName + '.replaceWith() without any argument.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | parent.appendChild(child); | 
|  | child.replaceWith(null); | 
|  | assert_equals(parent.innerHTML, 'null'); | 
|  | }, nodeName + '.replaceWith() with null as an argument.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | parent.appendChild(child); | 
|  | child.replaceWith(undefined); | 
|  | assert_equals(parent.innerHTML, 'undefined'); | 
|  | }, nodeName + '.replaceWith() with undefined as an argument.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | parent.appendChild(child); | 
|  | child.replaceWith(''); | 
|  | assert_equals(parent.innerHTML, ''); | 
|  | }, nodeName + '.replaceWith() with empty string as an argument.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | parent.appendChild(child); | 
|  | child.replaceWith('text'); | 
|  | assert_equals(parent.innerHTML, 'text'); | 
|  | }, nodeName + '.replaceWith() with only text as an argument.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | var x = document.createElement('x'); | 
|  | parent.appendChild(child); | 
|  | child.replaceWith(x); | 
|  | assert_equals(parent.innerHTML, '<x></x>'); | 
|  | }, nodeName + '.replaceWith() with only one element as an argument.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | var x = document.createElement('x'); | 
|  | var y = document.createElement('y'); | 
|  | var z = document.createElement('z'); | 
|  | parent.appendChild(y); | 
|  | parent.appendChild(child); | 
|  | parent.appendChild(x); | 
|  | child.replaceWith(x, y, z); | 
|  | assert_equals(parent.innerHTML, '<x></x><y></y><z></z>'); | 
|  | }, nodeName + '.replaceWith() with sibling of child as arguments.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | var x = document.createElement('x'); | 
|  | parent.appendChild(child); | 
|  | parent.appendChild(x); | 
|  | parent.appendChild(document.createTextNode('1')); | 
|  | child.replaceWith(x, '2'); | 
|  | assert_equals(parent.innerHTML, '<x></x>21'); | 
|  | }, nodeName + '.replaceWith() with one sibling of child and text as arguments.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | var x = document.createElement('x'); | 
|  | parent.appendChild(child); | 
|  | parent.appendChild(x); | 
|  | parent.appendChild(document.createTextNode('text')); | 
|  | child.replaceWith(x, child); | 
|  | assert_equals(parent.innerHTML, '<x></x>' + innerHTML + 'text'); | 
|  | }, nodeName + '.replaceWith() with one sibling of child and child itself as arguments.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | var x = document.createElement('x'); | 
|  | parent.appendChild(child); | 
|  | child.replaceWith(x, 'text'); | 
|  | assert_equals(parent.innerHTML, '<x></x>text'); | 
|  | }, nodeName + '.replaceWith() with one element and text as arguments.'); | 
|  |  | 
|  | test(function() { | 
|  | var parent = document.createElement('div'); | 
|  | var x = document.createElement('x'); | 
|  | var y = document.createElement('y'); | 
|  | parent.appendChild(x); | 
|  | parent.appendChild(y); | 
|  | child.replaceWith(x, y); | 
|  | assert_equals(parent.innerHTML, '<x></x><y></y>'); | 
|  | }, nodeName + '.replaceWith() on a parentless child with two elements as arguments.'); | 
|  | } | 
|  |  | 
|  | test_replaceWith(document.createComment('test'), 'Comment', '<!--test-->'); | 
|  | test_replaceWith(document.createElement('test'), 'Element', '<test></test>'); | 
|  | test_replaceWith(document.createTextNode('test'), 'Text', 'test'); | 
|  |  | 
|  | </script> | 
|  | </html> |