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

Side by Side Diff: tests/isolate/illegal_msg_test.dart

Issue 36933002: All isolate tests running on vm (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698