OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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 test_utils; | 5 library test_utils; |
6 | 6 |
7 import 'dart:async'; | 7 import 'dart:async'; |
8 import 'dart:io'; | 8 import 'dart:io'; |
9 import 'dart:json' as json; | 9 import 'dart:json' as json; |
10 import 'dart:uri'; | 10 import 'dart:uri'; |
11 | 11 |
12 import 'package:http/http.dart' as http; | 12 import 'package:http/http.dart' as http; |
13 import 'package:http/src/byte_stream.dart'; | 13 import 'package:http/src/byte_stream.dart'; |
14 import 'package:http/src/utils.dart'; | 14 import 'package:http/src/utils.dart'; |
15 import 'package:unittest/unittest.dart'; | 15 import 'package:unittest/unittest.dart'; |
16 | 16 |
17 import 'safe_http_server.dart'; | 17 import 'safe_http_server.dart'; |
18 | 18 |
19 /// The current server instance. | 19 /// The current server instance. |
20 HttpServer _server; | 20 HttpServer _server; |
21 | 21 |
22 /// The URL for the current server instance. | 22 /// The URL for the current server instance. |
23 Uri get serverUrl => Uri.parse('http://localhost:${_server.port}'); | 23 Uri get serverUrl => Uri.parse('http://localhost:${_server.port}'); |
24 | 24 |
25 /// A dummy URL for constructing requests that won't be sent. | 25 /// A dummy URL for constructing requests that won't be sent. |
26 Uri get dummyUrl => Uri.parse('http://dartlang.org/'); | 26 Uri get dummyUrl => Uri.parse('http://dartlang.org/'); |
27 | 27 |
28 /// Starts a new HTTP server. | 28 /// Starts a new HTTP server. |
29 Future startServer() { | 29 Future startServer() { |
30 return SafeHttpServer.bind("localhost", 0).then((s) { | 30 return SafeHttpServer.bind("127.0.0.1", 0).then((s) { |
31 _server = s; | 31 _server = s; |
32 s.listen((request) { | 32 s.listen((request) { |
33 var path = request.uri.path; | 33 var path = request.uri.path; |
34 var response = request.response; | 34 var response = request.response; |
35 | 35 |
36 if (path == '/error') { | 36 if (path == '/error') { |
37 response.statusCode = 400; | 37 response.statusCode = 400; |
38 response.contentLength = 0; | 38 response.contentLength = 0; |
39 response.close(); | 39 response.close(); |
40 return; | 40 return; |
(...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
199 const isSocketIOException = const _SocketIOException(); | 199 const isSocketIOException = const _SocketIOException(); |
200 | 200 |
201 /// A matcher for functions that throw SocketIOException. | 201 /// A matcher for functions that throw SocketIOException. |
202 const Matcher throwsSocketIOException = | 202 const Matcher throwsSocketIOException = |
203 const Throws(isSocketIOException); | 203 const Throws(isSocketIOException); |
204 | 204 |
205 class _SocketIOException extends TypeMatcher { | 205 class _SocketIOException extends TypeMatcher { |
206 const _SocketIOException() : super("SocketIOException"); | 206 const _SocketIOException() : super("SocketIOException"); |
207 bool matches(item, MatchState matchState) => item is SocketIOException; | 207 bool matches(item, MatchState matchState) => item is SocketIOException; |
208 } | 208 } |
OLD | NEW |