summaryrefslogtreecommitdiff
path: root/source4/selftest/Subunit.pm
diff options
context:
space:
mode:
authorStefan Metzmacher <metze@sernet.de>2008-03-17 15:17:19 +0100
committerStefan Metzmacher <metze@samba.org>2008-03-17 15:50:49 +0100
commit0de47f6b577fdb1e93395b56960951b32cca48c0 (patch)
tree112d7a2b0f49185c32f248aeb6bd12daab4555fc /source4/selftest/Subunit.pm
parent3e8124bc66503f1531ace71b64262aa2c26c3800 (diff)
downloadsamba-0de47f6b577fdb1e93395b56960951b32cca48c0.tar.gz
samba-0de47f6b577fdb1e93395b56960951b32cca48c0.tar.bz2
samba-0de47f6b577fdb1e93395b56960951b32cca48c0.zip
selftest: handle progress output in verbose mode
metze (This used to be commit 9196213c49532ac60349ff55e66430b7c80b09c2)
Diffstat (limited to 'source4/selftest/Subunit.pm')
-rw-r--r--source4/selftest/Subunit.pm29
1 files changed, 28 insertions, 1 deletions
diff --git a/source4/selftest/Subunit.pm b/source4/selftest/Subunit.pm
index e5c61ca9ba..f8a7794aac 100644
--- a/source4/selftest/Subunit.pm
+++ b/source4/selftest/Subunit.pm
@@ -15,7 +15,34 @@ sub parse_results($$$$$)
my $unexpected_err = 0;
my $orig_open_len = $#$open_tests;
- while(<$fh>) {
+ while(1) {
+ my $line = "";
+ my $char = "";
+ my $eof = 0;
+ my $error = 0;
+
+ while ($char ne "\n") {
+ my $ret = sysread($fh, $char, 1);
+ if (not defined($ret)) {
+ $error = $!;
+ last;
+ }
+ if ($ret == 0) {
+ $eof = 1;
+ last;
+ }
+
+ $line .= $char;
+ if ($char eq "\r") {
+ $msg_ops->output_msg($line);
+ $line = "";
+ }
+ }
+
+ last if ($eof or $error);
+
+ $_ = $line;
+
if (/^test: (.+)\n/) {
$msg_ops->control_msg($_);
$msg_ops->start_test($open_tests, $1);