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

Unified Diff: tests/lib/mirrors/toplevel_members_test.dart

Issue 44813004: Tests for instanceMembers, staticMembers, toplevelMembers. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 2 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: tests/lib/mirrors/toplevel_members_test.dart
diff --git a/tests/lib/mirrors/toplevel_members_test.dart b/tests/lib/mirrors/toplevel_members_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..8638b9a539535131ff5f663e55066c9a8f4fbf86
--- /dev/null
+++ b/tests/lib/mirrors/toplevel_members_test.dart
@@ -0,0 +1,52 @@
+// 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.toplevel_members;
+
+import 'dart:mirrors';
+import 'package:expect/expect.dart';
+
+import 'stringify.dart';
+import 'declarations_model.dart' as declarations_model;
+
+selectKeys(map, predicate) {
+ return map.keys.where((key) => predicate(map[key]));
+}
+
+main() {
+ LibraryMirror lm =
+ currentMirrorSystem().findLibrary(#test.declarations_model).single;
+
+ Expect.setEquals(
+ [#libraryVariable,
+ const Symbol('libraryVariable='),
+ #libraryGetter,
+ const Symbol('librarySetter='),
+ #libraryMethod,
+ #_libraryVariable,
+ const Symbol('_libraryVariable='),
+ #_libraryGetter,
+ const Symbol('_librarySetter='),
+ #_libraryMethod,
+ #Predicate,
rmacnak 2013/10/25 21:58:36 ?
gbracha 2013/10/26 18:37:48 So the notion of API for a library is alas hazy.
rmacnak 2013/10/30 18:50:42 I'm thinking this should behave how a prefix would
+ #Superclass,
+ #Interface,
+ #Mixin,
+ #_PrivateClass,
+ #ConcreteClass],
+ selectKeys(lm.toplevelMembers, (dm) => true);
+
+ Expect.setEquals(
+ [#libraryVariable,
+ const Symbol('libraryVariable='),
+ #_libraryVariable,
+ const Symbol('_libraryVariable='),
+ #Predicate,
gbracha 2013/10/26 18:37:48 So are all the type getters synthetic? I'm not so
rmacnak 2013/10/30 18:50:42 They weren't hand-written. The Newspeak mirrors d
rmacnak 2013/10/30 18:51:58 It would also allow the maps to provide the functi
gbracha 2013/10/30 18:58:40 Since this is topLevelMembers, not declarations, I
+ #Superclass,
+ #Interface,
+ #Mixin,
+ #_PrivateClass,
+ #ConcreteClass],
+ selectKeys(lm.toplevelMembers, (dm) => dm.isSynthetic));
+}

Powered by Google App Engine
This is Rietveld 408576698