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

Unified Diff: test/codegen/lib/mirrors/method_mirror_location_test.dart

Issue 2265533002: Add mirrors tests (Closed) Base URL: https://github.com/dart-lang/dev_compiler.git@master
Patch Set: Created 4 years, 4 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: test/codegen/lib/mirrors/method_mirror_location_test.dart
diff --git a/test/codegen/lib/mirrors/method_mirror_location_test.dart b/test/codegen/lib/mirrors/method_mirror_location_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..446f313877dbda7266b7bc911a50632d7017ecd1
--- /dev/null
+++ b/test/codegen/lib/mirrors/method_mirror_location_test.dart
@@ -0,0 +1,73 @@
+// Copyright (c) 2014, 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 test.method_location;
+
+import "dart:mirrors";
+import "package:expect/expect.dart";
+
+part 'method_mirror_location_other.dart';
+
+// We only check for a suffix of the uri because the test might be run from
+// any number of absolute paths.
+expectLocation(Mirror mirror, String uriSuffix, int line, int column) {
+ MethodMirror methodMirror;
+ if (mirror is ClosureMirror) {
+ methodMirror = mirror.function;
+ } else {
+ methodMirror = mirror as MethodMirror;
+ }
+ Expect.isTrue(methodMirror is MethodMirror);
+ Uri uri = methodMirror.location.sourceUri;
+ Expect.isTrue(uri.toString().endsWith(uriSuffix),
+ "Expected suffix $uriSuffix in $uri");
+ Expect.equals(line, methodMirror.location.line, "line");
+ Expect.equals(column, methodMirror.location.column, "column");
+}
+
+class ClassInMainFile {
+
+ ClassInMainFile();
+
+ method() {}
+}
+
+void topLevelInMainFile() {}
+ spaceIdentedInMainFile() {}
+ tabIdentedInMainFile() {}
+
+class HasImplicitConstructor {}
+
+typedef bool Predicate(num n);
+
+main() {
+ localFunction(x) { return x; }
+
+ String mainSuffix = 'method_mirror_location_test.dart';
+ String otherSuffix = 'method_mirror_location_other.dart';
+
+ // This file.
+ expectLocation(reflectClass(ClassInMainFile).declarations[#ClassInMainFile],
+ mainSuffix, 31, 3);
+ expectLocation(reflectClass(ClassInMainFile).declarations[#method],
+ mainSuffix, 33, 3);
+ expectLocation(reflect(topLevelInMainFile), mainSuffix, 36, 1);
+ expectLocation(reflect(spaceIdentedInMainFile), mainSuffix, 37, 3);
+ expectLocation(reflect(tabIdentedInMainFile), mainSuffix, 38, 2);
+ expectLocation(reflect(localFunction), mainSuffix, 45, 3);
+
+ // Another part.
+ expectLocation(reflectClass(ClassInOtherFile).declarations[#ClassInOtherFile],
+ otherSuffix, 9, 3);
+ expectLocation(reflectClass(ClassInOtherFile).declarations[#method],
+ otherSuffix, 11, 3);
+ expectLocation(reflect(topLevelInOtherFile), otherSuffix, 14, 1);
+ expectLocation(reflect(spaceIdentedInOtherFile), otherSuffix, 16, 3);
+ expectLocation(reflect(tabIdentedInOtherFile), otherSuffix, 18, 2);
+
+ // Synthetic methods.
+ Expect.isNull(reflectClass(HasImplicitConstructor)
+ .declarations[#HasImplicitConstructor].location);
+ Expect.isNull((reflectType(Predicate) as TypedefMirror).referent.callMethod.location);
+}
« no previous file with comments | « test/codegen/lib/mirrors/method_mirror_location_other.dart ('k') | test/codegen/lib/mirrors/method_mirror_name_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698