| Index: utils/tests/dartdoc/src/dartdoc_tests.dart | 
| diff --git a/utils/tests/dartdoc/src/dartdoc_tests.dart b/utils/tests/dartdoc/src/dartdoc_tests.dart | 
| deleted file mode 100644 | 
| index f464cd1daf8cf1fe973307e7f62bbd239df03460..0000000000000000000000000000000000000000 | 
| --- a/utils/tests/dartdoc/src/dartdoc_tests.dart | 
| +++ /dev/null | 
| @@ -1,224 +0,0 @@ | 
| -// Copyright (c) 2012, 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. | 
| - | 
| -/// Unit tests for doc. | 
| -#library('dartdoc_tests'); | 
| - | 
| -#import('../../../dartdoc/dartdoc.dart', prefix: 'dd'); | 
| -#import('../../../dartdoc/markdown.dart', prefix: 'md'); | 
| - | 
| -// TODO(rnystrom): Better path to unittest. | 
| -#import('../../../../client/testing/unittest/unittest_vm.dart'); | 
| -#import('../../../../frog/lang.dart'); | 
| -#import('../../../../frog/file_system_vm.dart'); | 
| - | 
| -main() { | 
| -  var files = new VMFileSystem(); | 
| -  parseOptions('../../frog', [], files); | 
| -  initializeWorld(files); | 
| - | 
| -  group('countOccurrences', () { | 
| -    test('empty text returns 0', () { | 
| -      expect(dd.countOccurrences('', 'needle')).equals(0); | 
| -    }); | 
| - | 
| -    test('one occurrence', () { | 
| -      expect(dd.countOccurrences('bananarama', 'nara')).equals(1); | 
| -    }); | 
| - | 
| -    test('multiple occurrences', () { | 
| -      expect(dd.countOccurrences('bananarama', 'a')).equals(5); | 
| -    }); | 
| - | 
| -    test('overlapping matches do not count', () { | 
| -      expect(dd.countOccurrences('bananarama', 'ana')).equals(1); | 
| -    }); | 
| -  }); | 
| - | 
| -  group('repeat', () { | 
| -    test('zero times returns an empty string', () { | 
| -      expect(dd.repeat('ba', 0)).equals(''); | 
| -    }); | 
| - | 
| -    test('one time returns the string', () { | 
| -      expect(dd.repeat('ba', 1)).equals('ba'); | 
| -    }); | 
| - | 
| -    test('multiple times', () { | 
| -      expect(dd.repeat('ba', 3)).equals('bababa'); | 
| -    }); | 
| - | 
| -    test('multiple times with a separator', () { | 
| -      expect(dd.repeat('ba', 3, separator: ' ')).equals('ba ba ba'); | 
| -    }); | 
| -  }); | 
| - | 
| -  group('isAbsolute', () { | 
| -    final doc = new dd.Dartdoc(); | 
| - | 
| -    test('returns false if there is no scheme', () { | 
| -      expect(doc.isAbsolute('index.html')).isFalse(); | 
| -      expect(doc.isAbsolute('foo/index.html')).isFalse(); | 
| -      expect(doc.isAbsolute('foo/bar/index.html')).isFalse(); | 
| -    }); | 
| - | 
| -    test('returns true if there is a scheme', () { | 
| -      expect(doc.isAbsolute('http://google.com')).isTrue(); | 
| -      expect(doc.isAbsolute('hTtPs://google.com')).isTrue(); | 
| -      expect(doc.isAbsolute('mailto:fake@email.com')).isTrue(); | 
| -    }); | 
| -  }); | 
| - | 
| -  group('relativePath', () { | 
| -    final doc = new dd.Dartdoc(); | 
| - | 
| -    test('absolute path is unchanged', () { | 
| -      doc.startFile('dir/sub/file.html'); | 
| -      expect(doc.relativePath('http://foo.com')).equals('http://foo.com'); | 
| -    }); | 
| - | 
| -    test('from root to root', () { | 
| -      doc.startFile('root.html'); | 
| -      expect(doc.relativePath('other.html')).equals('other.html'); | 
| -    }); | 
| - | 
| -    test('from root to directory', () { | 
| -      doc.startFile('root.html'); | 
| -      expect(doc.relativePath('dir/file.html')).equals('dir/file.html'); | 
| -    }); | 
| - | 
| -    test('from root to nested', () { | 
| -      doc.startFile('root.html'); | 
| -      expect(doc.relativePath('dir/sub/file.html')).equals( | 
| -          'dir/sub/file.html'); | 
| -    }); | 
| - | 
| -    test('from directory to root', () { | 
| -      doc.startFile('dir/file.html'); | 
| -      expect(doc.relativePath('root.html')).equals('../root.html'); | 
| -    }); | 
| - | 
| -    test('from nested to root', () { | 
| -      doc.startFile('dir/sub/file.html'); | 
| -      expect(doc.relativePath('root.html')).equals('../../root.html'); | 
| -    }); | 
| - | 
| -    test('from dir to dir with different path', () { | 
| -      doc.startFile('dir/file.html'); | 
| -      expect(doc.relativePath('other/file.html')).equals( | 
| -          '../other/file.html'); | 
| -    }); | 
| - | 
| -    test('from nested to nested with different path', () { | 
| -      doc.startFile('dir/sub/file.html'); | 
| -      expect(doc.relativePath('other/sub/file.html')).equals( | 
| -          '../../other/sub/file.html'); | 
| -    }); | 
| - | 
| -    test('from nested to directory with different path', () { | 
| -      doc.startFile('dir/sub/file.html'); | 
| -      expect(doc.relativePath('other/file.html')).equals( | 
| -          '../../other/file.html'); | 
| -    }); | 
| -  }); | 
| - | 
| -  group('name reference', () { | 
| -    // TODO(rnystrom): The paths here are a bit strange. They're relative to | 
| -    // where test.dart happens to be invoked from. | 
| -    final dummyPath = 'utils/tests/dartdoc/src/dummy.dart'; | 
| - | 
| -    // TODO(rnystrom): Bail if we couldn't find the test file. The problem is | 
| -    // that loading dummy.dart is sensitive to the location that dart was | 
| -    // *invoked* from and not relative to *this* file like we'd like. That | 
| -    // means these tests only run correctly from one place. Unfortunately, | 
| -    // test.py/test.dart runs this from one directory and frog/presubmit.py | 
| -    // runs it from another. | 
| -    // See Bug 1145. | 
| -    var fileSystem = new VMFileSystem(); | 
| -    if (!fileSystem.fileExists(dummyPath)) { | 
| -      print("Can't run dartdoc name reference tests because dummy.dart " + | 
| -          "could not be found."); | 
| -      return; | 
| -    } | 
| - | 
| -    var doc = new dd.Dartdoc(); | 
| -    doc.startFile('someLib/someType.html'); | 
| - | 
| -    world.processDartScript(dummyPath); | 
| -    world.resolveAll(); | 
| -    var dummy = world.libraries[dummyPath]; | 
| -    var klass = dummy.findTypeByName('Class'); | 
| -    var method = klass.getMember('method'); | 
| - | 
| -    String render(md.Node node) => md.renderToHtml([node]); | 
| - | 
| -    test('to a parameter of the current method', () { | 
| -      expect(render(doc.resolveNameReference('param', member: method))). | 
| -        equals('<span class="param">param</span>'); | 
| -    }); | 
| - | 
| -    test('to a member of the current type', () { | 
| -      expect(render(doc.resolveNameReference('method', type: klass))). | 
| -        equals('<a class="crossref" href="../dummy/Class.html#method">' + | 
| -            'method</a>'); | 
| -    }); | 
| - | 
| -    test('to a property with only a getter links to the getter', () { | 
| -      expect(render(doc.resolveNameReference('getterOnly', type: klass))). | 
| -        equals('<a class="crossref" ' + | 
| -            'href="../dummy/Class.html#get:getterOnly">getterOnly</a>'); | 
| -    }); | 
| - | 
| -    test('to a property with only a setter links to the setter', () { | 
| -      expect(render(doc.resolveNameReference('setterOnly', type: klass))). | 
| -        equals('<a class="crossref" ' + | 
| -            'href="../dummy/Class.html#set:setterOnly">setterOnly</a>'); | 
| -    }); | 
| - | 
| -    test('to a property with a getter and setter links to the getter', () { | 
| -      expect(render(doc.resolveNameReference('getterAndSetter', type: klass))). | 
| -        equals('<a class="crossref" ' + | 
| -            'href="../dummy/Class.html#get:getterAndSetter">' + | 
| -            'getterAndSetter</a>'); | 
| -    }); | 
| - | 
| -    test('to a type in the current library', () { | 
| -      expect(render(doc.resolveNameReference('Class', library: dummy))). | 
| -        equals('<a class="crossref" href="../dummy/Class.html">Class</a>'); | 
| -    }); | 
| - | 
| -    test('to a top-level member in the current library', () { | 
| -      expect(render(doc.resolveNameReference('topLevelMethod', | 
| -                  library: dummy))). | 
| -        equals('<a class="crossref" href="../dummy.html#topLevelMethod">' + | 
| -            'topLevelMethod</a>'); | 
| -    }); | 
| - | 
| -    test('to an unknown name', () { | 
| -      expect(render(doc.resolveNameReference('unknownName', library: dummy, | 
| -                  type: klass, member: method))). | 
| -        equals('<code>unknownName</code>'); | 
| -    }); | 
| - | 
| -    test('to a member of another class', () { | 
| -      expect(render(doc.resolveNameReference('Class.method', library: dummy))). | 
| -        equals('<a class="crossref" href="../dummy/Class.html#method">' + | 
| -            'Class.method</a>'); | 
| -    }); | 
| - | 
| -    test('to a constructor', () { | 
| -      expect(render(doc.resolveNameReference('new Class', library: dummy))). | 
| -        equals('<a class="crossref" href="../dummy/Class.html#new:Class">' + | 
| -            'new Class</a>'); | 
| -    }); | 
| - | 
| -    test('to a named constructor', () { | 
| -      expect(render(doc.resolveNameReference('new Class.namedConstructor', | 
| -                  library: dummy))). | 
| -        equals('<a class="crossref" ' + | 
| -            'href="../dummy/Class.html#new:Class.namedConstructor">new ' + | 
| -            'Class.namedConstructor</a>'); | 
| -    }); | 
| -  }); | 
| -} | 
|  |