|  | // Copyright (c) 2020, 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. | 
|  |  | 
|  | import 'dart:async'; | 
|  |  | 
|  | import 'package:expect/legacy/async_minitest.dart'; // ignore: deprecated_member_use | 
|  |  | 
|  | const ms = const Duration(milliseconds: 1); | 
|  |  | 
|  | /// Allows two asynchronous executions to synchronize. | 
|  | /// | 
|  | /// Calling [wait] and waiting for the returned future to complete will wait for | 
|  | /// the other executions to call [wait] again. At that point, the waiting | 
|  | /// execution is allowed to continue (the returned future completes), and the | 
|  | /// more resent call to [wait] is now the waiting execution. | 
|  | class Sync { | 
|  | Completer? _completer = null; | 
|  | // Release whoever is currently waiting and start waiting yourself. | 
|  | Future wait([v]) { | 
|  | _completer?.complete(v); | 
|  | _completer = Completer(); | 
|  | return _completer!.future; | 
|  | } | 
|  |  | 
|  | // Release whoever is currently waiting. | 
|  | void release([v]) { | 
|  | _completer?.complete(v); | 
|  | _completer = null; | 
|  | } | 
|  | } | 
|  |  | 
|  | expectList(stream, list) { | 
|  | return stream.toList().then((v) { | 
|  | expect(v, equals(list)); | 
|  | }); | 
|  | } | 
|  |  | 
|  | Stream<int> mkStream(int n) async* { | 
|  | for (int i = 0; i < n; i++) yield i; | 
|  | } |