blob: 2ea739b54f71e625e5d15867ec3fed5ab107a9c0 [file] [log] [blame]
// 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.
// OtherResources=certificates/untrusted_server_chain.pem
// OtherResources=certificates/untrusted_server_key.pem
// OtherResources=certificates/trusted_certs.pem
// OtherResources=secure_unauthorized_client.dart
// This test verifies that failing secure connection attempts always complete
// their returned future.
import "package:expect/expect.dart";
import "package:path/path.dart";
import "dart:async";
import "dart:io";
const HOST_NAME = "localhost";
String localFile(path) => Platform.script.resolve(path).toFilePath();
SecurityContext serverContext = new SecurityContext()
..useCertificateChain(localFile('certificates/untrusted_server_chain.pem'))
..usePrivateKey(localFile('certificates/untrusted_server_key.pem'),
password: 'dartdart');
Future<SecureServerSocket> runServer() {
return SecureServerSocket
.bind(HOST_NAME, 0, serverContext)
.then((SecureServerSocket server) {
server.listen((SecureSocket socket) {
socket.listen((_) {}, onDone: () {
socket.close();
});
}, onError: (e) => Expect.isTrue(e is HandshakeException));
return server;
});
}
void main() {
var clientScript = localFile('secure_unauthorized_client.dart');
Future clientProcess(int port) {
List<String> args = new List<String>.from(Platform.executableArguments);
args.add(clientScript);
args.add(port.toString());
return Process.run(Platform.executable, args).then((ProcessResult result) {
if (result.exitCode != 0 || !result.stdout.contains('SUCCESS')) {
print("Client failed");
print(" stdout:");
print(result.stdout);
print(" stderr:");
print(result.stderr);
Expect.fail('Client subprocess exit code: ${result.exitCode}');
}
});
}
runServer().then((server) {
clientProcess(server.port).then((_) {
server.close();
});
});
}