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

Unified Diff: pkg/unittest/mock.dart

Issue 11231074: Change signature of noSuchMethod to take an InvocationMirror. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Merged dart2js changes into this CL. Created 8 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: pkg/unittest/mock.dart
diff --git a/pkg/unittest/mock.dart b/pkg/unittest/mock.dart
index dd2ae539b7956b74ad9a9943f3fdd692c152558c..3b8d58bc264855d6f6f9dadeea49e7f7ff864841 100644
--- a/pkg/unittest/mock.dart
+++ b/pkg/unittest/mock.dart
@@ -1274,10 +1274,17 @@ class Mock {
* return value. If we find no [Behavior] to apply an exception is
* thrown.
*/
- noSuchMethod(String method, List args) {
- if (method.startsWith('get:')) {
- method = 'get ${method.substring(4)}';
+ noSuchMethod(InvocationMirror invocation) {
+ String method = invocation.methodName;
+ // Remove this when InvocationMirror works correctly.
+ if (method.startsWith("get:")) method = method.substring(4);
+
+ if (invocation.isGetter) {
+ method = 'get $method';
}
+ List args = invocation.positionalArguments;
+ // TODO: Handle named arguments too.
+
bool matchedMethodName = false;
MatchState matchState = new MatchState();
for (String k in _behaviors.keys) {

Powered by Google App Engine
This is Rietveld 408576698