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

Unified Diff: tests/compiler/dart2js_native/apply_test.dart

Issue 11093015: Implement Function.apply in dart2js. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: 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: tests/compiler/dart2js_native/apply_test.dart
===================================================================
--- tests/compiler/dart2js_native/apply_test.dart (revision 13403)
+++ tests/compiler/dart2js_native/apply_test.dart (working copy)
@@ -1,135 +0,0 @@
-// Copyright (c) 2012, 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.
-//
-// This test should move to a language test once the apply method
-// gets into the specification.
-
-apply(Function function, ArgumentDescriptor args) {
- int argumentCount = 0;
- StringBuffer buffer = new StringBuffer();
- List arguments = [];
-
- if (args.positionalArguments != null) {
- argumentCount += args.positionalArguments.length;
- arguments.addAll(args.positionalArguments);
- }
-
- // Sort the named arguments to get the right selector name and
- // arguments order.
- if (args.namedArguments != null && !args.namedArguments.isEmpty()) {
- // Call new List.from to make sure we get a JavaScript array.
- List<String> namedArguments =
- new List<String>.from(args.namedArguments.getKeys());
- argumentCount += namedArguments.length;
- // We're sorting on strings, and the behavior is the same between
- // Dart string sort and JS String sort. To avoid needing the Dart
- // sort implementation, we use the JavaScript one instead.
- JS('void', '#.sort()', namedArguments);
- namedArguments.forEach((String name) {
- buffer.add('\$$name');
- arguments.add(args.namedArguments[name]);
- });
- }
-
- String selectorName = 'call\$$argumentCount$buffer';
- var jsFunction = JS('var', '#[#]', function, selectorName);
- if (jsFunction == null) {
- throw new NoSuchMethodError(function, selectorName, arguments);
- }
- // We bound 'this' to [function] because of how we compile
- // closures: escaped local variables are stored and accessed through
- // [function].
- return JS('var', '#.apply(#, #)', jsFunction, function, arguments);
-}
-
-class ArgumentDescriptor {
- final List positionalArguments;
- final Map<String, Dynamic> namedArguments;
-
- ArgumentDescriptor(this.positionalArguments, this.namedArguments);
-}
-
-void throwsNSME(function) {
- Expect.throws(function, (e) => e is NoSuchMethodError);
-}
-
-main() {
- var c1 = () => 'c1';
- var c2 = (a) => 'c2 $a';
- var c3 = ([a = 1]) => 'c3 $a';
- var c4 = ({a: 1}) => 'c4 $a';
- var c5 = ({a: 1, b: 2}) => 'c5 $a $b';
- var c6 = ({b: 1, a: 2}) => 'c6 $a $b';
-
- // TODO(ngeoffray): Remove these calls. They are currently needed
- // because otherwise we would not generate the stubs. Once apply is
- // in the specification, we should change the compiler to emit stubs
- // for closures once it sees an 'apply' selector.
- c1();
- c2(1);
- c3(); c3(1);
- c4(); c4(a: 1);
- c5(); c5(a: 1); c5(b: 2); c5(a:1, b: 2);
- c6(); c6(a: 1); c6(b: 2); c6(a:1, b: 2);
-
- Expect.equals('c1', apply(c1, new ArgumentDescriptor(null, null)));
- Expect.equals('c1', apply(c1, new ArgumentDescriptor([], null)));
- Expect.equals('c1', apply(c1, new ArgumentDescriptor([], {})));
- Expect.equals('c1', apply(c1, new ArgumentDescriptor(null, {})));
- throwsNSME(() => apply(c1, new ArgumentDescriptor([1], null)));
- throwsNSME(() => apply(c1, new ArgumentDescriptor([1], {'a': 2})));
- throwsNSME(() => apply(c1, new ArgumentDescriptor(null, {'a': 2})));
-
- Expect.equals('c2 1', apply(c2, new ArgumentDescriptor([1], null)));
- Expect.equals('c2 1', apply(c2, new ArgumentDescriptor([1], {})));
- throwsNSME(() => apply(c2, new ArgumentDescriptor(null, null)));
- throwsNSME(() => apply(c2, new ArgumentDescriptor([], null)));
- throwsNSME(() => apply(c2, new ArgumentDescriptor(null, {})));
- throwsNSME(() => apply(c2, new ArgumentDescriptor(null, {'a': 1})));
-
- Expect.equals('c3 1', apply(c3, new ArgumentDescriptor([], null)));
- Expect.equals('c3 2', apply(c3, new ArgumentDescriptor([2], {})));
- throwsNSME(() => apply(c3, new ArgumentDescriptor([1, 2], null)));
- // TODO(ngeoffray): Should be throwsNSME with the new parameter
- // specification.
- Expect.equals('c3 1', apply(c3, new ArgumentDescriptor(null, {'a': 1})));
-
- Expect.equals('c4 1', apply(c4, new ArgumentDescriptor([], null)));
- Expect.equals('c4 2', apply(c4, new ArgumentDescriptor([], {'a': 2})));
- Expect.equals('c4 1', apply(c4, new ArgumentDescriptor(null, null)));
- Expect.equals('c4 1', apply(c4, new ArgumentDescriptor([], {})));
- throwsNSME(() => apply(c4, new ArgumentDescriptor([1], {'a': 1})));
- throwsNSME(() => apply(c4, new ArgumentDescriptor([1], {})));
- throwsNSME(() => apply(c4, new ArgumentDescriptor([], {'a': 1, 'b': 2})));
-
- Expect.equals('c5 1 2', apply(c5, new ArgumentDescriptor([], null)));
- Expect.equals('c5 3 2', apply(c5, new ArgumentDescriptor([], {'a': 3})));
- Expect.equals('c5 1 2', apply(c5, new ArgumentDescriptor(null, null)));
- Expect.equals('c5 1 2', apply(c5, new ArgumentDescriptor([], {})));
- Expect.equals('c5 3 4',
- apply(c5, new ArgumentDescriptor([], {'a': 3, 'b': 4})));
- Expect.equals('c5 4 3',
- apply(c5, new ArgumentDescriptor([], {'b': 3, 'a': 4})));
- Expect.equals('c5 1 3',
- apply(c5, new ArgumentDescriptor([], {'b': 3})));
- throwsNSME(() => apply(c5, new ArgumentDescriptor([1], {'a': 1})));
- throwsNSME(() => apply(c5, new ArgumentDescriptor([1], {})));
- throwsNSME(() =>
- apply(c5, new ArgumentDescriptor([], {'a': 1, 'b': 2, 'c': 3})));
-
- Expect.equals('c6 2 1', apply(c6, new ArgumentDescriptor([], null)));
- Expect.equals('c6 3 1', apply(c6, new ArgumentDescriptor([], {'a': 3})));
- Expect.equals('c6 2 1', apply(c6, new ArgumentDescriptor(null, null)));
- Expect.equals('c6 2 1', apply(c6, new ArgumentDescriptor([], {})));
- Expect.equals('c6 3 4',
- apply(c6, new ArgumentDescriptor([], {'a': 3, 'b': 4})));
- Expect.equals('c6 4 3',
- apply(c6, new ArgumentDescriptor([], {'b': 3, 'a': 4})));
- Expect.equals('c6 2 3',
- apply(c6, new ArgumentDescriptor([], {'b': 3})));
- throwsNSME(() => apply(c6, new ArgumentDescriptor([1], {'a': 1})));
- throwsNSME(() => apply(c6, new ArgumentDescriptor([1], {})));
- throwsNSME(() =>
- apply(c6, new ArgumentDescriptor([], {'a': 1, 'b': 2, 'c': 3})));
-}

Powered by Google App Engine
This is Rietveld 408576698