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

Unified Diff: tests/isolate/cross_isolate_message_stream_test.dart

Issue 27215002: Very simple version of Isolates. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Address comments. Created 7 years, 2 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tests/isolate/count_test.dart ('k') | tests/isolate/cross_isolate_message_test.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/isolate/cross_isolate_message_stream_test.dart
diff --git a/tests/isolate/cross_isolate_message_stream_test.dart b/tests/isolate/cross_isolate_message_stream_test.dart
deleted file mode 100644
index 70d13455b0d36716abcac0541b6178155fd44b08..0000000000000000000000000000000000000000
--- a/tests/isolate/cross_isolate_message_stream_test.dart
+++ /dev/null
@@ -1,112 +0,0 @@
-// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
-// for details. All rights reserved. Use of this source code is governed by a
-// BSD-style license that can be found in the LICENSE file.
-
-// Dart test program for testing that isolates can communicate to isolates
-// other than the main isolate.
-
-library CrossIsolateMessageTest;
-import 'dart:isolate';
-import '../../pkg/unittest/lib/unittest.dart';
-
-/*
- * Everything starts in the main-isolate (in the main-method).
- * The main isolate spawns two isolates: isolate1 (with entry point
- * 'crossIsolate1') and isolate2 (with entry point 'crossIsolate2').
- *
- * The main-isolate creates a new message-box and sends its sink to both
- * isolates. Whenever isolate1 or isolate2 send something to the main-isolate
- * they will use this sink.
- * Isolate2 stores the sink and replies with a new sink (sink2b) it created.
- * Isolate1 stores the sink and waits for another message.
- * Main receives isolate2's sink2b and sends it to isolate1.
- * Isolate1 stores this sink as "otherIsolate" and send a new sink (sink1b) to
- * the main isolate.
- * Main receives sink1b and sents a message "fromMain, 42" to sink1b.
- * isolate1 receives this message, modifies it (adding 58 to 42) and forwards
- * it to isolate2 (otherIsolate).
- * isolate2 receives the message, modifies it (adding 399), and sends it to
- * the main isolate.
- * The main-isolate receives it, verifies that the result is 499 and ends the
- * test.
- */
-
-void crossIsolate1() {
- bool first = true;
- IsolateSink mainIsolate;
- var subscription = stream.listen((msg) {
- if (first) {
- first = false;
- mainIsolate = msg;
- return;
- }
- IsolateSink otherIsolate = msg;
- MessageBox box = new MessageBox();
- box.stream.single.then((msg) {
- expect(msg[0], "fromMain");
- otherIsolate.add(["fromIsolate1", msg[1] + 58]); // 100;
- otherIsolate.close();
- box.stream.close();
- });
- mainIsolate.add(['ready1', box.sink]);
- stream.close();
- });
-}
-
-void crossIsolate2() {
- var subscription;
- subscription = stream.listen((msg) {
- IsolateSink mainIsolate = msg;
- MessageBox box = new MessageBox();
- box.stream.listen((msg) {
- expect(msg[0], "fromIsolate1");
- mainIsolate.add(["fromIsolate2", msg[1] + 399]); // 499;
- mainIsolate.close();
- box.stream.close();
- });
- mainIsolate.add(['ready2', box.sink]);
- subscription.cancel();
- });
-}
-
-main() {
- test("share sink, and send message cross isolates ", () {
- IsolateSink sink1 = streamSpawnFunction(crossIsolate1);
- IsolateSink sink2 = streamSpawnFunction(crossIsolate2);
- // Create a new sink and send it to isolate2.
- MessageBox box = new MessageBox();
- sink1.add(box.sink);
- sink2.add(box.sink);
- int msgNumber = 0;
-
- bool isReady1 = false;
- bool isReady2 = false;
- bool hasSentMessage = false;
-
- Function ready1 = expectAsync0(() => isReady1 = true);
- Function ready2 = expectAsync0(() => isReady2 = true);
- Function fromIsolate2 = expectAsync1((data) {
- expect(data, 499);
- });
- IsolateSink sink1b;
- IsolateSink sink2b;
-
- box.stream.listen((msg) {
- switch (msg[0]) {
- case 'ready1': ready1(); sink1b = msg[1]; break;
- case 'ready2':
- ready2();
- sink2b = msg[1];
- sink1.add(sink2b);
- break;
- case 'fromIsolate2': fromIsolate2(msg[1]); break;
- default: throw "bad message";
- }
- if (isReady1 && isReady2 && !hasSentMessage) {
- hasSentMessage = true;
- sink1b.add(["fromMain", 42]);
- sink1b.close();
- }
- });
- });
-}
« no previous file with comments | « tests/isolate/count_test.dart ('k') | tests/isolate/cross_isolate_message_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698