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 // VMOptions= | 5 // VMOptions= |
6 // VMOptions=--short_socket_read | 6 // VMOptions=--short_socket_read |
7 // VMOptions=--short_socket_write | 7 // VMOptions=--short_socket_write |
8 // VMOptions=--short_socket_read --short_socket_write | 8 // VMOptions=--short_socket_read --short_socket_write |
9 | 9 |
10 import "package:expect/expect.dart"; | 10 import "package:expect/expect.dart"; |
11 import "dart:async"; | 11 import "dart:async"; |
12 import "dart:io"; | 12 import "dart:io"; |
13 import "dart:isolate"; | 13 import "dart:isolate"; |
14 import "dart:typeddata"; | 14 import "dart:typeddata"; |
15 import "dart:uri"; | 15 import "dart:uri"; |
16 | 16 |
17 const String CERT_NAME = 'localhost_cert'; | 17 const String CERT_NAME = 'localhost_cert'; |
18 const String SERVER_ADDRESS = '127.0.0.1'; | |
19 const String HOST_NAME = 'localhost'; | 18 const String HOST_NAME = 'localhost'; |
20 | 19 |
21 /** | 20 /** |
22 * A SecurityConfiguration lets us run the tests over HTTP or HTTPS. | 21 * A SecurityConfiguration lets us run the tests over HTTP or HTTPS. |
23 */ | 22 */ |
24 class SecurityConfiguration { | 23 class SecurityConfiguration { |
25 final bool secure; | 24 final bool secure; |
26 | 25 |
27 SecurityConfiguration({bool this.secure}); | 26 SecurityConfiguration({bool this.secure}); |
28 | 27 |
29 Future<HttpServer> createServer({int backlog: 0}) => | 28 Future<HttpServer> createServer({int backlog: 0}) => |
30 secure ? HttpServer.bindSecure(SERVER_ADDRESS, | 29 secure ? HttpServer.bindSecure(HOST_NAME, |
31 0, | 30 0, |
32 backlog: backlog, | 31 backlog: backlog, |
33 certificateName: CERT_NAME) | 32 certificateName: CERT_NAME) |
34 : HttpServer.bind(SERVER_ADDRESS, | 33 : HttpServer.bind(HOST_NAME, |
35 0, | 34 0, |
36 backlog); | 35 backlog); |
37 | 36 |
38 Future<WebSocket> createClient(int port) => | 37 Future<WebSocket> createClient(int port) => |
39 WebSocket.connect('${secure ? "wss" : "ws"}://$HOST_NAME:$port/'); | 38 WebSocket.connect('${secure ? "wss" : "ws"}://$HOST_NAME:$port/'); |
40 | 39 |
41 void testRequestResponseClientCloses(int totalConnections, | 40 void testRequestResponseClientCloses(int totalConnections, |
42 int closeStatus, | 41 int closeStatus, |
43 String closeReason) { | 42 String closeReason) { |
44 createServer().then((server) { | 43 createServer().then((server) { |
(...skipping 358 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
403 SecureSocket.initialize(database: testPkcertDatabase.toNativePath(), | 402 SecureSocket.initialize(database: testPkcertDatabase.toNativePath(), |
404 password: "dartdart"); | 403 password: "dartdart"); |
405 } | 404 } |
406 | 405 |
407 | 406 |
408 main() { | 407 main() { |
409 new SecurityConfiguration(secure: false).runTests(); | 408 new SecurityConfiguration(secure: false).runTests(); |
410 initializeSSL(); | 409 initializeSSL(); |
411 new SecurityConfiguration(secure: true).runTests(); | 410 new SecurityConfiguration(secure: true).runTests(); |
412 } | 411 } |
OLD | NEW |