|  | // Copyright (c) 2011, the Dart project authors.  Please see the AUTHORS file | 
|  | // for details. All rights reserved. Use of this source code is governed by a | 
|  | // BSD-style license that can be found in the LICENSE file. | 
|  |  | 
|  | library DocumentFragmentTest; | 
|  | import 'package:unittest/unittest.dart'; | 
|  | import 'package:unittest/html_config.dart'; | 
|  | import 'util.dart'; | 
|  | import 'dart:html'; | 
|  |  | 
|  | main() { | 
|  | useHtmlConfiguration(); | 
|  |  | 
|  | var isAnchorElement = | 
|  | predicate((x) => x is AnchorElement, 'is an AnchorElement'); | 
|  |  | 
|  | List<String> _nodeStrings(Iterable<Node> input) { | 
|  | var out = new List<String>(); | 
|  | for (Node n in input) { | 
|  | if (n is Element) { | 
|  | Element e = n; | 
|  | out.add(e.tagName); | 
|  | } else { | 
|  | out.add(n.text); | 
|  | } | 
|  | } | 
|  | return out; | 
|  | }; | 
|  |  | 
|  | assertConstError(void fn()) { | 
|  | try { | 
|  | fn(); | 
|  | } catch (e) { | 
|  | if (e is UnsupportedError) { | 
|  | return; | 
|  | } | 
|  | } | 
|  | expect(true, isFalse, reason: 'Expected immutability error'); | 
|  | }; | 
|  |  | 
|  | void expectEmptyStyleDeclaration(CssStyleDeclaration style) { | 
|  | expect(style.cssText, equals('')); | 
|  | expect(style.getPropertyPriority('color'), equals('')); | 
|  | expect(style.item(0), equals('')); | 
|  | expect(style.length, isZero); | 
|  | // TODO(jacobr): these checks throw UnimplementedErrors in dartium. | 
|  | // expect(style.parentRule, isNull); | 
|  | // expect(style.getPropertyCssValue('color'), isNull); | 
|  | // expect(style.getPropertyShorthand('color'), isNull); | 
|  | // expect(style.isPropertyImplicit('color'), isFalse); | 
|  |  | 
|  | // Ideally these would throw errors, but it's not possible to create a class | 
|  | // that'll intercept these calls without implementing the entire | 
|  | // CssStyleDeclaration interface, so we'll settle for them being no-ops. | 
|  | style.cssText = '* {color: blue}'; | 
|  | style.removeProperty('color'); | 
|  | style.setProperty('color', 'blue'); | 
|  | } | 
|  |  | 
|  | group('constructors', () { | 
|  | test('0-argument makes an empty fragment', () { | 
|  | final fragment = new DocumentFragment(); | 
|  | expect(fragment.children, equals([])); | 
|  | }); | 
|  |  | 
|  | test('.html parses input as HTML', () { | 
|  | final fragment = new DocumentFragment.html('<a>foo</a>'); | 
|  | expect(fragment.children[0], isAnchorElement); | 
|  | }); | 
|  |  | 
|  | // test('.svg parses input as SVG', () { | 
|  | //   final fragment = new DocumentFragment.svg('<a>foo</a>'); | 
|  | //   expect(fragment.children[0] is SVGAElement, isTrue); | 
|  | // }); | 
|  |  | 
|  | // TODO(nweiz): enable this once XML is ported. | 
|  | // test('.xml parses input as XML', () { | 
|  | //   final fragment = new DocumentFragment.xml('<a>foo</a>'); | 
|  | //   expect(fragment.children[0] is XMLElement, isTrue); | 
|  | // }); | 
|  | }); | 
|  |  | 
|  | group('children', () { | 
|  | var fragment; | 
|  | var children; | 
|  |  | 
|  | init() { | 
|  | fragment = new DocumentFragment(); | 
|  | children = fragment.children; | 
|  | fragment.nodes.addAll( | 
|  | [new Text("1"), new Element.tag("A"), new Element.tag("B"), | 
|  | new Text("2"), new Element.tag("I"), new Text("3"), | 
|  | new Element.tag("U")]); | 
|  | }; | 
|  |  | 
|  | test('is initially empty', () { | 
|  | children = new DocumentFragment().children; | 
|  | expect(children, equals([])); | 
|  | expect(children.isEmpty, isTrue); | 
|  | }); | 
|  |  | 
|  | test('filters out non-element nodes', () { | 
|  | init(); | 
|  | expect(_nodeStrings(fragment.nodes), | 
|  | orderedEquals(["1", "A", "B", "2", "I", "3", "U"])); | 
|  | expect(_nodeStrings(children), | 
|  | orderedEquals(["A", "B", "I", "U"])); | 
|  | }); | 
|  |  | 
|  | test('only indexes children, not other nodes', () { | 
|  | init(); | 
|  | children[1] = new Element.tag("BR"); | 
|  | expect(_nodeStrings(fragment.nodes), | 
|  | orderedEquals(["1", "A", "BR", "2", "I", "3", "U"])); | 
|  | expect(_nodeStrings(children), | 
|  | orderedEquals(["A", "BR", "I", "U"])); | 
|  | }); | 
|  |  | 
|  | test('adds to both children and nodes', () { | 
|  | init(); | 
|  | children.add(new Element.tag("UL")); | 
|  | expect(_nodeStrings(fragment.nodes), | 
|  | orderedEquals(["1", "A", "B", "2", "I", "3", "U", "UL"])); | 
|  | expect(_nodeStrings(children), | 
|  | orderedEquals(["A", "B", "I", "U", "UL"])); | 
|  | }); | 
|  |  | 
|  | test('removes only children, from both children and nodes', () { | 
|  | init(); | 
|  | expect(children.removeLast().tagName, equals('U')); | 
|  | expect(_nodeStrings(fragment.nodes), | 
|  | orderedEquals(["1", "A", "B", "2", "I", "3"])); | 
|  | expect(_nodeStrings(children), | 
|  | orderedEquals(["A", "B", "I"])); | 
|  |  | 
|  | expect(children.removeLast().tagName, "I"); | 
|  | expect(_nodeStrings(fragment.nodes), | 
|  | equals(["1", "A", "B", "2", "3"])); | 
|  | expect(_nodeStrings(children), equals(["A", "B"])); | 
|  | }); | 
|  |  | 
|  | test('accessors are wrapped', () { | 
|  | init(); | 
|  | expect(children[0].tagName, "A"); | 
|  | expect(_nodeStrings(children.where((e) => e.tagName == "I")), ["I"]); | 
|  | expect(children.every((e) => e is Element), isTrue); | 
|  | expect(children.any((e) => e.tagName == "U"), isTrue); | 
|  | expect(children.isEmpty, isFalse); | 
|  | expect(children.length, 4); | 
|  | expect(children[2].tagName, "I"); | 
|  | expect(children.last.tagName, "U"); | 
|  | }); | 
|  |  | 
|  | test('setting children overwrites nodes as well', () { | 
|  | init(); | 
|  | fragment.children = [new Element.tag("DIV"), new Element.tag("HEAD")]; | 
|  | expect(_nodeStrings(fragment.nodes), equals(["DIV", "HEAD"])); | 
|  | }); | 
|  | }); | 
|  |  | 
|  | test('setting innerHtml works', () { | 
|  | var fragment = new DocumentFragment(); | 
|  | fragment.append(new Text("foo")); | 
|  | fragment.innerHtml = "<a>bar</a>baz"; | 
|  | expect(_nodeStrings(fragment.nodes), equals(["A", "baz"])); | 
|  | }); | 
|  |  | 
|  | test('getting innerHtml works', () { | 
|  | var fragment = new DocumentFragment(); | 
|  | fragment.nodes.addAll([new Text("foo"), new Element.html("<A>bar</A>")]); | 
|  | expect(fragment.innerHtml, "foo<a>bar</a>"); | 
|  | }); | 
|  |  | 
|  | test('query searches the fragment', () { | 
|  | var fragment = new DocumentFragment.html( | 
|  | "<div class='foo'><a>foo</a><b>bar</b></div>"); | 
|  | expect(fragment.query(".foo a").tagName, "A"); | 
|  | expect(_nodeStrings(fragment.queryAll(".foo *")), equals(["A", "B"])); | 
|  | }); | 
|  | } |