The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;
do './testlib.pl' || do './t/testlib.pl' || die "no testlib";

$|=1;
print "1..16\n";


{
	# first use SSL client
	my ($server,$saddr) = create_listen_socket();
	ok( 1, "listening \@$saddr" );
	my $srv = fork_sub( 'server','ssl',$server );
	close($server);
	fd_grep_ok( 'Waiting', $srv );
	my $cl = fork_sub( 'client',$saddr );
	fd_grep_ok( 'Connect from',$srv );
	fd_grep_ok( 'Connected', $cl );
	fd_grep_ok( 'SSL Handshake OK', $srv );
	fd_grep_ok( 'SSL Handshake OK', $cl );
	fd_grep_ok( 'Hi!', $cl );
}

if ( $^O =~m{mswin32}i ) {
	# skip
	ok( 1, "skip - TODO on win32" ) for(1..7);
} else {
	# then try bad non-SSL client
	my ($server,$saddr) = create_listen_socket();
	ok( 1, "listening \@$saddr" );
	my $srv = fork_sub( 'server','nossl',$server );
	close($server);
	fd_grep_ok( 'Waiting', $srv );
	my $cl = fork_sub( 'client',$saddr );
	fd_grep_ok( 'Connect from',$srv );
	fd_grep_ok( 'Connected', $cl );
	fd_grep_ok( 'SSL Handshake FAILED', $cl );
}


sub server {
	my ($behavior,$server) = @_;
	print "Waiting\n";
	my $client = $server->accept || die "accept failed: $!";
	print "Connect from ".$client->peerhost.':'.$client->peerport."\n";
	if ( $behavior eq 'ssl' ) {
		if ( IO::Socket::SSL->start_SSL( $client, SSL_server => 1, Timeout => 30 )) {
			print "SSL Handshake OK\n";
			print $client "Hi!\n";
		}
	} else {
		while ( sysread( $client, my $buf,8000 )) {}
	}
}

sub client {
	my $saddr = shift;
	my $c = IO::Socket::INET->new( $saddr ) || die "connect failed: $!";
	print "Connected\n";
	if ( IO::Socket::SSL->start_SSL( $c, Timeout => 5, SSL_verify_mode => 0 )) {
		 print "SSL Handshake OK\n";
		 print <$c>
	} else {
		print "SSL Handshake FAILED - $!\n";
	}
}