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

Side by Side Diff: tests/isolate/src/CrossIsolateMessageTest.dart

Issue 10153005: unittest step 3 and 4: remove TestFramework.dart, make test.dart use (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 8 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
OLDNEW
1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2011, 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('TestFramework.dart'); 10 #import('../../../lib/unittest/unittest.dart');
11 11
12 class CrossIsolate1 extends Isolate { 12 class CrossIsolate1 extends Isolate {
13 CrossIsolate1() : super.heavy(); 13 CrossIsolate1() : super.heavy();
14 14
15 void main() { 15 void main() {
16 this.port.receive((msg, replyTo) { 16 this.port.receive((msg, replyTo) {
17 SendPort otherIsolate = msg; 17 SendPort otherIsolate = msg;
18 ReceivePort receivePort = new ReceivePort(); 18 ReceivePort receivePort = new ReceivePort();
19 receivePort.receive((msg, replyTo) { 19 receivePort.receive((msg, replyTo) {
20 otherIsolate.send(msg + 58, null); // 100. 20 otherIsolate.send(msg + 58, null); // 100.
(...skipping 17 matching lines...) Expand all
38 receivePort.receive((msg, replyTo) { 38 receivePort.receive((msg, replyTo) {
39 mainIsolate.send(msg + 399, null); // 499. 39 mainIsolate.send(msg + 399, null); // 499.
40 receivePort.close(); 40 receivePort.close();
41 }); 41 });
42 replyTo.send(['ready', receivePort.toSendPort()]); 42 replyTo.send(['ready', receivePort.toSendPort()]);
43 this.port.close(); 43 this.port.close();
44 }); 44 });
45 } 45 }
46 } 46 }
47 47
48 test(TestExpectation expect) { 48 main() {
49 // Create CrossIsolate1 and CrossIsolate2. 49 test("share port, and send message cross isolates ", () {
50 expect.completes(new CrossIsolate1().spawn()).then((SendPort port1) { 50 // Create CrossIsolate1 and CrossIsolate2.
51 expect.completes(new CrossIsolate2().spawn()).then((SendPort port2) { 51 new CrossIsolate1().spawn().then(later1((SendPort port1) {
52 // Create a new receive port and send it to isolate2. 52 new CrossIsolate2().spawn().then(later1((SendPort port2) {
53 ReceivePort myPort = new ReceivePort(); 53 // Create a new receive port and send it to isolate2.
54 port2.call(myPort.toSendPort()).then(expect.runs1((msg) { 54 ReceivePort myPort = new ReceivePort();
55 Expect.equals("ready", msg[0]); 55 port2.call(myPort.toSendPort()).then(later1((msg) {
56 // Send port of isolate2 to isolate1.
57 port1.call(msg[1]).then(expect.runs1((msg) {
58 Expect.equals("ready", msg[0]); 56 Expect.equals("ready", msg[0]);
59 myPort.receive(expect.runs2((msg, replyTo) { 57 // Send port of isolate2 to isolate1.
60 Expect.equals(499, msg); 58 port1.call(msg[1]).then(later1((msg) {
61 expect.succeeded(); 59 Expect.equals("ready", msg[0]);
62 myPort.close(); 60 myPort.receive(later2((msg, replyTo) {
61 Expect.equals(499, msg);
62 myPort.close();
63 }));
64 msg[1].send(42, null);
63 })); 65 }));
64 msg[1].send(42, null);
65 })); 66 }));
66 })); 67 }));
67 }); 68 }));
68 }); 69 });
69 } 70 }
70
71 main() {
72 runTests([test]);
73 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698