dart-sdk/tests/language/call/closurization_test.dart
Tess Strickland d06d627c79 [vm] Remove --[no-]lazy-dispatchers flag.
No client of the VM uses this flag, only tests, and this flag was always
set to false in AOT mode. Thus, remove uses of this flag and instead
always lazily create dispatchers as needed when resolving method names
in JIT mode.

Remove the implicit value of `allow_add` for some Resolver
static methods. For callers that previously depended on the implicit
`true` value (which includes the AOT precompilier), pass `true` for
uses in the compiler and pass `!FLAG_precompiled_mode` for uses in the
runtime. Assert that `allow_add` is false when these methods are invoked
from the precompiled runtime.

Remove Resolver static methods that are no longer used.

TEST=ci

Change-Id: Ib6a7354f7a859e86743c381513a4129c14895753
Cq-Include-Trybots: luci.dart.try:vm-linux-debug-x64-try,vm-linux-release-x64-try,vm-aot-linux-debug-x64-try,vm-aot-linux-release-x64-try,vm-aot-mac-release-arm64-try,vm-mac-debug-arm64-try,vm-mac-release-arm64-try
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/366668
Reviewed-by: Ryan Macnak <rmacnak@google.com>
Reviewed-by: Martin Kustermann <kustermann@google.com>
Commit-Queue: Tess Strickland <sstrickl@google.com>
2024-06-06 10:56:12 +00:00

55 lines
1.9 KiB
Dart

// Copyright (c) 2014, 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.
// VMOptions=--optimization_counter_threshold=10 --no-background_compilation
import "package:expect/expect.dart";
main() {
bar(a) {
return a is String;
}
var bar_tearOff = bar.call;
for (var i = 0; i < 20; i++) {
Expect.isFalse(bar_tearOff(1));
Expect.isTrue(bar_tearOff.call('foo'));
Expect.isFalse(bar_tearOff.call(1));
Expect.isTrue(bar_tearOff('foo'));
}
opt_arg([a = "a"]) => a is String;
var opt_arg_tearOff = opt_arg.call;
for (var i = 0; i < 20; i++) {
Expect.isFalse(opt_arg_tearOff(1));
Expect.isFalse(opt_arg_tearOff.call(1));
Expect.isTrue(opt_arg_tearOff());
Expect.isTrue(opt_arg_tearOff.call());
Expect.isTrue(opt_arg_tearOff("b"));
Expect.isTrue(opt_arg_tearOff.call("b"));
}
named_arg({x = 11, y = 22}) => "$x$y";
var named_arg_tearOff = named_arg.call;
for (var i = 0; i < 20; i++) {
Expect.equals("1122", named_arg_tearOff());
Expect.equals("1122", named_arg_tearOff.call());
Expect.equals("4455", named_arg_tearOff(y: 55, x: 44));
Expect.equals("4455", named_arg_tearOff.call(y: 55, x: 44));
Expect.equals("4455", named_arg_tearOff(x: 44, y: 55));
Expect.equals("4455", named_arg_tearOff.call(x: 44, y: 55));
}
// In order to test runtime behavior of calling with invalid arguments,
// we cast to dynamic to make the type system forget about the actual types.
dynamic bar_tearOff_d = bar_tearOff;
dynamic opt_arg_tearOff_d = opt_arg_tearOff;
dynamic named_arg_tearOff_d = named_arg_tearOff;
Expect.throws(() => bar_tearOff_d.call());
Expect.throwsNoSuchMethodError(() => opt_arg_tearOff_d.call(x: "p"));
Expect.throwsNoSuchMethodError(() => named_arg_tearOff_d.call("p", "q"));
}