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

Side by Side Diff: tests/isolate/src/APIv2_unresolvedPortsTest.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, 7 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) 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 // spawns multiple isolates and sends unresolved ports between them. 5 // spawns multiple isolates and sends unresolved ports between them.
6 #library('unresolved_ports'); 6 #library('unresolved_ports');
7 #import('dart:dom'); // import added so test.dart can treat this as a webtest.
8 #import('dart:isolate'); 7 #import('dart:isolate');
9 #import('../../../lib/unittest/unittest.dart'); 8 #import('../../../lib/unittest/unittest.dart');
10 #import('../../../lib/unittest/dom_config.dart');
11 9
12 // This is similar to APIv2_unresolvedPortsStandaloneTest but using 10 // This test does the following:
13 // 'unittest.dart' so it can run to completion in browsers. 11 // - main spawns two isolates: 'tim' and 'beth'
12 // - 'tim' spawns an isolate: 'bob'
13 // - main starts a message chain:
14 // main -> beth -> tim -> bob -> main
15 // by giving 'beth' a send-port to 'tim'.
14 16
15 bethIsolate() { 17 bethIsolate() {
16 port.receive((msg, reply) => msg[1].send( 18 port.receive((msg, reply) => msg[1].send(
17 '${msg[0]}\nBeth says: Tim are you coming? And Bob?', reply)); 19 '${msg[0]}\nBeth says: Tim are you coming? And Bob?', reply));
18 } 20 }
19 21
20 timIsolate() { 22 timIsolate() {
21 SendPort bob = spawnFunction(bobIsolate); 23 SendPort bob = spawnFunction(bobIsolate);
22 port.receive((msg, reply) => bob.send( 24 port.receive((msg, reply) => bob.send(
23 '$msg\nTim says: Can you tell "main" that we are all coming?', reply)); 25 '$msg\nTim says: Can you tell "main" that we are all coming?', reply));
24 } 26 }
25 27
26 bobIsolate() { 28 bobIsolate() {
27 port.receive((msg, reply) => reply.send( 29 port.receive((msg, reply) => reply.send(
28 '$msg\nBob says: we are all coming!')); 30 '$msg\nBob says: we are all coming!'));
29 } 31 }
30 32
31 main() { 33 main() {
32 useDomConfiguration(); 34 test('Message chain with unresolved ports', () {
33 asyncTest('Message chain with unresolved ports', 1, () {
34 ReceivePort port = new ReceivePort(); 35 ReceivePort port = new ReceivePort();
35 port.receive((msg, _) { 36 port.receive(expectAsync2((msg, _) {
36 expect(msg).equals('main says: Beth, find out if Tim is coming.' 37 expect(msg).equals('main says: Beth, find out if Tim is coming.'
37 + '\nBeth says: Tim are you coming? And Bob?' 38 + '\nBeth says: Tim are you coming? And Bob?'
38 + '\nTim says: Can you tell "main" that we are all coming?' 39 + '\nTim says: Can you tell "main" that we are all coming?'
39 + '\nBob says: we are all coming!'); 40 + '\nBob says: we are all coming!');
40 port.close(); 41 port.close();
41 callbackDone(); 42 }));
42 });
43 43
44 SendPort tim = spawnFunction(timIsolate); 44 SendPort tim = spawnFunction(timIsolate);
45 SendPort beth = spawnFunction(bethIsolate); 45 SendPort beth = spawnFunction(bethIsolate);
46 46
47 beth.send( 47 beth.send(
48 // because tim is created asynchronously, here we are sending an 48 // because tim is created asynchronously, here we are sending an
49 // unresolved port: 49 // unresolved port:
50 ['main says: Beth, find out if Tim is coming.', tim], 50 ['main says: Beth, find out if Tim is coming.', tim],
51 port.toSendPort()); 51 port.toSendPort());
52 }); 52 });
53 } 53 }
OLDNEW
« no previous file with comments | « tests/isolate/src/APIv2_unresolvedPortsStandaloneTest.dart ('k') | tests/isolate/src/ConstructorTest.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698