dart-sdk/tests/lib/isolate/kill_self_synchronously_test.dart
Martin Kustermann 96d40d1caa [vm/concurrency] Remove --(no-)enable-isolate-groups flag usage in tests
This is a preparation CL to remove the --enable-isolate-groups flag in
the VM.

The following tests were only running in --no-enable-isolate-groups and
are therefore obsolete now:

  - runtime/tests/vm/dart/regress_47468_test.dart
  - runtime/tests/vm/dart_2/regress_47468_test.dart
  - tests/lib/isolate/illegal_msg_function_test.dart
  - tests/lib_2/isolate/illegal_msg_function_test.dart

TEST=Changes tests only.

Change-Id: I6257cb667eebca66a649614d3010139dd2cdd3ab
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/219100
Reviewed-by: Alexander Aprelev <aam@google.com>
Commit-Queue: Martin Kustermann <kustermann@google.com>
2021-11-04 18:57:21 +00:00

34 lines
1.1 KiB
Dart

// Copyright (c) 2017, 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 "dart:isolate";
import "dart:io";
void main(List<String> args) {
if (args.contains("--child")) {
new RawReceivePort(); // Hang if not killed.
Isolate.current.kill(priority: Isolate.immediate);
// No intervening call.
throw "QQQ Should not be reached";
} else {
var exec = Platform.resolvedExecutable;
var args = <String>[];
args.addAll(Platform.executableArguments);
args.add(Platform.script.toFilePath());
args.add("--child");
var result = Process.runSync(exec, args);
if (result.exitCode != 255) {
throw "Wrong exit code: ${result.exitCode}";
}
if (result.stderr.contains("QQQ Should not be reached")) {
print(result.stderr);
throw "Not killed synchronously";
}
if (!result.stderr.contains("isolate terminated by Isolate.kill")) {
print(result.stderr);
throw "Missing killed message";
}
}
}