Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 library illegal_msg_tests; | 5 library illegal_msg_tests; |
| 6 import "package:expect/expect.dart"; | 6 import "package:expect/expect.dart"; |
| 7 import 'dart:isolate'; | 7 import 'dart:isolate'; |
| 8 import "package:async_helper/async_helper.dart"; | 8 import "package:async_helper/async_helper.dart"; |
| 9 | 9 |
| 10 funcFoo(x) => x + 2; | 10 funcFoo(x) => x + 2; |
| 11 | 11 |
| 12 echo() { | 12 echo(sendPort) { |
| 13 port.receive((msg, reply) { | 13 var port = new ReceivePort(); |
| 14 reply.send("echoing ${msg(1)}}"); | 14 sendPort.send(port.sendPort); |
| 15 port.list((msg) { | |
|
Lasse Reichstein Nielsen
2013/10/24 10:26:01
This is a typo, so this code doesn't run either (w
| |
| 16 sendPort.send("echoing ${msg(1)}}"); | |
| 15 }); | 17 }); |
| 16 } | 18 } |
| 17 | 19 |
| 18 main() { | 20 main() { |
| 19 var snd = spawnFunction(echo); | 21 ReceivePort port = new ReceivePort(); |
| 22 Future spawn = Isolate.spawn(echo, port.sendPort); | |
| 20 var caught_exception = false; | 23 var caught_exception = false; |
| 21 try { | 24 var stream = port.asBroadcastStream(); |
| 22 snd.send(funcFoo, port.toSendPort()); | 25 asyncStart(); |
| 23 } catch (e) { | 26 stream.first.then((snd) { |
| 24 caught_exception = true; | 27 asyncEnd(); |
|
floitsch
2013/10/23 13:33:24
Looks like the second part is never executed.
Lasse Reichstein Nielsen
2013/10/24 10:26:01
It never is if the test succeeds. The expected beh
| |
| 25 } | 28 try { |
| 29 snd.send(funcFoo); | |
| 30 } catch (e) { | |
| 31 caught_exception = true; | |
| 32 } | |
| 26 | 33 |
| 27 if (caught_exception) { | 34 if (caught_exception) { |
| 28 port.close(); | 35 port.close(); |
| 29 } else { | 36 } else { |
| 30 asyncStart(); | 37 asyncStart(); |
|
floitsch
2013/10/23 13:33:24
This would yield an error.
you are not allowed to
Lasse Reichstein Nielsen
2013/10/24 10:26:01
Now overlaps.
| |
| 31 port.receive((msg, reply) { | 38 stream.first.then((msg) { |
| 32 print("from worker ${msg}"); | 39 print("from worker ${msg}"); |
| 33 asyncEnd(); | 40 asyncEnd(); |
| 34 }); | 41 }); |
| 35 } | 42 } |
| 36 Expect.isTrue(caught_exception); | 43 Expect.isTrue(caught_exception); |
| 44 }); | |
| 37 } | 45 } |
| OLD | NEW |