| OLD | NEW |
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file | 3 // BSD-style license that can be found in the LICENSE file |
| 4 | 4 |
| 5 library ElementAddTest; | 5 library ElementAddTest; |
| 6 import '../../pkg/unittest/lib/unittest.dart'; | 6 import '../../pkg/unittest/lib/unittest.dart'; |
| 7 import '../../pkg/unittest/lib/html_config.dart'; | 7 import '../../pkg/unittest/lib/html_config.dart'; |
| 8 import 'dart:html'; | 8 import 'dart:html'; |
| 9 part 'util.dart'; | 9 part 'util.dart'; |
| 10 | 10 |
| 11 main() { | 11 main() { |
| 12 useHtmlConfiguration(); | 12 useHtmlConfiguration(); |
| 13 | 13 |
| 14 var isSpanElement = predicate((x) => x is SpanElement, 'is a SpanElemt'); | 14 var isSpanElement = predicate((x) => x is SpanElement, 'is a SpanElemt'); |
| 15 var isDivElement = predicate((x) => x is DivElement, 'is a DivElement'); | 15 var isDivElement = predicate((x) => x is DivElement, 'is a DivElement'); |
| 16 var isText = predicate((x) => x is Text, 'is a Text'); | 16 var isText = predicate((x) => x is Text, 'is a Text'); |
| 17 | 17 |
| 18 void expectNoSuchMethod(void fn()) => | 18 void expectNoSuchMethod(void fn()) => |
| 19 expect(fn, throwsNoSuchMethodError); | 19 expect(fn, throwsNoSuchMethodError); |
| 20 | 20 |
| 21 group('addHtml', () { | 21 group('addHtml', () { |
| 22 test('htmlelement', () { | 22 test('htmlelement', () { |
| 23 var el = new DivElement(); | 23 var el = new DivElement(); |
| 24 el.addHtml('<span></span>'); | 24 el.addHtml('<span></span>'); |
| 25 expect(el.elements.length, equals(1)); | 25 expect(el.children.length, equals(1)); |
| 26 var span = el.elements[0]; | 26 var span = el.children[0]; |
| 27 expect(span, isSpanElement); | 27 expect(span, isSpanElement); |
| 28 | 28 |
| 29 el.addHtml('<div></div>'); | 29 el.addHtml('<div></div>'); |
| 30 expect(el.elements.length, equals(2)); | 30 expect(el.children.length, equals(2)); |
| 31 // Validate that the first item is still first. | 31 // Validate that the first item is still first. |
| 32 expect(el.elements[0], equals(span)); | 32 expect(el.children[0], equals(span)); |
| 33 expect(el.elements[1], isDivElement); | 33 expect(el.children[1], isDivElement); |
| 34 }); | 34 }); |
| 35 | 35 |
| 36 test('documentFragment', () { | 36 test('documentFragment', () { |
| 37 var fragment = new DocumentFragment(); | 37 var fragment = new DocumentFragment(); |
| 38 fragment.addHtml('<span>something</span>'); | 38 fragment.addHtml('<span>something</span>'); |
| 39 expect(fragment.elements.length, equals(1)); | 39 expect(fragment.children.length, equals(1)); |
| 40 expect(fragment.elements[0], isSpanElement); | 40 expect(fragment.children[0], isSpanElement); |
| 41 }); | 41 }); |
| 42 }); | 42 }); |
| 43 | 43 |
| 44 group('addText', () { | 44 group('addText', () { |
| 45 test('htmlelement', () { | 45 test('htmlelement', () { |
| 46 var el = new DivElement(); | 46 var el = new DivElement(); |
| 47 el.addText('foo'); | 47 el.addText('foo'); |
| 48 // No elements were created. | 48 // No children were created. |
| 49 expect(el.elements.length, equals(0)); | 49 expect(el.children.length, equals(0)); |
| 50 // One text node was added. | 50 // One text node was added. |
| 51 expect(el.nodes.length, equals(1)); | 51 expect(el.nodes.length, equals(1)); |
| 52 }); | 52 }); |
| 53 | 53 |
| 54 test('documentFragment', () { | 54 test('documentFragment', () { |
| 55 var fragment = new DocumentFragment(); | 55 var fragment = new DocumentFragment(); |
| 56 fragment.addText('foo'); | 56 fragment.addText('foo'); |
| 57 // No elements were created. | 57 // No children were created. |
| 58 expect(fragment.elements.length, equals(0)); | 58 expect(fragment.children.length, equals(0)); |
| 59 // One text node was added. | 59 // One text node was added. |
| 60 expect(fragment.nodes.length, equals(1)); | 60 expect(fragment.nodes.length, equals(1)); |
| 61 }); | 61 }); |
| 62 }); | 62 }); |
| 63 | 63 |
| 64 group('insertAdjacentElement', () { | 64 group('insertAdjacentElement', () { |
| 65 test('beforebegin', () { | 65 test('beforebegin', () { |
| 66 var parent = new DivElement(); | 66 var parent = new DivElement(); |
| 67 var child = new DivElement(); | 67 var child = new DivElement(); |
| 68 var newChild = new SpanElement(); | 68 var newChild = new SpanElement(); |
| 69 parent.elements.add(child); | 69 parent.children.add(child); |
| 70 | 70 |
| 71 child.insertAdjacentElement('beforebegin', newChild); | 71 child.insertAdjacentElement('beforebegin', newChild); |
| 72 | 72 |
| 73 expect(parent.elements.length, 2); | 73 expect(parent.children.length, 2); |
| 74 expect(parent.elements[0], isSpanElement); | 74 expect(parent.children[0], isSpanElement); |
| 75 }); | 75 }); |
| 76 | 76 |
| 77 test('afterend', () { | 77 test('afterend', () { |
| 78 var parent = new DivElement(); | 78 var parent = new DivElement(); |
| 79 var child = new DivElement(); | 79 var child = new DivElement(); |
| 80 var newChild = new SpanElement(); | 80 var newChild = new SpanElement(); |
| 81 parent.elements.add(child); | 81 parent.children.add(child); |
| 82 | 82 |
| 83 child.insertAdjacentElement('afterend', newChild); | 83 child.insertAdjacentElement('afterend', newChild); |
| 84 | 84 |
| 85 expect(parent.elements.length, 2); | 85 expect(parent.children.length, 2); |
| 86 expect(parent.elements[1], isSpanElement); | 86 expect(parent.children[1], isSpanElement); |
| 87 }); | 87 }); |
| 88 | 88 |
| 89 test('afterbegin', () { | 89 test('afterbegin', () { |
| 90 var parent = new DivElement(); | 90 var parent = new DivElement(); |
| 91 var child = new DivElement(); | 91 var child = new DivElement(); |
| 92 var newChild = new SpanElement(); | 92 var newChild = new SpanElement(); |
| 93 parent.elements.add(child); | 93 parent.children.add(child); |
| 94 | 94 |
| 95 parent.insertAdjacentElement('afterbegin', newChild); | 95 parent.insertAdjacentElement('afterbegin', newChild); |
| 96 | 96 |
| 97 expect(parent.elements.length, 2); | 97 expect(parent.children.length, 2); |
| 98 expect(parent.elements[0], isSpanElement); | 98 expect(parent.children[0], isSpanElement); |
| 99 }); | 99 }); |
| 100 | 100 |
| 101 test('beforeend', () { | 101 test('beforeend', () { |
| 102 var parent = new DivElement(); | 102 var parent = new DivElement(); |
| 103 var child = new DivElement(); | 103 var child = new DivElement(); |
| 104 var newChild = new SpanElement(); | 104 var newChild = new SpanElement(); |
| 105 parent.elements.add(child); | 105 parent.children.add(child); |
| 106 | 106 |
| 107 parent.insertAdjacentElement('beforeend', newChild); | 107 parent.insertAdjacentElement('beforeend', newChild); |
| 108 | 108 |
| 109 expect(parent.elements.length, 2); | 109 expect(parent.children.length, 2); |
| 110 expect(parent.elements[1], isSpanElement); | 110 expect(parent.children[1], isSpanElement); |
| 111 }); | 111 }); |
| 112 }); | 112 }); |
| 113 | 113 |
| 114 group('insertAdjacentHTML', () { | 114 group('insertAdjacentHTML', () { |
| 115 test('beforebegin', () { | 115 test('beforebegin', () { |
| 116 var parent = new DivElement(); | 116 var parent = new DivElement(); |
| 117 var child = new DivElement(); | 117 var child = new DivElement(); |
| 118 parent.elements.add(child); | 118 parent.children.add(child); |
| 119 | 119 |
| 120 child.insertAdjacentHTML('beforebegin', '<span></span>'); | 120 child.insertAdjacentHTML('beforebegin', '<span></span>'); |
| 121 | 121 |
| 122 expect(parent.elements.length, 2); | 122 expect(parent.children.length, 2); |
| 123 expect(parent.elements[0], isSpanElement); | 123 expect(parent.children[0], isSpanElement); |
| 124 }); | 124 }); |
| 125 | 125 |
| 126 test('afterend', () { | 126 test('afterend', () { |
| 127 var parent = new DivElement(); | 127 var parent = new DivElement(); |
| 128 var child = new DivElement(); | 128 var child = new DivElement(); |
| 129 parent.elements.add(child); | 129 parent.children.add(child); |
| 130 | 130 |
| 131 child.insertAdjacentHTML('afterend', '<span></span>'); | 131 child.insertAdjacentHTML('afterend', '<span></span>'); |
| 132 | 132 |
| 133 expect(parent.elements.length, 2); | 133 expect(parent.children.length, 2); |
| 134 expect(parent.elements[1], isSpanElement); | 134 expect(parent.children[1], isSpanElement); |
| 135 }); | 135 }); |
| 136 | 136 |
| 137 test('afterbegin', () { | 137 test('afterbegin', () { |
| 138 var parent = new DivElement(); | 138 var parent = new DivElement(); |
| 139 var child = new DivElement(); | 139 var child = new DivElement(); |
| 140 parent.elements.add(child); | 140 parent.children.add(child); |
| 141 | 141 |
| 142 parent.insertAdjacentHTML('afterbegin', '<span></span>'); | 142 parent.insertAdjacentHTML('afterbegin', '<span></span>'); |
| 143 | 143 |
| 144 expect(parent.elements.length, 2); | 144 expect(parent.children.length, 2); |
| 145 expect(parent.elements[0], isSpanElement); | 145 expect(parent.children[0], isSpanElement); |
| 146 }); | 146 }); |
| 147 | 147 |
| 148 test('beforeend', () { | 148 test('beforeend', () { |
| 149 var parent = new DivElement(); | 149 var parent = new DivElement(); |
| 150 var child = new DivElement(); | 150 var child = new DivElement(); |
| 151 parent.elements.add(child); | 151 parent.children.add(child); |
| 152 | 152 |
| 153 parent.insertAdjacentHTML('beforeend', '<span></span>'); | 153 parent.insertAdjacentHTML('beforeend', '<span></span>'); |
| 154 | 154 |
| 155 expect(parent.elements.length, 2); | 155 expect(parent.children.length, 2); |
| 156 expect(parent.elements[1], isSpanElement); | 156 expect(parent.children[1], isSpanElement); |
| 157 }); | 157 }); |
| 158 }); | 158 }); |
| 159 | 159 |
| 160 group('insertAdjacentText', () { | 160 group('insertAdjacentText', () { |
| 161 test('beforebegin', () { | 161 test('beforebegin', () { |
| 162 var parent = new DivElement(); | 162 var parent = new DivElement(); |
| 163 var child = new DivElement(); | 163 var child = new DivElement(); |
| 164 parent.elements.add(child); | 164 parent.children.add(child); |
| 165 | 165 |
| 166 child.insertAdjacentText('beforebegin', 'test'); | 166 child.insertAdjacentText('beforebegin', 'test'); |
| 167 | 167 |
| 168 expect(parent.nodes.length, 2); | 168 expect(parent.nodes.length, 2); |
| 169 expect(parent.nodes[0], isText); | 169 expect(parent.nodes[0], isText); |
| 170 }); | 170 }); |
| 171 | 171 |
| 172 test('afterend', () { | 172 test('afterend', () { |
| 173 var parent = new DivElement(); | 173 var parent = new DivElement(); |
| 174 var child = new DivElement(); | 174 var child = new DivElement(); |
| 175 parent.elements.add(child); | 175 parent.children.add(child); |
| 176 | 176 |
| 177 child.insertAdjacentText('afterend', 'test'); | 177 child.insertAdjacentText('afterend', 'test'); |
| 178 | 178 |
| 179 expect(parent.nodes.length, 2); | 179 expect(parent.nodes.length, 2); |
| 180 expect(parent.nodes[1], isText); | 180 expect(parent.nodes[1], isText); |
| 181 }); | 181 }); |
| 182 | 182 |
| 183 test('afterbegin', () { | 183 test('afterbegin', () { |
| 184 var parent = new DivElement(); | 184 var parent = new DivElement(); |
| 185 var child = new DivElement(); | 185 var child = new DivElement(); |
| 186 parent.elements.add(child); | 186 parent.children.add(child); |
| 187 | 187 |
| 188 parent.insertAdjacentText('afterbegin', 'test'); | 188 parent.insertAdjacentText('afterbegin', 'test'); |
| 189 | 189 |
| 190 expect(parent.nodes.length, 2); | 190 expect(parent.nodes.length, 2); |
| 191 expect(parent.nodes[0], isText); | 191 expect(parent.nodes[0], isText); |
| 192 }); | 192 }); |
| 193 | 193 |
| 194 test('beforeend', () { | 194 test('beforeend', () { |
| 195 var parent = new DivElement(); | 195 var parent = new DivElement(); |
| 196 var child = new DivElement(); | 196 var child = new DivElement(); |
| 197 parent.elements.add(child); | 197 parent.children.add(child); |
| 198 | 198 |
| 199 parent.insertAdjacentText('beforeend', 'test'); | 199 parent.insertAdjacentText('beforeend', 'test'); |
| 200 | 200 |
| 201 expect(parent.nodes.length, 2); | 201 expect(parent.nodes.length, 2); |
| 202 expect(parent.nodes[1], isText); | 202 expect(parent.nodes[1], isText); |
| 203 }); | 203 }); |
| 204 }); | 204 }); |
| 205 } | 205 } |
| OLD | NEW |