Chromium Code Reviews| Index: tests/language/no_such_method_dispatcher_test.dart |
| =================================================================== |
| --- tests/language/no_such_method_dispatcher_test.dart (revision 24510) |
| +++ tests/language/no_such_method_dispatcher_test.dart (working copy) |
| @@ -16,6 +16,35 @@ |
| class B extends A { } |
| + |
| +call_bar(x) => x.bar(); |
| + |
| +testMessage() { |
| + try { |
| + call_bar(5); |
| + } catch (e) { |
| + Expect.isTrue(e.toString().indexOf("method not found") != -1); |
|
ahe
2013/07/20 17:24:27
I'm working on improving dart2js' handling of NoSu
|
| + } |
| +} |
| + |
| +class C { |
| + C(this.pos, this.named, this.posArgs, this.namedArgs); |
| + var pos, named; |
| + noSuchMethod(m) { |
| + Expect.equals(pos, m.positionalArguments.length); |
| + Expect.equals(named, m.namedArguments.length); |
| + for (var i = 0; i < posArgs.length; ++i) { |
| + Expect.equals(posArgs[i], m.positionalArguments[i]); |
| + } |
| + for (var k in namedArgs.keys) { |
| + Expect.equals(namedArgs[k], m.namedArguments[new Symbol(k)]); |
| + } |
| + return 123; |
| + } |
| + List posArgs; |
| + Map namedArgs; |
| +} |
| + |
| main() { |
| var a = new A(); |
| for (var i = 0; i < 100; ++i) Expect.equals(123, a.foo()); |
| @@ -28,5 +57,21 @@ |
| Expect.equals(123, b.bar()); |
| Expect.equals(2, b.bar(1)); |
| } |
| + |
| + for (var i = 0; i < 100; ++i) { |
| + Expect.equals(123, b.bar(1,2,3)); |
| + Expect.equals(123, b.bar(1,2,foo:3)); |
| + } |
| + |
| + // Test named and positional arguments. |
| + var c = new C(1, 2, [100], {"n1":101, "n2":102}); |
| + for (var i = 0; i < 100; ++i) { |
| + Expect.equals(123, c.bar(100, n1:101, n2:102)); |
| + Expect.equals(123, c.bar(100, n2:102, n1:101)); |
| + } |
| + |
| + // Test NoSuchMethodError message. |
| + for (var i = 0; i < 100; i++) testMessage(); |
| + |
| } |