| 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();
|
| - }
|
| - });
|
| - });
|
| -}
|
|
|