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

Unified Diff: tests/isolate/error_exit_at_spawnuri_test.dart

Issue 1244733002: - Implement VM parts of https://codereview.chromium.org/1240743003/ (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Update isolate.status file as expected. Created 5 years, 5 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
« no previous file with comments | « tests/isolate/error_exit_at_spawnuri_iso.dart ('k') | tests/isolate/exit_at_spawn_test.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/isolate/error_exit_at_spawnuri_test.dart
diff --git a/tests/isolate/error_exit_at_spawnuri_test.dart b/tests/isolate/error_exit_at_spawnuri_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..80328a4838db9ccece04caff27744e8afdd419f9
--- /dev/null
+++ b/tests/isolate/error_exit_at_spawnuri_test.dart
@@ -0,0 +1,70 @@
+// 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.
+
+library error_exit_at_spawnuri;
+
+import "dart:isolate";
+import "dart:async";
+import "package:async_helper/async_helper.dart";
+import "package:expect/expect.dart";
+
+main(){
+ asyncStart();
+ // Setup the port for communication with the newly spawned isolate.
+ RawReceivePort reply = new RawReceivePort(null);
+ SendPort sendPort;
+ int state = 0;
+ reply.handler = (port) {
+ sendPort = port;
+ port.send(state);
+ reply.handler = (v) {
+ Expect.equals(0, state);
+ Expect.equals(42, v);
+ state++;
+ sendPort.send(state);
+ };
+ };
+
+ // Capture errors from other isolate as raw messages.
+ RawReceivePort errorPort = new RawReceivePort();
+ errorPort.handler = (message) {
+ String error = message[0];
+ String stack = message[1];
+ switch (state) {
+ case 1:
+ Expect.equals(new ArgumentError("whoops").toString(), "$error");
+ state++;
+ sendPort.send(state);
+ break;
+ case 2:
+ Expect.equals(new RangeError.value(37).toString(), "$error");
+ state++;
+ sendPort.send(state);
+ reply.close();
+ errorPort.close();
+ break;
+ default:
+ throw "Bad state for error: $state: $error";
+ }
+ };
+
+ // Get exit notifications from other isolate as raw messages.
+ RawReceivePort exitPort = new RawReceivePort();
+ exitPort.handler = (message) {
+ // onExit ports registered at spawn cannot have a particular message
+ // associated.
+ Expect.equals(null, message);
+ // Only exit after sending the termination message.
+ Expect.equals(3, state);
+ exitPort.close();
+ asyncEnd();
+ };
+
+ Isolate.spawnUri(Uri.parse("error_exit_at_spawnuri_iso.dart"), [],
+ reply.sendPort,
+ // Setup handlers as part of spawn.
+ errorsAreFatal: false,
+ onError: errorPort.sendPort,
+ onExit: exitPort.sendPort);
+}
« no previous file with comments | « tests/isolate/error_exit_at_spawnuri_iso.dart ('k') | tests/isolate/exit_at_spawn_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698