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; | 5 library json_rpc_2.test.client.utils; |
6 | 6 |
7 import 'dart:async'; | 7 import 'dart:async'; |
8 import 'dart:convert'; | 8 import 'dart:convert'; |
9 | 9 |
10 import 'package:json_rpc_2/json_rpc_2.dart' as json_rpc; | 10 import 'package:json_rpc_2/json_rpc_2.dart' as json_rpc; |
11 import 'package:json_rpc_2/error_code.dart' as error_code; | 11 import 'package:json_rpc_2/error_code.dart' as error_code; |
12 import 'package:unittest/unittest.dart'; | 12 import 'package:test/test.dart'; |
13 | 13 |
14 /// A controller used to test a [json_rpc.Client]. | 14 /// A controller used to test a [json_rpc.Client]. |
15 class ClientController { | 15 class ClientController { |
16 /// The controller for the client's response stream. | 16 /// The controller for the client's response stream. |
17 final _responseController = new StreamController<String>(); | 17 final _responseController = new StreamController<String>(); |
18 | 18 |
19 /// The controller for the client's request sink. | 19 /// The controller for the client's request sink. |
20 final _requestController = new StreamController<String>(); | 20 final _requestController = new StreamController<String>(); |
21 | 21 |
22 /// The client. | 22 /// The client. |
(...skipping 33 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 | 56 /// 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. | 57 /// any code to run, as long as it's not waiting on some external event. |
58 Future pumpEventQueue([int times = 20]) { | 58 Future pumpEventQueue([int times = 20]) { |
59 if (times == 0) return new Future.value(); | 59 if (times == 0) return new Future.value(); |
60 // We use a delayed future to allow microtask events to finish. The | 60 // We use a delayed future to allow microtask events to finish. The |
61 // Future.value or Future() constructors use scheduleMicrotask themselves and | 61 // Future.value or Future() constructors use scheduleMicrotask themselves and |
62 // would therefore not wait for microtask callbacks that are scheduled after | 62 // would therefore not wait for microtask callbacks that are scheduled after |
63 // invoking this method. | 63 // invoking this method. |
64 return new Future.delayed(Duration.ZERO, () => pumpEventQueue(times - 1)); | 64 return new Future.delayed(Duration.ZERO, () => pumpEventQueue(times - 1)); |
65 } | 65 } |
OLD | NEW |