blob: 67162a5aca6d4557484a2179f386ea079f7e6166 [file] [log] [blame]
// Copyright (c) 2012, 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.
import "dart:async";
import "dart:io";
import "dart:uri";
import "dart:isolate";
const SERVER_ADDRESS = "127.0.0.1";
const HOST_NAME = "localhost";
int numClientCertificatesReceived = 0;
Function test(Map options) {
Future runTest([var unused]) {
var completer = new Completer();
HttpsServer server = new HttpsServer();
Expect.throws(() => server.port);
server.defaultRequestHandler =
(HttpRequest request, HttpResponse response) {
if (request.path == '/true') {
// Client certificate sent
numClientCertificatesReceived++;
Expect.isNotNull(request.certificate);
Expect.equals('CN=localhost', request.certificate.subject);
} else {
Expect.equals('/false', request.path);
Expect.isNull(request.certificate);
}
request.inputStream.onClosed = () {
response.outputStream.close();
};
};
server.listen(SERVER_ADDRESS,
0,
backlog: 5,
certificate_name: 'CN=$HOST_NAME',
requestClientCertificate: true);
HttpClient client = new HttpClient();
Future testConnect(bool sendCertificate) {
client.sendClientCertificate = sendCertificate;
client.clientCertificate = options['certificateName'];
var completer = new Completer();
HttpClientConnection conn =
client.getUrl(Uri.parse(
"https://$HOST_NAME:${server.port}/$sendCertificate"));
conn.onRequest = (HttpClientRequest request) {
request.outputStream.close();
};
conn.onResponse = (HttpClientResponse response) {
Expect.isNotNull(response.certificate);
Expect.equals('CN=myauthority', response.certificate.issuer);
response.inputStream.onClosed = () {
completer.complete(false); // Chained call will not send cert.
};
};
conn.onError = (Exception e) {
Expect.fail("Unexpected error in Https Client: $e");
};
return completer.future;
}
testConnect(true).then(testConnect).then((_) {
client.shutdown();
server.close();
Expect.throws(() => server.port);
// Run second test with a certificate name.
completer.complete(null);
});
return completer.future;
}
return runTest;
}
void InitializeSSL() {
var testPkcertDatabase =
new Path(new Options().script).directoryPath.append('pkcert/');
SecureSocket.initialize(database: testPkcertDatabase.toNativePath(),
password: 'dartdart');
}
void main() {
var keepAlive = new ReceivePort();
InitializeSSL();
// Test two connections in sequence.
test({'certificateName': null})()
.then((_) => test({'certificateName': 'localhost_cert'})())
.then((_) {
Expect.equals(2, numClientCertificatesReceived);
keepAlive.close();
});
}