summaryrefslogtreecommitdiff
path: root/regress/usr.sbin/relayd/funcs.pl
diff options
context:
space:
mode:
Diffstat (limited to 'regress/usr.sbin/relayd/funcs.pl')
-rw-r--r--regress/usr.sbin/relayd/funcs.pl115
1 files changed, 67 insertions, 48 deletions
diff --git a/regress/usr.sbin/relayd/funcs.pl b/regress/usr.sbin/relayd/funcs.pl
index 06fffffe344..27f77a60a19 100644
--- a/regress/usr.sbin/relayd/funcs.pl
+++ b/regress/usr.sbin/relayd/funcs.pl
@@ -1,6 +1,6 @@
-# $OpenBSD: funcs.pl,v 1.22 2016/05/03 19:13:04 bluhm Exp $
+# $OpenBSD: funcs.pl,v 1.23 2017/07/14 14:41:03 bluhm Exp $
-# Copyright (c) 2010-2015 Alexander Bluhm <bluhm@openbsd.org>
+# Copyright (c) 2010-2017 Alexander Bluhm <bluhm@openbsd.org>
#
# Permission to use, copy, modify, and distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
@@ -51,25 +51,27 @@ sub find_ports {
sub write_syswrite {
my $self = shift;
my $buf = shift;
- my $len = 0;
- my $size = length($buf);
- my $r = 0;
+ IO::Handle::flush(\*STDOUT);
+ my $size = length($buf);
+ my $len = 0;
while ($len < $size) {
- while (($r = syswrite(STDOUT, $buf, $size, $len))) {
- $len += $r;
- if ($r != $size) {
- print STDERR "short write (only $r bytes)\n";
- }
+ my $n = syswrite(STDOUT, $buf, $size, $len);
+ if (!defined($n)) {
+ $!{EWOULDBLOCK}
+ or die ref($self), " syswrite failed: $!";
+ print STDERR "blocked write at $len of $size: $!\n";
+ next;
}
- if ($len != $size) {
- print STDERR "short write ($!)\n";
+ if ($len + $n != $size) {
+ print STDERR "short write $n at $len of $size\n";
}
+ $len += $n;
}
return $len;
}
-sub write_blocks {
+sub write_block {
my $self = shift;
my $len = shift;
@@ -79,22 +81,30 @@ sub write_blocks {
my $rest = $len % 1000;
for (my $i = 1; $i <= 100 ; $i++) {
- $data .= '012345678'."\n";
+ $data .= "012345678\n";
}
+ my $opct = 0;
for (my $i = 1; $i <= $blocks; $i++) {
- $outb += write_syswrite($self,$data);
- print STDERR ".";
+ $outb += write_syswrite($self, $data);
+ my $pct = ($outb / $len) * 100.0;
+ if ($pct >= $opct + 1) {
+ printf(STDERR "%.2f%% $outb/$len\n", $pct);
+ $opct = $pct;
+ }
}
if ($rest>0) {
for (my $i = 1; $i < $rest-1 ; $i++) {
- $outb += write_syswrite($self,'r');
- print STDERR ".";
+ $outb += write_syswrite($self, 'r');
+ my $pct = ($outb / $len) * 100.0;
+ if ($pct >= $opct + 1) {
+ printf(STDERR "%.2f%% $outb/$len\n", $pct);
+ $opct = $pct;
+ }
}
}
- print STDERR "\n";
- $outb += write_syswrite($self,"\n\n");
+ $outb += write_syswrite($self, "\n\n");
IO::Handle::flush(\*STDOUT);
print STDERR "LEN: ", $outb, "\n";
}
@@ -105,7 +115,7 @@ sub write_char {
my $sleep = $self->{sleep};
if ($self->{fast}) {
- write_blocks($self,$len);
+ write_block($self, $len);
return;
}
@@ -273,7 +283,8 @@ sub http_response {
if ($chunked) {
read_chunked($self);
} else {
- read_char($self, $vers eq "1.1" ? $len : undef)
+ undef $len unless defined($vers) && $vers eq "1.1";
+ read_char($self, $len)
if $method eq "GET";
}
}
@@ -327,25 +338,27 @@ sub errignore {
}
########################################################################
-# Server funcs
+# Common funcs
########################################################################
-sub read_char_fast {
+sub read_char {
my $self = shift;
my $max = shift // $self->{max};
+ if ($self->{fast}) {
+ read_block($self, $max);
+ return;
+ }
+
my $ctx = Digest::MD5->new();
my $len = 0;
if (defined($max) && $max == 0) {
print STDERR "Max\n";
} else {
- while ((my $r = sysread(STDIN, my $buf, POSIX::BUFSIZ))) {
- my $pct;
- $_ = $buf;
- $len += $r;
+ while (<STDIN>) {
+ $len += length($_);
$ctx->add($_);
- $pct = ($len / $max) * 100.0;
- printf(STDERR "%.2f%%\n", $pct);
+ print STDERR ".";
if (defined($max) && $len >= $max) {
print STDERR "\nMax";
last;
@@ -358,36 +371,42 @@ sub read_char_fast {
print STDERR "MD5: ", $ctx->hexdigest, "\n";
}
-sub read_char {
+sub read_block {
my $self = shift;
my $max = shift // $self->{max};
- if ($self->{fast}) {
- read_char_fast($self,$max);
- return;
- }
-
+ my $opct = 0;
my $ctx = Digest::MD5->new();
my $len = 0;
- if (defined($max) && $max == 0) {
- print STDERR "Max\n";
- } else {
- while (<STDIN>) {
- $len += length($_);
- $ctx->add($_);
- print STDERR ".";
- if (defined($max) && $len >= $max) {
- print STDERR "\nMax";
- last;
- }
+ for (;;) {
+ if (defined($max) && $len >= $max) {
+ print STDERR "Max\n";
+ last;
+ }
+ my $rlen = POSIX::BUFSIZ;
+ if (defined($max) && $rlen > $max - $len) {
+ $rlen = $max - $len;
+ }
+ defined(my $n = read(STDIN, my $buf, $rlen))
+ or die ref($self), " read failed: $!";
+ $n or last;
+ $len += $n;
+ $ctx->add($buf);
+ my $pct = ($len / $max) * 100.0;
+ if ($pct >= $opct + 1) {
+ printf(STDERR "%.2f%% $len/$max\n", $pct);
+ $opct = $pct;
}
- print STDERR "\n";
}
print STDERR "LEN: ", $len, "\n";
print STDERR "MD5: ", $ctx->hexdigest, "\n";
}
+########################################################################
+# Server funcs
+########################################################################
+
sub http_server {
my $self = shift;
my %header = %{$self->{header} || { Server => "Perl/".$^V }};