Index: test/codegen/language/call_function_test.dart |
diff --git a/test/codegen/language/call_function_test.dart b/test/codegen/language/call_function_test.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2f609dad6ab4ce9818dcf9fe534aae9126ed176a |
--- /dev/null |
+++ b/test/codegen/language/call_function_test.dart |
@@ -0,0 +1,32 @@ |
+// Copyright (c) 2015, 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. |
+ |
+import "package:expect/expect.dart"; |
+ |
+Object bar(Object x) { return x; } |
+ |
+Function baz = bar; |
+ |
+class Foo { |
+ Object call(Object x) { return 'Foo$x'; } |
+} |
+ |
+typedef Object FooType(Object x); |
+FooType foo = bar; |
+ |
+void main() { |
+ Expect.equals(42, bar.call(42)); |
Jennifer Messerly
2016/08/17 23:50:39
could you add a dynamic variant? e.g.
dynamic
|
+ Expect.equals(42, baz.call(42)); |
+ Expect.equals(42, foo.call(42)); |
+ Expect.equals(42, bar(42)); |
+ Expect.equals(42, baz(42)); |
+ Expect.equals(42, foo(42)); |
+ |
+ baz = new Foo(); |
+ foo = new Foo(); |
+ Expect.equals('Foo42', baz.call(42)); |
+ Expect.equals('Foo42', foo.call(42)); |
+ Expect.equals('Foo42', baz(42)); |
+ Expect.equals('Foo42', foo(42)); |
+} |