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

Unified Diff: tests/lib/async/stream_controller_async_test.dart

Issue 17490002: Make asBroadcastStream take two callbacks. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Reintroduce zone. Created 7 years, 6 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 | « sdk/lib/html/dartium/html_dartium.dart ('k') | tests/lib/async/stream_controller_test.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/lib/async/stream_controller_async_test.dart
diff --git a/tests/lib/async/stream_controller_async_test.dart b/tests/lib/async/stream_controller_async_test.dart
index 7c134055bc249134739f8f69a72e0a50b0bb5738..4339c02cde3f23cf0f6dadcfb3bbd07f761fad36 100644
--- a/tests/lib/async/stream_controller_async_test.dart
+++ b/tests/lib/async/stream_controller_async_test.dart
@@ -12,11 +12,13 @@ import '../../../pkg/unittest/lib/unittest.dart';
import 'event_helper.dart';
import 'stream_state_helper.dart';
+void cancelSub(StreamSubscription sub) { sub.cancel(); }
+
testController() {
// Test fold
test("StreamController.fold", () {
StreamController c = new StreamController();
- Stream stream = c.stream.asBroadcastStream();
+ Stream stream = c.stream.asBroadcastStream(onCancel: cancelSub);
stream.fold(0, (a,b) => a + b)
.then(expectAsync1((int v) {
Expect.equals(42, v);
@@ -28,7 +30,7 @@ testController() {
test("StreamController.fold throws", () {
StreamController c = new StreamController();
- Stream stream = c.stream.asBroadcastStream();
+ Stream stream = c.stream.asBroadcastStream(onCancel: cancelSub);
stream.fold(0, (a,b) { throw "Fnyf!"; })
.catchError(expectAsync1((error) { Expect.equals("Fnyf!", error); }));
c.add(42);
@@ -267,6 +269,7 @@ testExtraMethods() {
testPause() {
test("pause event-unpause", () {
+
StreamProtocolTest test = new StreamProtocolTest();
Completer completer = new Completer();
test..expectListen()
@@ -277,7 +280,7 @@ testPause() {
..expectData(43)
..expectData(44)
..expectDone()
- ..expectCancel();
+ ..expectCancel(test.terminate);
test.listen();
test.add(42);
test.add(43);
@@ -301,7 +304,7 @@ testPause() {
..expectData(43)
..expectData(44)
..expectDone()
- ..expectCancel();
+ ..expectCancel(test.terminate);
test..listen()
..add(42)
..add(43)
@@ -323,7 +326,7 @@ testPause() {
..expectData(43)
..expectData(44)
..expectDone()
- ..expectCancel();
+ ..expectCancel(test.terminate);
test..listen()
..add(42)
..add(43)
@@ -349,7 +352,7 @@ testPause() {
..expectData(43)
..expectData(44)
..expectDone()
- ..expectCancel();
+ ..expectCancel(test.terminate);
test..listen()
..add(42);
});
@@ -360,7 +363,6 @@ class TestError { const TestError(); }
testRethrow() {
TestError error = const TestError();
-
testStream(name, streamValueTransform) {
test("rethrow-$name-value", () {
StreamController c = new StreamController();
@@ -498,6 +500,74 @@ void testBroadcastController() {
});
}
+void testAsBroadcast() {
+ test("asBroadcast-not-canceled", () {
+ StreamProtocolTest test = new StreamProtocolTest.asBroadcast();
+ var sub;
+ test..expectListen()
+ ..expectBroadcastListen((_) {
+ test.add(42);
+ })
+ ..expectData(42, () {
+ sub.cancel();
+ })
+ ..expectBroadcastCancel((_) {
+ sub = test.listen();
+ })
+ ..expectBroadcastListen((_) {
+ test.terminate();
+ });
+ sub = test.listen();
+ });
+
+ test("asBroadcast-canceled", () {
+ StreamProtocolTest test = new StreamProtocolTest.asBroadcast();
+ var sub;
+ test..expectListen()
+ ..expectBroadcastListen((_) {
+ test.add(42);
+ })
+ ..expectData(42, () {
+ sub.cancel();
+ })
+ ..expectBroadcastCancel((originalSub) {
+ originalSub.cancel();
+ })
+ ..expectCancel(test.terminate);
+ sub = test.listen();
+ });
+
+ test("asBroadcast-pause-original", () {
+ StreamProtocolTest test = new StreamProtocolTest.asBroadcast();
+ var sub;
+ test..expectListen()
+ ..expectBroadcastListen((_) {
+ test.add(42);
+ test.add(43);
+ })
+ ..expectData(42, () {
+ sub.cancel();
+ })
+ ..expectBroadcastCancel((originalSub) {
+ originalSub.pause(); // Pause before sending 43 from original sub.
+ })
+ ..expectPause(() {
+ sub = test.listen();
+ })
+ ..expectBroadcastListen((originalSub) {
+ originalSub.resume();
+ })
+ ..expectData(43)
+ ..expectResume(() {
+ test.close();
+ })
+ ..expectDone()
+ ..expectBroadcastCancel()
+ ..expectCancel(test.terminate);
+ sub = test.listen();
+ });
+}
+
main() {
testController();
testSingleController();
@@ -505,4 +575,5 @@ main() {
testPause();
testRethrow();
testBroadcastController();
+ testAsBroadcast();
}
« no previous file with comments | « sdk/lib/html/dartium/html_dartium.dart ('k') | tests/lib/async/stream_controller_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698