Index: tests/isolate/handle_error2_test.dart |
diff --git a/tests/isolate/handle_error2_test.dart b/tests/isolate/handle_error2_test.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..8a72a0e3f16f6a89b351c5f42baa03c85e6ef2c4 |
--- /dev/null |
+++ b/tests/isolate/handle_error2_test.dart |
@@ -0,0 +1,89 @@ |
+// 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. |
+ |
+library handle_error_test; |
+ |
+import "dart:isolate"; |
+import "dart:async"; |
+import "package:async_helper/async_helper.dart"; |
+import "package:expect/expect.dart"; |
+ |
+isomain1(replyPort) { |
+ RawReceivePort port = new RawReceivePort(); |
+ port.handler = (v) { |
+ switch (v) { |
+ case 0: |
+ replyPort.send(42); |
+ break; |
+ case 1: |
+ throw new ArgumentError("whoops"); |
+ case 2: |
+ throw new RangeError.value(37); |
+ case 3: |
+ port.close(); |
+ } |
+ }; |
+ replyPort.send(port.sendPort); |
+} |
+ |
+/// Do Isolate.spawn(entry) and get a sendPort from the isolate that it |
+/// expects commands on. |
+/// The isolate has errors set to non-fatal. |
+/// Returns a list of `[isolate, commandPort]` in a future. |
+Future spawn(entry) { |
+ ReceivePort reply = new ReceivePort(); |
+ Future isolate = Isolate.spawn(entry, reply.sendPort, paused: true); |
+ return isolate.then((Isolate isolate) { |
+ isolate.setErrorsFatal(false); |
+ isolate.resume(isolate.pauseCapability); |
+ Future result = reply.first.then((sendPort) { |
+ return [isolate, sendPort]; |
+ }); |
+ return result; |
+ }); |
+} |
+ |
+main(){ |
+ asyncStart(); |
+ RawReceivePort reply = new RawReceivePort(null); |
+ RawReceivePort reply2 = new RawReceivePort(null); |
+ // Create two isolates waiting for commands, with errors non-fatal. |
+ Future iso1 = spawn(isomain1); |
+ Future iso2 = spawn(isomain1); |
+ Future.wait([iso1, iso2]).then((l) { |
+ var isolate1 = l[0][0]; |
+ var sendPort1 = l[0][1]; |
+ var isolate2 = l[1][0]; |
+ var sendPort2 = l[1][1]; |
+ Stream errors = isolate1.errors; // Broadcast stream, never a done message. |
+ int state = 1; |
+ var subscription; |
+ subscription = errors.listen(null, onError: (error, stack) { |
+ switch (state) { |
+ case 1: |
+ Expect.equals(new ArgumentError("whoops").toString(), "$error"); |
+ state++; |
+ break; |
+ case 2: |
+ Expect.equals(new RangeError.value(37).toString(), "$error"); |
+ state++; |
+ reply.close(); |
+ subscription.cancel(); |
+ asyncEnd(); |
+ break; |
+ default: |
+ throw "Bad state for error: $state: $error"; |
+ } |
+ }); |
+ sendPort1.send(0); |
+ sendPort2.send(0); |
+ sendPort1.send(1); |
+ sendPort2.send(1); |
+ sendPort1.send(2); |
+ sendPort2.send(2); |
+ sendPort1.send(3); |
+ sendPort2.send(3); |
+ }); |
+} |
+ |