| // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| // |
| // VMOptions= |
| // VMOptions=--short_socket_read |
| // VMOptions=--short_socket_write |
| // VMOptions=--short_socket_read --short_socket_write |
| // OtherResources=certificates/server_chain.pem |
| // OtherResources=certificates/server_key.pem |
| // OtherResources=certificates/trusted_certs.pem |
| // OtherResources=certificates/server_chain.p12 |
| // OtherResources=certificates/server_key.p12 |
| // OtherResources=certificates/trusted_certs.p12 |
| |
| import "package:expect/async_helper.dart"; |
| import "package:expect/expect.dart"; |
| import "package:path/path.dart"; |
| import "dart:async"; |
| import "dart:io"; |
| |
| String localFile(path) => Platform.script.resolve(path).toFilePath(); |
| |
| SecurityContext serverContext(String certType, String password) => |
| new SecurityContext() |
| ..useCertificateChain( |
| localFile('certificates/server_chain.$certType'), |
| password: password, |
| ) |
| ..usePrivateKey( |
| localFile('certificates/server_key.$certType'), |
| password: password, |
| ); |
| |
| SecurityContext clientContext(String certType, String password) => |
| new SecurityContext()..setTrustedCertificates( |
| localFile('certificates/trusted_certs.$certType'), |
| password: password, |
| ); |
| |
| Future<HttpServer> startServer(String certType, String password) { |
| return HttpServer.bindSecure( |
| "localhost", |
| 0, |
| serverContext(certType, password), |
| backlog: 5, |
| ).then((server) { |
| server.listen((HttpRequest request) { |
| request.listen( |
| (_) {}, |
| onDone: () { |
| request.response.contentLength = 100; |
| for (int i = 0; i < 10; i++) { |
| request.response.add([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]); |
| } |
| request.response.close(); |
| }, |
| ); |
| }); |
| return server; |
| }); |
| } |
| |
| Future test(String certType, String password) { |
| List<int> body = <int>[]; |
| Completer completer = new Completer(); |
| startServer(certType, password).then((server) { |
| SecureSocket.connect( |
| "localhost", |
| server.port, |
| context: clientContext(certType, password), |
| ).then((socket) { |
| socket.write("GET / HTTP/1.0\r\nHost: localhost\r\n\r\n"); |
| socket.close(); |
| socket.listen( |
| (List<int> data) { |
| body.addAll(data); |
| }, |
| onDone: () { |
| Expect.isTrue(body.length > 100, "$body\n${body.length}"); |
| Expect.equals(72, body[0]); |
| Expect.equals(9, body[body.length - 1]); |
| server.close(); |
| completer.complete(null); |
| }, |
| onError: (e, trace) { |
| String msg = "Unexpected error $e"; |
| if (trace != null) msg += "\nStackTrace: $trace"; |
| Expect.fail(msg); |
| completer.complete(null); |
| }, |
| ); |
| }); |
| }); |
| return completer.future; |
| } |
| |
| void testConnectTimeout() { |
| asyncStart(); |
| Duration timeout = new Duration(milliseconds: 0); |
| // TODO(https://github.com/dart-lang/sdk/issues/60246): ensure that the |
| // exception was really caused by a timeout. |
| SecureSocket.connect("8.8.8.7", 80, timeout: timeout) |
| .then((socket) { |
| Expect.fail("Unexpected connection made."); |
| asyncEnd(); |
| }) |
| .catchError((e) { |
| Expect.isTrue(e is SocketException); |
| asyncEnd(); |
| }); |
| } |
| |
| main() async { |
| asyncStart(); |
| await test('pem', 'dartdart'); |
| await test('p12', 'dartdart'); |
| testConnectTimeout(); |
| asyncEnd(); |
| } |