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.server.util; | 5 library json_rpc_2.test.server.util; |
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.Server]. | 14 /// A controller used to test a [json_rpc.Server]. |
15 class ServerController { | 15 class ServerController { |
16 /// The controller for the server's request stream. | 16 /// The controller for the server's request stream. |
17 final _requestController = new StreamController<String>(); | 17 final _requestController = new StreamController<String>(); |
18 | 18 |
19 /// The controller for the server's response sink. | 19 /// The controller for the server's response sink. |
20 final _responseController = new StreamController<String>(); | 20 final _responseController = new StreamController<String>(); |
21 | 21 |
22 /// The server. | 22 /// The server. |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
90 /// times. By default, this should pump the event queue enough times to allow | 90 /// times. By default, this should pump the event queue enough times to allow |
91 /// any code to run, as long as it's not waiting on some external event. | 91 /// any code to run, as long as it's not waiting on some external event. |
92 Future pumpEventQueue([int times = 20]) { | 92 Future pumpEventQueue([int times = 20]) { |
93 if (times == 0) return new Future.value(); | 93 if (times == 0) return new Future.value(); |
94 // We use a delayed future to allow microtask events to finish. The | 94 // We use a delayed future to allow microtask events to finish. The |
95 // Future.value or Future() constructors use scheduleMicrotask themselves and | 95 // Future.value or Future() constructors use scheduleMicrotask themselves and |
96 // would therefore not wait for microtask callbacks that are scheduled after | 96 // would therefore not wait for microtask callbacks that are scheduled after |
97 // invoking this method. | 97 // invoking this method. |
98 return new Future.delayed(Duration.ZERO, () => pumpEventQueue(times - 1)); | 98 return new Future.delayed(Duration.ZERO, () => pumpEventQueue(times - 1)); |
99 } | 99 } |
OLD | NEW |