OLD | NEW |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 library json_rpc_2.test.client.utils; | |
6 | |
7 import 'dart:async'; | 5 import 'dart:async'; |
8 import 'dart:convert'; | 6 import 'dart:convert'; |
9 | 7 |
10 import 'package:json_rpc_2/json_rpc_2.dart' as json_rpc; | 8 import 'package:json_rpc_2/json_rpc_2.dart' as json_rpc; |
11 import 'package:json_rpc_2/error_code.dart' as error_code; | 9 import 'package:json_rpc_2/error_code.dart' as error_code; |
12 import 'package:test/test.dart'; | 10 import 'package:test/test.dart'; |
13 | 11 |
14 /// A controller used to test a [json_rpc.Client]. | 12 /// A controller used to test a [json_rpc.Client]. |
15 class ClientController { | 13 class ClientController { |
16 /// The controller for the client's response stream. | 14 /// The controller for the client's response stream. |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
56 /// times. By default, this should pump the event queue enough times to allow | 54 /// times. By default, this should pump the event queue enough times to allow |
57 /// any code to run, as long as it's not waiting on some external event. | 55 /// any code to run, as long as it's not waiting on some external event. |
58 Future pumpEventQueue([int times = 20]) { | 56 Future pumpEventQueue([int times = 20]) { |
59 if (times == 0) return new Future.value(); | 57 if (times == 0) return new Future.value(); |
60 // We use a delayed future to allow microtask events to finish. The | 58 // We use a delayed future to allow microtask events to finish. The |
61 // Future.value or Future() constructors use scheduleMicrotask themselves and | 59 // Future.value or Future() constructors use scheduleMicrotask themselves and |
62 // would therefore not wait for microtask callbacks that are scheduled after | 60 // would therefore not wait for microtask callbacks that are scheduled after |
63 // invoking this method. | 61 // invoking this method. |
64 return new Future.delayed(Duration.ZERO, () => pumpEventQueue(times - 1)); | 62 return new Future.delayed(Duration.ZERO, () => pumpEventQueue(times - 1)); |
65 } | 63 } |
OLD | NEW |