Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(197)

Unified Diff: utils/tests/dartdoc/src/dartdoc_tests.dart

Issue 9555013: Get dartdoc in the SDK and working correctly. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Update copyright date. Created 8 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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>');
- });
- });
-}

Powered by Google App Engine
This is Rietveld 408576698