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

Unified Diff: test/codegen/lib/mirrors/instance_members_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/instance_members_test.dart
diff --git a/test/codegen/lib/mirrors/instance_members_test.dart b/test/codegen/lib/mirrors/instance_members_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..8f2f4773ee05a0e82161cded0071207fc3bf35b9
--- /dev/null
+++ b/test/codegen/lib/mirrors/instance_members_test.dart
@@ -0,0 +1,54 @@
+// Copyright (c) 2013, 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.instance_members;
+
+import 'dart:mirrors';
+import 'package:expect/expect.dart';
+
+import 'declarations_model.dart' as declarations_model;
+
+selectKeys(map, predicate) {
+ return map.keys.where((key) => predicate(map[key]));
+}
+
+main() {
+ ClassMirror cm = reflectClass(declarations_model.Class);
+
+ Expect.setEquals(
+ [#+,
+ #instanceVariable,
+ const Symbol('instanceVariable='),
+ #instanceGetter,
+ const Symbol('instanceSetter='),
+ #instanceMethod,
+ #-,
+ #inheritedInstanceVariable,
+ const Symbol('inheritedInstanceVariable='),
+ #inheritedInstanceGetter,
+ const Symbol('inheritedInstanceSetter='),
+ #inheritedInstanceMethod,
+ #*,
+ #mixinInstanceVariable,
+ const Symbol('mixinInstanceVariable='),
+ #mixinInstanceGetter,
+ const Symbol('mixinInstanceSetter='),
+ #mixinInstanceMethod,
+ #hashCode,
+ #runtimeType,
+ #==,
+ #noSuchMethod,
+ #toString],
+ selectKeys(cm.instanceMembers, (dm) => !dm.isPrivate));
+ // Filter out private to avoid implementation-specific members of Object.
+
+ Expect.setEquals(
+ [#instanceVariable,
+ const Symbol('instanceVariable='),
+ #inheritedInstanceVariable,
+ const Symbol('inheritedInstanceVariable='),
+ #mixinInstanceVariable,
+ const Symbol('mixinInstanceVariable=')],
+ selectKeys(cm.instanceMembers, (dm) => !dm.isPrivate && dm.isSynthetic));
+}

Powered by Google App Engine
This is Rietveld 408576698