| /* |
| * Copyright (c) 2011-2016, 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. |
| */ |
| /** |
| * @assertion Future<Isolate> spawnUri(Uri uri, |
| * List<String> args, |
| * message, |
| * { bool paused: false, |
| * SendPort onExit, |
| * SendPort onError, |
| * bool errorsAreFatal, |
| * bool checked, |
| * Map<String, String> environment, |
| * Uri packageRoot, |
| * Uri packageConfig, |
| * bool automaticPackageResolution: false |
| * } |
| * ) |
| * Creates and spawns an isolate that runs the code from the library with |
| * the specified URI. |
| * The isolate starts executing the top-level main function of the library |
| * with the given URI. |
| * The target main must be callable with zero, one or two arguments. |
| * Examples: |
| * main() |
| * main(args) |
| * main(args, message) |
| * When present, the parameter args is set to the provided args list. When |
| * present, the parameter message is set to the initial message. |
| * |
| * @description Checks that an isolate can be spawned from a newly spawned |
| * isolate. |
| * |
| * @author kaigorodov |
| */ |
| import "dart:isolate"; |
| import "../../../Utils/expect.dart"; |
| |
| var expectedMessage = "spawnUri_A01_t03"; |
| |
| var receivePort = new ReceivePort(); |
| |
| void receiveHandler(var message) { |
| Expect.equals(expectedMessage, message); |
| receivePort.close(); |
| asyncEnd(); |
| } |
| |
| void main() { |
| asyncStart(); |
| receivePort.listen(receiveHandler); |
| Isolate.spawnUri(new Uri.file("spawnUri_A01_t01.dart"), [expectedMessage], |
| receivePort.sendPort); |
| } |