blob: 882016ea1181941025233df964dd2348d142de40 [file] [log] [blame] [edit]
// Copyright (c) 2024, 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.
/// @assertion bool get isPaused
/// Whether the subscription would need to buffer events.
///
/// This is the case if the controller's stream has a listener and it is paused,
/// or if it has not received a listener yet. In that case, the controller is
/// considered paused as well.
///
/// A broadcast stream controller is never considered paused. It always forwards
/// its events to all uncanceled subscriptions, if any, and let the
/// subscriptions handle their own pausing and buffering.
///
/// @description Checks that this getter returns `true` if the stream is paused
/// and `false` otherwise.
/// @author sgrekhov22@gmail.com
import "dart:async";
import "../../../Utils/expect.dart";
main() {
asyncStart();
var controllers = <MultiStreamController<int>>[];
var stream = Stream<int>.multi((controller) {
controllers.add(controller);
Expect.isFalse(controller.isPaused);
controller.add(1);
controller.add(2);
controller.add(3);
});
listen(stream);
listen(stream);
Future.delayed(Duration(milliseconds: 200), () {
controllers.forEach((c) {
Expect.isTrue(c.isPaused);
});
asyncEnd();
});
}
void listen(Stream<int> stream) {
late StreamSubscription ss;
ss = stream.listen((v) {
ss.pause();
});
}