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

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

Issue 10837070: Remove old isolate API and update all code in the repository to use (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Address review comments. Created 8 years, 4 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « tests/isolate/count_test.dart ('k') | tests/isolate/isolate.status » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011, 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 // Dart test program for testing that isolates can communicate to isolates 5 // Dart test program for testing that isolates can communicate to isolates
6 // other than the main isolate. 6 // other than the main isolate.
7 7
8 #library('CrossIsolateMessageTest'); 8 #library('CrossIsolateMessageTest');
9 #import('dart:isolate'); 9 #import('dart:isolate');
10 #import('../../lib/unittest/unittest.dart'); 10 #import('../../lib/unittest/unittest.dart');
11 11
12 class CrossIsolate1 extends Isolate { 12 void crossIsolate1() {
13 CrossIsolate1() : super.heavy(); 13 port.receive((msg, replyTo) {
14 14 SendPort otherIsolate = msg;
15 void main() { 15 ReceivePort receivePort = new ReceivePort();
16 this.port.receive((msg, replyTo) { 16 receivePort.receive((msg, replyTo) {
17 SendPort otherIsolate = msg; 17 otherIsolate.send(msg + 58, null); // 100.
18 ReceivePort receivePort = new ReceivePort(); 18 receivePort.close();
19 receivePort.receive((msg, replyTo) {
20 otherIsolate.send(msg + 58, null); // 100.
21 receivePort.close();
22 });
23 replyTo.send(['ready', receivePort.toSendPort()]);
24 this.port.close();
25 }); 19 });
26 } 20 replyTo.send(['ready', receivePort.toSendPort()]);
21 port.close();
22 });
27 } 23 }
28 24
29 // CrossIsolate2 is nearly the same as CrossIsolate1, but contains a 25 // crossIsolate2 is nearly the same as crossIsolate1, but contains a
30 // different constant. 26 // different constant.
31 class CrossIsolate2 extends Isolate { 27 void crossIsolate2() {
32 CrossIsolate2() : super.heavy(); 28 port.receive((msg, replyTo) {
33 29 SendPort mainIsolate = msg;
34 void main() { 30 ReceivePort receivePort = new ReceivePort();
35 this.port.receive((msg, replyTo) { 31 receivePort.receive((msg, replyTo) {
36 SendPort mainIsolate = msg; 32 mainIsolate.send(msg + 399, null); // 499.
37 ReceivePort receivePort = new ReceivePort(); 33 receivePort.close();
38 receivePort.receive((msg, replyTo) {
39 mainIsolate.send(msg + 399, null); // 499.
40 receivePort.close();
41 });
42 replyTo.send(['ready', receivePort.toSendPort()]);
43 this.port.close();
44 }); 34 });
45 } 35 replyTo.send(['ready', receivePort.toSendPort()]);
36 port.close();
37 });
46 } 38 }
47 39
48 main() { 40 main() {
49 test("share port, and send message cross isolates ", () { 41 test("share port, and send message cross isolates ", () {
50 // Create CrossIsolate1 and CrossIsolate2. 42 SendPort port1 = spawnFunction(crossIsolate1);
51 new CrossIsolate1().spawn().then(expectAsync1((SendPort port1) { 43 SendPort port2 = spawnFunction(crossIsolate2);
52 new CrossIsolate2().spawn().then(expectAsync1((SendPort port2) { 44 // Create a new receive port and send it to isolate2.
53 // Create a new receive port and send it to isolate2. 45 ReceivePort myPort = new ReceivePort();
54 ReceivePort myPort = new ReceivePort(); 46 port2.call(myPort.toSendPort()).then(expectAsync1((msg) {
55 port2.call(myPort.toSendPort()).then(expectAsync1((msg) { 47 Expect.equals("ready", msg[0]);
56 Expect.equals("ready", msg[0]); 48 // Send port of isolate2 to isolate1.
57 // Send port of isolate2 to isolate1. 49 port1.call(msg[1]).then(expectAsync1((msg) {
58 port1.call(msg[1]).then(expectAsync1((msg) { 50 Expect.equals("ready", msg[0]);
59 Expect.equals("ready", msg[0]); 51 myPort.receive(expectAsync2((msg, replyTo) {
60 myPort.receive(expectAsync2((msg, replyTo) { 52 Expect.equals(499, msg);
61 Expect.equals(499, msg); 53 myPort.close();
62 myPort.close();
63 }));
64 msg[1].send(42, null);
65 }));
66 })); 54 }));
55 msg[1].send(42, null);
67 })); 56 }));
68 })); 57 }));
69 }); 58 });
70 } 59 }
OLDNEW
« no previous file with comments | « tests/isolate/count_test.dart ('k') | tests/isolate/isolate.status » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698