Index: LayoutTests/fast/dom/ChildNode/replace-with.html |
diff --git a/LayoutTests/fast/dom/ChildNode/replace-with.html b/LayoutTests/fast/dom/ChildNode/replace-with.html |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f21e14af6a10531b385532a5140f42e251311bbf |
--- /dev/null |
+++ b/LayoutTests/fast/dom/ChildNode/replace-with.html |
@@ -0,0 +1,120 @@ |
+<!DOCTYPE html> |
+<script src="../../../resources/testharness.js"></script> |
+<script src="../../../resources/testharnessreport.js"></script> |
+<script> |
+ |
+function test_replaceWith(nodeName) { |
+ var child; |
+ var innerHTML; |
+ if (nodeName == 'Comment') { |
+ child = document.createComment('test'); |
+ innerHTML = '<!--test-->'; |
+ } else if (nodeName == 'Element') { |
+ child = document.createElement('test'); |
+ innerHTML = '<test></test>'; |
+ } else { |
+ child = document.createTextNode('test'); |
+ innerHTML = 'test'; |
+ } |
+ |
+ 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 an 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); |
+ var innerHTML = parent.innerHTML; |
+ 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 parenless child with two elements as arguments.'); |
+} |
+ |
+test_replaceWith('Comment'); |
+test_replaceWith('Element'); |
+test_replaceWith('Text'); |
+ |
+</script> |
+</html> |