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

Side by Side Diff: tests/lib/mirrors/delegate_class_test.dart

Issue 1273983002: Hoist InstanceMirror.delegate to ObjectMirror. (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Created 5 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 unified diff | Download patch
« no previous file with comments | « tests/lib/lib.status ('k') | tests/lib/mirrors/delegate_library_test.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 library test.invoke_named_test; 5 library test.delegate_class;
6 6
7 import 'dart:mirrors'; 7 import 'dart:mirrors';
8 8
9 import 'package:expect/expect.dart'; 9 import 'package:expect/expect.dart';
10 10
11 class C { 11 class C {
12 method(a, b, c) => "$a-$b-$c"; 12 static method(a, b, c) => "$a-$b-$c";
13 methodWithNamed(a, {b:'B', c}) => "$a-$b-$c"; 13 static methodWithNamed(a, {b:'B', c}) => "$a-$b-$c";
14 methodWithOpt(a, [b, c='C']) => "$a-$b-$c"; 14 static methodWithOpt(a, [b, c='C']) => "$a-$b-$c";
15 get getter => 'g'; 15 static get getter => 'g';
16 set setter(x) { 16 static set setter(x) {
17 field = x*2; 17 field = x*2;
18 return 'unobservable value'; 18 return 'unobservable value';
19 } 19 }
20 var field; 20 static var field;
gbracha 2015/08/05 23:58:16 It would be nice to retain the instance level test
rmacnak 2015/08/06 00:01:11 The old test is not removed. Note Rietveld lists t
21 } 21 }
22 22
23 class Proxy { 23 class Proxy {
24 var targetMirror; 24 var targetMirror;
25 Proxy(target) : this.targetMirror = reflect(target); 25 Proxy(this.targetMirror);
26 noSuchMethod(invocation) => targetMirror.delegate(invocation); 26 noSuchMethod(invocation) => targetMirror.delegate(invocation);
27 } 27 }
28 28
29 main() { 29 main() {
30 var c = new C(); 30 var proxy = new Proxy(reflectClass(C));
31 var proxy = new Proxy(c);
32 var result; 31 var result;
33 32
34 Expect.equals('X-Y-Z', proxy.method('X', 'Y', 'Z')); 33 Expect.equals('X-Y-Z', proxy.method('X', 'Y', 'Z'));
35 34
36 Expect.equals('X-B-null', proxy.methodWithNamed('X')); 35 Expect.equals('X-B-null', proxy.methodWithNamed('X'));
37 Expect.equals('X-Y-null', proxy.methodWithNamed('X', b: 'Y')); 36 Expect.equals('X-Y-null', proxy.methodWithNamed('X', b: 'Y'));
38 Expect.equals('X-Y-Z', proxy.methodWithNamed('X', b: 'Y', c: 'Z')); 37 Expect.equals('X-Y-Z', proxy.methodWithNamed('X', b: 'Y', c: 'Z'));
39 38
40 Expect.equals('X-null-C', proxy.methodWithOpt('X')); 39 Expect.equals('X-null-C', proxy.methodWithOpt('X'));
41 Expect.equals('X-Y-C', proxy.methodWithOpt('X', 'Y')); 40 Expect.equals('X-Y-C', proxy.methodWithOpt('X', 'Y'));
42 Expect.equals('X-Y-Z', proxy.methodWithOpt('X', 'Y', 'Z')); 41 Expect.equals('X-Y-Z', proxy.methodWithOpt('X', 'Y', 'Z'));
43 42
44 Expect.equals('g', proxy.getter); 43 Expect.equals('g', proxy.getter);
45 44
46 Expect.equals(5, proxy.setter = 5); 45 Expect.equals(5, proxy.setter = 5);
47 Expect.equals(10, proxy.field); 46 Expect.equals(10, proxy.field);
48 47
49 Expect.equals(5, proxy.field = 5); 48 Expect.equals(5, proxy.field = 5);
50 Expect.equals(5, proxy.field); 49 Expect.equals(5, proxy.field);
51 } 50 }
OLDNEW
« no previous file with comments | « tests/lib/lib.status ('k') | tests/lib/mirrors/delegate_library_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698