Replaced the messy GNU-styled, multi-lingual documents with a single Markdown README.md. Added the GitHub repository to the document and removed the SourceForge website, my web page, and the SourceForge mailing list from the document. Removed the document license, and my PGP key from the package. Removed the signature file from the repository. Changed the license from GPLv3 to APLv2. Various fixes to avoid JetBrains IDE problem detection.
This commit is contained in:
@ -1,17 +1,23 @@
|
||||
#!/usr/bin/perl
|
||||
|
||||
use strict;
|
||||
print "1..1\n";
|
||||
|
||||
if (!-s 'SIGNATURE') {
|
||||
if (!$ENV{TEST_SIGNATURE}) {
|
||||
print "ok 1 # skip Set the environment variable",
|
||||
" TEST_SIGNATURE to enable this test\n";
|
||||
}
|
||||
elsif (!-s 'SIGNATURE') {
|
||||
print "ok 1 # skip No signature file found\n";
|
||||
}
|
||||
elsif (!eval { require Module::Signature; 1 }) {
|
||||
print "ok 1 # skip ",
|
||||
"Next time around, consider install Module::Signature, ",
|
||||
"so you can verify the integrity of this distribution.\n";
|
||||
"Next time around, consider install Module::Signature, ",
|
||||
"so you can verify the integrity of this distribution.\n";
|
||||
}
|
||||
elsif (!eval { require Socket; Socket::inet_aton('pgp.mit.edu') }) {
|
||||
print "ok 1 # skip Cannot connect to the keyserver\n";
|
||||
elsif (!eval { require Socket; Socket::inet_aton('pool.sks-keyservers.net') }) {
|
||||
print "ok 1 # skip ",
|
||||
"Cannot connect to the keyserver\n";
|
||||
}
|
||||
else {
|
||||
(Module::Signature::verify() == Module::Signature::SIGNATURE_OK())
|
||||
|
123
t/01-exhaust.t
123
t/01-exhaust.t
@ -1,20 +1,19 @@
|
||||
#! /usr/bin/perl -w
|
||||
# Test all the possible combination of options
|
||||
|
||||
# Copyright (c) 2007 imacat
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# Copyright (c) 2007-2021 imacat.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
use 5.005;
|
||||
use strict;
|
||||
@ -30,7 +29,7 @@ use File::Spec::Functions qw(catdir catfile updir);
|
||||
use FindBin;
|
||||
use lib $FindBin::Bin;
|
||||
use _helper;
|
||||
use vars qw($WORKDIR $arclog $tno);
|
||||
our ($WORKDIR, $arclog, $tno);
|
||||
|
||||
$WORKDIR = catdir($FindBin::Bin, "logs");
|
||||
$arclog = catfile($FindBin::Bin, updir, "blib", "script", "arclog");
|
||||
@ -38,105 +37,105 @@ $tno = 0;
|
||||
|
||||
# 1-2160: All possible option combinations
|
||||
# Test each log file format
|
||||
foreach my $fmt (@LOGFMTS) {
|
||||
foreach my $fmt (@LOG_FORMATS) {
|
||||
# Test each source log file type
|
||||
foreach my $st (@SRCTYPES) {
|
||||
foreach my $st (@SOURCE_TYPES) {
|
||||
# Test each result file type
|
||||
foreach my $rt (@RESTYPES) {
|
||||
# Test each keep type
|
||||
foreach my $kt (@KEEPTYPES) {
|
||||
# Test each override type
|
||||
foreach my $ot (@OVERTYPES) {
|
||||
foreach my $rt (@RESULT_TYPES) {
|
||||
# Test each keep mode
|
||||
foreach my $keep (@KEEP_MODES) {
|
||||
# Test each override mode
|
||||
foreach my $override (@OVERRIDE_MODES) {
|
||||
$_ = eval {
|
||||
return if $$st{"skip"} || $$rt{"skip"};
|
||||
my ($title, $cmd, $retno, $out, $err, $vardump, $logfile);
|
||||
my ($title, $cmd, $ret_no, $out, $err, $var_dump, $logfile);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($fs, $cs, %cem, @mle, $mt, %cof);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$title = join ", ", ($$fmt{"title"}, $$st{"title"},
|
||||
$$rt{"title"}, $$kt{"title"}, $$ot{"title"});
|
||||
$logfile = randword;
|
||||
$$rt{"title"}, $$keep{"title"}, $$override{"title"});
|
||||
$logfile = random_word;
|
||||
$fs = catfile($WORKDIR, $logfile . $$st{"suf"});
|
||||
($cs, $vardump, %cem) = &{$$fmt{"sub"}}($fs);
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
($cs, $var_dump, %cem) = &{$$fmt{"sub"}}($fs);
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
@mle = sort keys %cem;
|
||||
$mt = pop @mle if $$kt{"tm"};
|
||||
if ($$ot{"mkex"}) {
|
||||
%cof = mkrndlog_existing $$fmt{"sub"},
|
||||
$mt = pop @mle if $$keep{"tm"};
|
||||
if ($$override{"exists"}) {
|
||||
%cof = make_log_file $$fmt{"sub"},
|
||||
$WORKDIR, "$logfile.%s" . $$rt{"suf"}, @mle;
|
||||
} else {
|
||||
%cof = map { "$logfile.$_" . $$rt{"suf"} => "" }
|
||||
@mle;
|
||||
}
|
||||
@fle = qw();
|
||||
push @fle, basename($fs) if !$$kt{"del"};
|
||||
push @fle, "$logfile.vardump";
|
||||
if ($$ot{"ok"}) {
|
||||
push @fle, basename($fs) if !$$keep{"del"};
|
||||
push @fle, "$logfile.var-dump";
|
||||
if ($$override{"ok"}) {
|
||||
push @fle, map "$logfile.$_" . $$rt{"suf"}, @mle;
|
||||
} else {
|
||||
push @fle, "$logfile.tmp-arclog" if $$kt{"tmp"};
|
||||
push @fle, "$logfile.tmp-arclog" if $$keep{"tmp"};
|
||||
push @fle, grep $cof{$_} ne "", keys %cof;
|
||||
}
|
||||
prsrvsrc $WORKDIR;
|
||||
if (!$$kt{"stdin"}) {
|
||||
@_ = ($arclog, qw(-d -d -d), @{$$kt{"opts"}},
|
||||
@{$$ot{"opts"}}, @{$$rt{"opts"}}, $fs);
|
||||
preserve_source $WORKDIR;
|
||||
if (!$$keep{"stdin"}) {
|
||||
@_ = ($arclog, qw(-d -d -d), @{$$keep{"opts"}},
|
||||
@{$$override{"opts"}}, @{$$rt{"opts"}}, $fs);
|
||||
$cmd = join " ", @_;
|
||||
($retno, $out, $err) = runcmd "", @_;
|
||||
($ret_no, $out, $err) = run_cmd "", @_;
|
||||
} else {
|
||||
@_ = ($arclog, qw(-d -d -d), @{$$kt{"opts"}},
|
||||
@{$$ot{"opts"}}, @{$$rt{"opts"}}, "-",
|
||||
@_ = ($arclog, qw(-d -d -d), @{$$keep{"opts"}},
|
||||
@{$$override{"opts"}}, @{$$rt{"opts"}}, "-",
|
||||
catfile($WORKDIR, $logfile));
|
||||
$cmd = join(" ", @_) . " < " . $fs;
|
||||
($retno, $out, $err) = runcmd frread $fs, @_;
|
||||
($ret_no, $out, $err) = run_cmd read_raw_file $fs, @_;
|
||||
}
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
%trf = qw(); # Resulted file type by file
|
||||
if (!$$kt{"del"}) {
|
||||
if (!$$keep{"del"}) {
|
||||
$fr = $fs;
|
||||
$frb = basename($fr);
|
||||
$cef{$frb} = !$$kt{"tmp"}? $cs:
|
||||
!$$ot{"ok"}? "":
|
||||
$$kt{"tm"}? $cem{$mt}: "";
|
||||
$cef{$frb} = !$$keep{"tmp"}? $cs:
|
||||
!$$override{"ok"}? "":
|
||||
$$keep{"tm"}? $cem{$mt}: "";
|
||||
$tef{$frb} = $$st{"type"};
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
if (!$$ot{"ok"} && $$kt{"tmp"}) {
|
||||
if (!$$override{"ok"} && $$keep{"tmp"}) {
|
||||
$frb = "$logfile.tmp-arclog";
|
||||
$fr = catfile($WORKDIR, $frb);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs, TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs, TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
$frb = "$logfile.vardump";
|
||||
$frb = "$logfile.var-dump";
|
||||
$fr = catfile($WORKDIR, $frb);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump, TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump, TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
foreach my $m (@mle) {
|
||||
$frb = "$logfile.$m" . $$rt{"suf"};
|
||||
$fr = catfile($WORKDIR, $frb);
|
||||
$cef{$frb} = &{$$ot{"ce"}}($cof{$frb}, $cem{$m});
|
||||
$cef{$frb} = &{$$override{"ce"}}($cof{$frb}, $cem{$m});
|
||||
$tef{$frb} = $$rt{"type"};
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
die "$title\n$cmd\n$out$err"
|
||||
unless $$ot{"ok"}? $retno == 0: $retno != 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nVariables: $vardump\nOutput:\n$out$err"
|
||||
unless $$override{"ok"}? $ret_no == 0: $ret_no != 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nVariables: $var_dump\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nVariables: $vardump\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr}
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nVariables: $var_dump\nOutput:\n$out$err"
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr}
|
||||
|| ($tef{$fr} eq TYPE_BZIP2 && -z catfile($WORKDIR, $fr));
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nVariables: $vardump\nOutput:\n$out$err"
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nVariables: $var_dump\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
skip($$st{"skip"} || $$rt{"skip"}, $_, 1, $@);
|
||||
cleanup $_ || $$st{"skip"} || $$rt{"skip"}, $WORKDIR, ++$tno;
|
||||
clean_up $_ || $$st{"skip"} || $$rt{"skip"}, $WORKDIR, ++$tno;
|
||||
die unless $_ || $$st{"skip"} || $$rt{"skip"};
|
||||
}
|
||||
}
|
||||
|
211
t/02-several.t
211
t/02-several.t
@ -1,20 +1,19 @@
|
||||
#! /usr/bin/perl -w
|
||||
# Test archiving several log files at once
|
||||
|
||||
# Copyright (c) 2007 imacat
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# Copyright (c) 2007-2021 imacat.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
use 5.005;
|
||||
use strict;
|
||||
@ -30,87 +29,87 @@ use File::Spec::Functions qw(catdir catfile updir);
|
||||
use FindBin;
|
||||
use lib $FindBin::Bin;
|
||||
use _helper;
|
||||
use vars qw($WORKDIR $arclog $tno);
|
||||
our ($WORKDIR, $arclog, $tno);
|
||||
|
||||
$WORKDIR = catdir($FindBin::Bin, "logs");
|
||||
$arclog = catfile($FindBin::Bin, updir, "blib", "script", "arclog");
|
||||
$tno = 0;
|
||||
|
||||
# 1-16: Archiving several log files at once
|
||||
foreach my $rt (@RESTYPES) {
|
||||
foreach my $rt (@RESULT_TYPES) {
|
||||
my $skip;
|
||||
$skip = 0;
|
||||
# 1: Source log files listed as the arguments
|
||||
$_ = eval {
|
||||
if ( ($$rt{"type"} eq TYPE_GZIP && nogzip)
|
||||
|| ($$rt{"type"} eq TYPE_BZIP2 && nobzip2)) {
|
||||
if ( ($$rt{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
|| ($$rt{"type"} eq TYPE_BZIP2 && has_no_bzip2)) {
|
||||
$skip = 1;
|
||||
return;
|
||||
}
|
||||
my ($title, $cmd, $retno, $out, $err, @vardump, %logfiles);
|
||||
my ($title, $cmd, $ret_no, $out, $err, @var_dump, %logfiles);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($num, @fs, @cs, @cem, @mle, %cof, $opref, $oprfb, $mt);
|
||||
my (@st, $fmt);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$fmt = $LOGFMTS[int rand @LOGFMTS];
|
||||
$fmt = $LOG_FORMATS[int rand @LOG_FORMATS];
|
||||
$title = join ", ", "several log files", "all listed as arguments",
|
||||
$$fmt{"title"}, $$rt{"title"};
|
||||
# (2-4 times available compression) log files
|
||||
$_ = 2 + (nogzip? 0: 2) + (nobzip2? 0: 2);
|
||||
$_ = 2 + (has_no_gzip? 0: 2) + (has_no_bzip2? 0: 2);
|
||||
$num = $_ + int rand $_;
|
||||
%_ = qw();
|
||||
my %types = qw();
|
||||
# At least 2 files for each available compression
|
||||
foreach my $st (@SRCTYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && nogzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
foreach my $st (@SOURCE_TYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
}
|
||||
# Set random compression on the rest files
|
||||
foreach (grep !exists $_{$_}, (0...$num-1)) {
|
||||
foreach (grep !exists $types{$_}, (0...$num-1)) {
|
||||
do {
|
||||
$_{$_} = $SRCTYPES[int rand @SRCTYPES];
|
||||
} until !(${$_{$_}}{"type"} eq TYPE_GZIP && nogzip)
|
||||
&& !(${$_{$_}}{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
$types{$_} = $SOURCE_TYPES[int rand @SOURCE_TYPES];
|
||||
} until !(${$types{$_}}{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
&& !(${$types{$_}}{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
}
|
||||
@st = map $_{$_}, (0...$num-1);
|
||||
@st = map $types{$_}, (0...$num-1);
|
||||
@fs = qw();
|
||||
@cs = qw();
|
||||
@cem = qw();
|
||||
@vardump = qw();
|
||||
@var_dump = qw();
|
||||
@fle = qw();
|
||||
%logfiles = qw();
|
||||
for (my $k = 0; $k < $num; $k++) {
|
||||
my ($logfile, $cs, $vardump);
|
||||
do { $logfile = randword } until !exists $logfiles{$logfile};
|
||||
my ($logfile, $cs, $var_dump);
|
||||
do { $logfile = random_word } until !exists $logfiles{$logfile};
|
||||
$logfiles{$logfile} = 1;
|
||||
$logfile .= ${$st[$k]}{"suf"};
|
||||
push @fs, catfile($WORKDIR, $logfile);
|
||||
($cs, $vardump, %_) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
($cs, $var_dump, %types) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
push @cs, $cs;
|
||||
push @cem, {%_};
|
||||
push @cem, {%types};
|
||||
push @fle, $logfile;
|
||||
push @vardump, $vardump;
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
push @fle, "$logfile.vardump";
|
||||
push @var_dump, $var_dump;
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
push @fle, "$logfile.var-dump";
|
||||
}
|
||||
%_ = qw();
|
||||
%_ = (%_, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %_;
|
||||
%types = qw();
|
||||
%types = (%types, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %types;
|
||||
$mt = pop @mle;
|
||||
do { $oprfb = randword } until !exists $logfiles{$oprfb};
|
||||
do { $oprfb = random_word } until !exists $logfiles{$oprfb};
|
||||
$opref = catfile($WORKDIR, $oprfb);
|
||||
%cof = mkrndlog_existing $$fmt{"sub"},
|
||||
%cof = make_log_file $$fmt{"sub"},
|
||||
$WORKDIR, "$oprfb.%s" . $$rt{"suf"}, @mle;
|
||||
push @fle, map "$oprfb.$_" . $$rt{"suf"}, @mle;
|
||||
prsrvsrc $WORKDIR;
|
||||
preserve_source $WORKDIR;
|
||||
@_ = ($arclog, qw(-d -d -d -o a), @{$$rt{"opts"}}, @fs, $opref);
|
||||
$cmd = join(" ", @_);
|
||||
($retno, $out, $err) = runcmd "", @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($ret_no, $out, $err) = run_cmd "", @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
@ -119,11 +118,11 @@ foreach my $rt (@RESTYPES) {
|
||||
$fr = $fs[$k];
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = (${$cem[$k]}{$mt}, ${$st[$k]}{"type"});
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
$fr = $fs[$k] . ".vardump";
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
$fr = $fs[$k] . ".var-dump";
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump[$k], TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump[$k], TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
foreach my $m (@mle) {
|
||||
$fr = "$opref.$m" . $$rt{"suf"};
|
||||
@ -131,102 +130,102 @@ foreach my $rt (@RESTYPES) {
|
||||
$cef{$frb} = $cof{$frb}
|
||||
. join "", map(exists $$_{$m}? $$_{$m}: "", @cem);
|
||||
$tef{$frb} = $$rt{"type"};
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
die "$title\n$cmd\n$out$err" unless $retno == 0;
|
||||
die "$title\n$cmd\n$out$err" unless $ret_no == 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr};
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr};
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
skip($skip, $_, 1, $@);
|
||||
cleanup $_ || $skip, $WORKDIR, ++$tno;
|
||||
|
||||
clean_up $_ || $skip, $WORKDIR, ++$tno;
|
||||
|
||||
# 2-4: One of the source log files is read from STDIN
|
||||
# The file type at STDIN
|
||||
foreach my $ststdin (@SRCTYPES) {
|
||||
foreach my $st_stdin (@SOURCE_TYPES) {
|
||||
$skip = 0;
|
||||
$_ = eval {
|
||||
if ( ($$rt{"type"} eq TYPE_GZIP && nogzip)
|
||||
|| ($$rt{"type"} eq TYPE_BZIP2 && nobzip2)
|
||||
|| ($$ststdin{"type"} eq TYPE_GZIP && nogzip)
|
||||
|| ($$ststdin{"type"} eq TYPE_BZIP2 && nobzip2)) {
|
||||
if ( ($$rt{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
|| ($$rt{"type"} eq TYPE_BZIP2 && has_no_bzip2)
|
||||
|| ($$st_stdin{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
|| ($$st_stdin{"type"} eq TYPE_BZIP2 && has_no_bzip2)) {
|
||||
$skip = 1;
|
||||
return;
|
||||
}
|
||||
my ($title, $cmd, $retno, $out, $err, @vardump, %logfiles);
|
||||
my ($title, $cmd, $ret_no, $out, $err, @var_dump, %logfiles);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($num, @fs, @cs, @cem, @mle, %cof, $opref, $oprfb, $stdin);
|
||||
my (@st, $fmt);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$fmt = $LOGFMTS[int rand @LOGFMTS];
|
||||
$fmt = $LOG_FORMATS[int rand @LOG_FORMATS];
|
||||
$title = join ", ", "several log files", "one read from STDIN",
|
||||
"STDIN " . $$ststdin{"title"}, $$rt{"title"};
|
||||
"STDIN " . $$st_stdin{"title"}, $$rt{"title"};
|
||||
# (2-4 times available compression) log files
|
||||
$_ = 2 + (nogzip? 0: 2) + (nobzip2? 0: 2);
|
||||
$_ = 2 + (has_no_gzip? 0: 2) + (has_no_bzip2? 0: 2);
|
||||
$num = $_ + int rand $_;
|
||||
%_ = qw();
|
||||
my %types = qw();
|
||||
# At least 2 files for each available compression
|
||||
foreach my $st (@SRCTYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && nogzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
foreach my $st (@SOURCE_TYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
}
|
||||
# Set random compression on the rest files
|
||||
foreach (grep !exists $_{$_}, (0...$num-1)) {
|
||||
foreach (grep !exists $types{$_}, (0...$num-1)) {
|
||||
do {
|
||||
$_{$_} = $SRCTYPES[int rand @SRCTYPES];
|
||||
} until !(${$_{$_}}{"type"} eq TYPE_GZIP && nogzip)
|
||||
&& !(${$_{$_}}{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
$types{$_} = $SOURCE_TYPES[int rand @SOURCE_TYPES];
|
||||
} until !(${$types{$_}}{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
&& !(${$types{$_}}{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
}
|
||||
# Choose the STDIN from the matching compression
|
||||
@_ = grep ${$_{$_}}{"type"} eq $$ststdin{"type"}, (0...$num-1);
|
||||
@_ = grep ${$types{$_}}{"type"} eq $$st_stdin{"type"}, (0...$num-1);
|
||||
$stdin = $_[int rand @_];
|
||||
@st = map $_{$_}, (0...$num-1);
|
||||
@st = map $types{$_}, (0...$num-1);
|
||||
@fs = qw();
|
||||
@cs = qw();
|
||||
@cem = qw();
|
||||
@vardump = qw();
|
||||
@var_dump = qw();
|
||||
@fle = qw();
|
||||
%logfiles = qw();
|
||||
for (my $k = 0; $k < $num; $k++) {
|
||||
my ($logfile, $cs, $vardump);
|
||||
do { $logfile = randword } until !exists $logfiles{$logfile};
|
||||
my ($logfile, $cs, $var_dump);
|
||||
do { $logfile = random_word } until !exists $logfiles{$logfile};
|
||||
$logfiles{$logfile} = 1;
|
||||
$logfile .= ${$st[$k]}{"suf"};
|
||||
push @fs, catfile($WORKDIR, $logfile);
|
||||
($cs, $vardump, %_) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
($cs, $var_dump, %types) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
push @cs, $cs;
|
||||
push @cem, {%_};
|
||||
push @cem, {%types};
|
||||
push @fle, $logfile;
|
||||
push @vardump, $vardump;
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
push @fle, "$logfile.vardump";
|
||||
push @var_dump, $var_dump;
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
push @fle, "$logfile.var-dump";
|
||||
}
|
||||
%_ = qw();
|
||||
%_ = (%_, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %_;
|
||||
do { $oprfb = randword } until !exists $logfiles{$oprfb};
|
||||
%types = qw();
|
||||
%types = (%types, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %types;
|
||||
do { $oprfb = random_word } until !exists $logfiles{$oprfb};
|
||||
$opref = catfile($WORKDIR, $oprfb);
|
||||
%cof = mkrndlog_existing $$fmt{"sub"},
|
||||
%cof = make_log_file $$fmt{"sub"},
|
||||
$WORKDIR, "$oprfb.%s" . $$rt{"suf"}, @mle;
|
||||
push @fle, map "$oprfb.$_" . $$rt{"suf"}, @mle;
|
||||
prsrvsrc $WORKDIR;
|
||||
preserve_source $WORKDIR;
|
||||
@_ = @fs;
|
||||
$_[$stdin] = "-";
|
||||
@_ = ($arclog, qw(-d -d -d -k a -o a), @{$$rt{"opts"}}, @_, $opref);
|
||||
$cmd = join(" ", @_) . " < " . $fs[$stdin];
|
||||
($retno, $out, $err) = runcmd frread $fs[$stdin], @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($ret_no, $out, $err) = run_cmd read_raw_file $fs[$stdin], @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
@ -235,11 +234,11 @@ foreach my $rt (@RESTYPES) {
|
||||
$fr = $fs[$k];
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs[$k], ${$st[$k]}{"type"});
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
$fr = $fs[$k] . ".vardump";
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
$fr = $fs[$k] . ".var-dump";
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump[$k], TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump[$k], TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
foreach my $m (@mle) {
|
||||
$fr = "$opref.$m" . $$rt{"suf"};
|
||||
@ -247,20 +246,20 @@ foreach my $rt (@RESTYPES) {
|
||||
$cef{$frb} = $cof{$frb}
|
||||
. join "", map(exists $$_{$m}? $$_{$m}: "", @cem);
|
||||
$tef{$frb} = $$rt{"type"};
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
die "$title\n$cmd\n$out$err" unless $retno == 0;
|
||||
die "$title\n$cmd\n$out$err" unless $ret_no == 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr};
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr};
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
skip($skip, $_, 1, $@);
|
||||
cleanup $_ || $skip, $WORKDIR, ++$tno;
|
||||
clean_up $_ || $skip, $WORKDIR, ++$tno;
|
||||
}
|
||||
}
|
||||
|
203
t/03-fallback.t
203
t/03-fallback.t
@ -1,20 +1,19 @@
|
||||
#! /usr/bin/perl -w
|
||||
# Test fallback behavior
|
||||
|
||||
# Copyright (c) 2007 imacat
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# Copyright (c) 2007-2021 imacat.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
use 5.005;
|
||||
use strict;
|
||||
@ -30,87 +29,87 @@ use File::Spec::Functions qw(catdir catfile updir);
|
||||
use FindBin;
|
||||
use lib $FindBin::Bin;
|
||||
use _helper;
|
||||
use vars qw($WORKDIR $arclog $tno);
|
||||
our ($WORKDIR, $arclog, $tno);
|
||||
|
||||
$WORKDIR = catdir($FindBin::Bin, "logs");
|
||||
$arclog = catfile($FindBin::Bin, updir, "blib", "script", "arclog");
|
||||
$tno = 0;
|
||||
|
||||
# 1-4: STDIN keep fall back
|
||||
foreach my $kt (@KEEPTYPES) {
|
||||
foreach my $kt (@KEEP_MODES) {
|
||||
next if $$kt{"stdin"} || $$kt{"title"} eq "keep all";
|
||||
$_ = eval {
|
||||
my ($title, $cmd, $retno, $out, $err, @vardump, %logfiles);
|
||||
my ($title, $cmd, $ret_no, $out, $err, @var_dump, %logfiles);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($num, @fs, @cs, @cem, @mle, %cof, $opref, $oprfb, $stdin);
|
||||
my (@st, $fmt, $rt);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$fmt = $LOGFMTS[int rand @LOGFMTS];
|
||||
$fmt = $LOG_FORMATS[int rand @LOG_FORMATS];
|
||||
# A random available compression
|
||||
do {
|
||||
$rt = $RESTYPES[int rand @RESTYPES];
|
||||
} until !($$rt{"type"} eq TYPE_GZIP && nogzip)
|
||||
&& !($$rt{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
$rt = $RESULT_TYPES[int rand @RESULT_TYPES];
|
||||
} until !($$rt{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
&& !($$rt{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
$title = join ", ", "STDIN keep fall back", $$kt{"title"},
|
||||
$$fmt{"title"}, $$rt{"title"};
|
||||
# (2-4 times available compression) log files
|
||||
$_ = 2 + (nogzip? 0: 2) + (nobzip2? 0: 2);
|
||||
$_ = 2 + (has_no_gzip? 0: 2) + (has_no_bzip2? 0: 2);
|
||||
$num = $_ + int rand $_;
|
||||
$stdin = int rand $num;
|
||||
%_ = qw();
|
||||
my %types = qw();
|
||||
# At least 2 files for each available compression
|
||||
foreach my $st (@SRCTYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && nogzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
foreach my $st (@SOURCE_TYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
}
|
||||
# Set random compression on the rest files
|
||||
foreach (grep !exists $_{$_}, (0...$num-1)) {
|
||||
foreach (grep !exists $types{$_}, (0...$num-1)) {
|
||||
do {
|
||||
$_{$_} = $SRCTYPES[int rand @SRCTYPES];
|
||||
} until !(${$_{$_}}{"type"} eq TYPE_GZIP && nogzip)
|
||||
&& !(${$_{$_}}{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
$types{$_} = $SOURCE_TYPES[int rand @SOURCE_TYPES];
|
||||
} until !(${$types{$_}}{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
&& !(${$types{$_}}{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
}
|
||||
@st = map $_{$_}, (0...$num-1);
|
||||
@st = map $types{$_}, (0...$num-1);
|
||||
@fs = qw();
|
||||
@cs = qw();
|
||||
@cem = qw();
|
||||
@vardump = qw();
|
||||
@var_dump = qw();
|
||||
@fle = qw();
|
||||
%logfiles = qw();
|
||||
for (my $k = 0; $k < $num; $k++) {
|
||||
my ($logfile, $cs, $vardump);
|
||||
do { $logfile = randword } until !exists $logfiles{$logfile};
|
||||
my ($logfile, $cs, $var_dump);
|
||||
do { $logfile = random_word } until !exists $logfiles{$logfile};
|
||||
$logfiles{$logfile} = 1;
|
||||
$logfile .= ${$st[$k]}{"suf"};
|
||||
push @fs, catfile($WORKDIR, $logfile);
|
||||
($cs, $vardump, %_) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
($cs, $var_dump, %types) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
push @cs, $cs;
|
||||
push @cem, {%_};
|
||||
push @cem, {%types};
|
||||
push @fle, $logfile;
|
||||
push @vardump, $vardump;
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
push @fle, "$logfile.vardump";
|
||||
push @var_dump, $var_dump;
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
push @fle, "$logfile.var-dump";
|
||||
}
|
||||
%_ = qw();
|
||||
%_ = (%_, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %_;
|
||||
do { $oprfb = randword } until !exists $logfiles{$oprfb};
|
||||
%types = qw();
|
||||
%types = (%types, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %types;
|
||||
do { $oprfb = random_word } until !exists $logfiles{$oprfb};
|
||||
$opref = catfile($WORKDIR, $oprfb);
|
||||
%cof = mkrndlog_existing $$fmt{"sub"},
|
||||
%cof = make_log_file $$fmt{"sub"},
|
||||
$WORKDIR, "$oprfb.%s" . $$rt{"suf"}, @mle;
|
||||
push @fle, map "$oprfb.$_" . $$rt{"suf"}, @mle;
|
||||
prsrvsrc $WORKDIR;
|
||||
preserve_source $WORKDIR;
|
||||
@_ = @fs;
|
||||
$_[$stdin] = "-";
|
||||
@_ = ($arclog, qw(-d -d -d -o a), @{$$kt{"opts"}}, @{$$rt{"opts"}}, @_, $opref);
|
||||
$cmd = join(" ", @_) . " < " . $fs[$stdin];
|
||||
($retno, $out, $err) = runcmd frread $fs[$stdin], @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($ret_no, $out, $err) = run_cmd read_raw_file $fs[$stdin], @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
@ -119,11 +118,11 @@ foreach my $kt (@KEEPTYPES) {
|
||||
$fr = $fs[$k];
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs[$k], ${$st[$k]}{"type"});
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
$fr = $fs[$k] . ".vardump";
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
$fr = $fs[$k] . ".var-dump";
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump[$k], TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump[$k], TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
foreach my $m (@mle) {
|
||||
$fr = "$opref.$m" . $$rt{"suf"};
|
||||
@ -131,96 +130,96 @@ foreach my $kt (@KEEPTYPES) {
|
||||
$cef{$frb} = $cof{$frb}
|
||||
. join "", map(exists $$_{$m}? $$_{$m}: "", @cem);
|
||||
$tef{$frb} = $$rt{"type"};
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
die "$title\n$cmd\n$out$err" unless $retno == 0;
|
||||
die "$title\n$cmd\n$out$err" unless $ret_no == 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr};
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr};
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
ok($_, 1, $@);
|
||||
cleanup $_, $WORKDIR, ++$tno;
|
||||
clean_up $_, $WORKDIR, ++$tno;
|
||||
}
|
||||
|
||||
# 5: STDIN override ask fall back
|
||||
$_ = eval {
|
||||
my ($title, $cmd, $retno, $out, $err, @vardump, %logfiles);
|
||||
my ($title, $cmd, $ret_no, $out, $err, @var_dump, %logfiles);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($num, @fs, @cs, @cem, @mle, %cof, $opref, $oprfb, $stdin);
|
||||
my (@st, $fmt, $rt);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$fmt = $LOGFMTS[int rand @LOGFMTS];
|
||||
$fmt = $LOG_FORMATS[int rand @LOG_FORMATS];
|
||||
# A random available compression
|
||||
do {
|
||||
$rt = $RESTYPES[int rand @RESTYPES];
|
||||
} until !($$rt{"type"} eq TYPE_GZIP && nogzip)
|
||||
&& !($$rt{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
$rt = $RESULT_TYPES[int rand @RESULT_TYPES];
|
||||
} until !($$rt{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
&& !($$rt{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
$title = join ", ", "STDIN override ask fall back",
|
||||
$$fmt{"title"}, $$rt{"title"};
|
||||
# (2-4 times available compression) log files
|
||||
$_ = 2 + (nogzip? 0: 2) + (nobzip2? 0: 2);
|
||||
$_ = 2 + (has_no_gzip? 0: 2) + (has_no_bzip2? 0: 2);
|
||||
$num = $_ + int rand $_;
|
||||
$stdin = int rand $num;
|
||||
%_ = qw();
|
||||
my %types = qw();
|
||||
# At least 2 files for each available compression
|
||||
foreach my $st (@SRCTYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && nogzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
foreach my $st (@SOURCE_TYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
}
|
||||
# Set random compression on the rest files
|
||||
foreach (grep !exists $_{$_}, (0...$num-1)) {
|
||||
foreach (grep !exists $types{$_}, (0...$num-1)) {
|
||||
do {
|
||||
$_{$_} = $SRCTYPES[int rand @SRCTYPES];
|
||||
} until !(${$_{$_}}{"type"} eq TYPE_GZIP && nogzip)
|
||||
&& !(${$_{$_}}{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
$types{$_} = $SOURCE_TYPES[int rand @SOURCE_TYPES];
|
||||
} until !(${$types{$_}}{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
&& !(${$types{$_}}{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
}
|
||||
@st = map $_{$_}, (0...$num-1);
|
||||
@st = map $types{$_}, (0...$num-1);
|
||||
@fs = qw();
|
||||
@cs = qw();
|
||||
@cem = qw();
|
||||
@vardump = qw();
|
||||
@var_dump = qw();
|
||||
@fle = qw();
|
||||
%logfiles = qw();
|
||||
for (my $k = 0; $k < $num; $k++) {
|
||||
my ($logfile, $cs, $vardump);
|
||||
do { $logfile = randword } until !exists $logfiles{$logfile};
|
||||
my ($logfile, $cs, $var_dump);
|
||||
do { $logfile = random_word } until !exists $logfiles{$logfile};
|
||||
$logfiles{$logfile} = 1;
|
||||
$logfile .= ${$st[$k]}{"suf"};
|
||||
push @fs, catfile($WORKDIR, $logfile);
|
||||
($cs, $vardump, %_) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
($cs, $var_dump, %types) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
push @cs, $cs;
|
||||
push @cem, {%_};
|
||||
push @cem, {%types};
|
||||
push @fle, $logfile;
|
||||
push @vardump, $vardump;
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
push @fle, "$logfile.vardump";
|
||||
push @var_dump, $var_dump;
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
push @fle, "$logfile.var-dump";
|
||||
}
|
||||
%_ = qw();
|
||||
%_ = (%_, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %_;
|
||||
do { $oprfb = randword } until !exists $logfiles{$oprfb};
|
||||
%types = qw();
|
||||
%types = (%types, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %types;
|
||||
do { $oprfb = random_word } until !exists $logfiles{$oprfb};
|
||||
$opref = catfile($WORKDIR, $oprfb);
|
||||
%cof = mkrndlog_existing $$fmt{"sub"},
|
||||
%cof = make_log_file $$fmt{"sub"},
|
||||
$WORKDIR, "$oprfb.%s" . $$rt{"suf"}, @mle;
|
||||
push @fle, grep $cof{$_} ne "", keys %cof;
|
||||
prsrvsrc $WORKDIR;
|
||||
preserve_source $WORKDIR;
|
||||
@_ = @fs;
|
||||
$_[$stdin] = "-";
|
||||
@_ = ($arclog, qw(-d -d -d -o ask), @{$$rt{"opts"}}, @_, $opref);
|
||||
$cmd = join(" ", @_) . " < " . $fs[$stdin];
|
||||
($retno, $out, $err) = runcmd frread $fs[$stdin], @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($ret_no, $out, $err) = run_cmd read_raw_file $fs[$stdin], @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
@ -229,28 +228,28 @@ $_ = eval {
|
||||
$fr = $fs[$k];
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs[$k], ${$st[$k]}{"type"});
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
$fr = $fs[$k] . ".vardump";
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
$fr = $fs[$k] . ".var-dump";
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump[$k], TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump[$k], TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
foreach my $m (@mle) {
|
||||
$fr = "$opref.$m" . $$rt{"suf"};
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cof{$frb}, $$rt{"type"});
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
die "$title\n$cmd\n$out$err" unless $retno != 0;
|
||||
die "$title\n$cmd\n$out$err" unless $ret_no != 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr};
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr};
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
ok($_, 1, $@);
|
||||
cleanup $_, $WORKDIR, ++$tno;
|
||||
clean_up $_, $WORKDIR, ++$tno;
|
||||
|
226
t/04-errors.t
226
t/04-errors.t
@ -1,20 +1,19 @@
|
||||
#! /usr/bin/perl -w
|
||||
# Test the errors that should be captured.
|
||||
|
||||
# Copyright (c) 2007 imacat
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# Copyright (c) 2007-2021 imacat.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
use 5.005;
|
||||
use strict;
|
||||
@ -30,7 +29,7 @@ use File::Spec::Functions qw(catdir catfile updir);
|
||||
use FindBin;
|
||||
use lib $FindBin::Bin;
|
||||
use _helper;
|
||||
use vars qw($WORKDIR $arclog $tno);
|
||||
our ($WORKDIR, $arclog, $tno);
|
||||
|
||||
$WORKDIR = catdir($FindBin::Bin, "logs");
|
||||
$arclog = catfile($FindBin::Bin, updir, "blib", "script", "arclog");
|
||||
@ -38,166 +37,166 @@ $tno = 0;
|
||||
|
||||
# 1: STDIN alone
|
||||
$_ = eval {
|
||||
my ($title, $cmd, $retno, $out, $err, $vardump, $logfile);
|
||||
my ($title, $cmd, $ret_no, $out, $err, $var_dump, $logfile);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($fs, $cs, %cem);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$title = "STDIN alone";
|
||||
$logfile = randword;
|
||||
$logfile = random_word;
|
||||
$fs = catfile($WORKDIR, $logfile);
|
||||
($cs, $vardump, %cem) = mkrndlog_apache $fs;
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
($cs, $var_dump, %cem) = make_apache_log_file $fs;
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
@fle = qw();
|
||||
push @fle, basename($fs);
|
||||
push @fle, "$logfile.vardump";
|
||||
prsrvsrc $WORKDIR;
|
||||
push @fle, "$logfile.var-dump";
|
||||
preserve_source $WORKDIR;
|
||||
@_ = ($arclog, qw(-d -d -d -c n), "-");
|
||||
$cmd = join(" ", @_) . " < " . $fs;
|
||||
($retno, $out, $err) = runcmd frread $fs, @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($ret_no, $out, $err) = run_cmd read_raw_file $fs, @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
%trf = qw(); # Resulted file type by file
|
||||
$fr = $fs;
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs, TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
$frb = "$logfile.vardump";
|
||||
($cef{$frb}, $tef{$frb}) = ($cs, TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
$frb = "$logfile.var-dump";
|
||||
$fr = catfile($WORKDIR, $frb);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump, TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
die "$title\n$cmd\n$out$err" unless $retno != 0;
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump, TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
die "$title\n$cmd\n$out$err" unless $ret_no != 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr};
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr};
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
ok($_, 1, $@);
|
||||
cleanup $_, $WORKDIR, ++$tno;
|
||||
clean_up $_, $WORKDIR, ++$tno;
|
||||
|
||||
# 2: STDOUT as output prefix
|
||||
$_ = eval {
|
||||
my ($title, $cmd, $retno, $out, $err, $vardump, $logfile);
|
||||
my ($title, $cmd, $ret_no, $out, $err, $var_dump, $logfile);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($fs, $cs, %cem);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$title = "STDOUT as output prefix";
|
||||
$logfile = randword;
|
||||
$logfile = random_word;
|
||||
$fs = catfile($WORKDIR, $logfile);
|
||||
($cs, $vardump, %cem) = mkrndlog_apache $fs;
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
($cs, $var_dump, %cem) = make_apache_log_file $fs;
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
@fle = qw();
|
||||
push @fle, basename($fs);
|
||||
push @fle, "$logfile.vardump";
|
||||
prsrvsrc $WORKDIR;
|
||||
push @fle, "$logfile.var-dump";
|
||||
preserve_source $WORKDIR;
|
||||
@_ = ($arclog, qw(-d -d -d -c n), $logfile, "-");
|
||||
$cmd = join " ", @_;
|
||||
($retno, $out, $err) = runcmd "", @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($ret_no, $out, $err) = run_cmd "", @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
%trf = qw(); # Resulted file type by file
|
||||
$fr = $fs;
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs, TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
$frb = "$logfile.vardump";
|
||||
($cef{$frb}, $tef{$frb}) = ($cs, TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
$frb = "$logfile.var-dump";
|
||||
$fr = catfile($WORKDIR, $frb);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump, TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
die "$title\n$cmd\n$out$err" unless $retno != 0;
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump, TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
die "$title\n$cmd\n$out$err" unless $ret_no != 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr};
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr};
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
ok($_, 1, $@);
|
||||
cleanup $_, $WORKDIR, ++$tno;
|
||||
clean_up $_, $WORKDIR, ++$tno;
|
||||
|
||||
# 3: A same log file is specified more than once
|
||||
$_ = eval {
|
||||
my ($title, $cmd, $retno, $out, $err, @vardump, %logfiles);
|
||||
my ($title, $cmd, $ret_no, $out, $err, @var_dump, %logfiles);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($num, @fs, @cs, @cem, @mle, %cof, $opref, $oprfb, $mt);
|
||||
my (@st, $fmt, $rt, $dup);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$fmt = $LOGFMTS[int rand @LOGFMTS];
|
||||
$rt = $RESTYPES[int rand @RESTYPES];
|
||||
$fmt = $LOG_FORMATS[int rand @LOG_FORMATS];
|
||||
$rt = $RESULT_TYPES[int rand @RESULT_TYPES];
|
||||
$title = join ",", "A same log file is specified more than once",
|
||||
$$fmt{"title"}, $$rt{"title"};
|
||||
# (2-4 times available compression) log files
|
||||
$_ = 2 + (nogzip? 0: 2) + (nobzip2? 0: 2);
|
||||
$_ = 2 + (has_no_gzip? 0: 2) + (has_no_bzip2? 0: 2);
|
||||
$num = $_ + int rand $_;
|
||||
%_ = qw();
|
||||
my %types = qw();
|
||||
# At least 2 files for each available compression
|
||||
foreach my $st (@SRCTYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && nogzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $_{$_}, (0...$num-1);
|
||||
$_{$_[int rand @_]} = $st;
|
||||
foreach my $st (@SOURCE_TYPES) {
|
||||
next if ($$st{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
|| ($$st{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
@_ = grep !exists $types{$_}, (0...$num-1);
|
||||
$types{$_[int rand @_]} = $st;
|
||||
}
|
||||
# Set random compression on the rest files
|
||||
foreach (grep !exists $_{$_}, (0...$num-1)) {
|
||||
foreach (grep !exists $types{$_}, (0...$num-1)) {
|
||||
do {
|
||||
$_{$_} = $SRCTYPES[int rand @SRCTYPES];
|
||||
} until !(${$_{$_}}{"type"} eq TYPE_GZIP && nogzip)
|
||||
&& !(${$_{$_}}{"type"} eq TYPE_BZIP2 && nobzip2);
|
||||
$types{$_} = $SOURCE_TYPES[int rand @SOURCE_TYPES];
|
||||
} until !(${$types{$_}}{"type"} eq TYPE_GZIP && has_no_gzip)
|
||||
&& !(${$types{$_}}{"type"} eq TYPE_BZIP2 && has_no_bzip2);
|
||||
}
|
||||
@st = map $_{$_}, (0...$num-1);
|
||||
@st = map $types{$_}, (0...$num-1);
|
||||
@fs = qw();
|
||||
@cs = qw();
|
||||
@cem = qw();
|
||||
@vardump = qw();
|
||||
@var_dump = qw();
|
||||
@fle = qw();
|
||||
%logfiles = qw();
|
||||
for (my $k = 0; $k < $num; $k++) {
|
||||
my ($logfile, $cs, $vardump);
|
||||
do { $logfile = randword } until !exists $logfiles{$logfile};
|
||||
my ($logfile, $cs, $var_dump);
|
||||
do { $logfile = random_word } until !exists $logfiles{$logfile};
|
||||
$logfiles{$logfile} = 1;
|
||||
$logfile .= ${$st[$k]}{"suf"};
|
||||
push @fs, catfile($WORKDIR, $logfile);
|
||||
($cs, $vardump, %_) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
($cs, $var_dump, %types) = &{$$fmt{"sub"}}($fs[$k]);
|
||||
push @cs, $cs;
|
||||
push @cem, {%_};
|
||||
push @cem, {%types};
|
||||
push @fle, $logfile;
|
||||
push @vardump, $vardump;
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
push @fle, "$logfile.vardump";
|
||||
push @var_dump, $var_dump;
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
push @fle, "$logfile.var-dump";
|
||||
}
|
||||
%_ = qw();
|
||||
%_ = (%_, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %_;
|
||||
%types = qw();
|
||||
%types = (%types, map { $_ => 1 } keys %$_) foreach @cem;
|
||||
@mle = sort keys %types;
|
||||
$mt = pop @mle;
|
||||
do { $oprfb = randword } until !exists $logfiles{$oprfb};
|
||||
do { $oprfb = random_word } until !exists $logfiles{$oprfb};
|
||||
$opref = catfile($WORKDIR, $oprfb);
|
||||
%cof = mkrndlog_existing $$fmt{"sub"},
|
||||
%cof = make_log_file $$fmt{"sub"},
|
||||
$WORKDIR, "$oprfb.%s" . $$rt{"suf"}, @mle;
|
||||
push @fle, map basename($_), grep $cof{$_} ne "", keys %cof;
|
||||
prsrvsrc $WORKDIR;
|
||||
preserve_source $WORKDIR;
|
||||
$dup = $fs[int rand @fs];
|
||||
$_ = int rand(@fs + 1);
|
||||
@_ = (@fs[0...$_-1], $dup, @fs[$_...$#fs]);
|
||||
@_ = ($arclog, qw(-d -d -d -o a), @{$$rt{"opts"}}, @_, $opref);
|
||||
$cmd = join(" ", @_);
|
||||
($retno, $out, $err) = runcmd "", @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($ret_no, $out, $err) = run_cmd "", @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
@ -206,76 +205,77 @@ $_ = eval {
|
||||
$fr = $fs[$k];
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs[$k], ${$st[$k]}{"type"});
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
$fr = $fs[$k] . ".vardump";
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
$fr = $fs[$k] . ".var-dump";
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump[$k], TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump[$k], TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
foreach my $m (@mle) {
|
||||
$fr = "$opref.$m" . $$rt{"suf"};
|
||||
$frb = basename($fr);
|
||||
next if $cof{$frb} eq "";
|
||||
($cef{$frb}, $tef{$frb}) = ($cof{$frb}, $$rt{"type"});
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
die "$title\n$cmd\n$out$err" unless $retno != 0;
|
||||
die "$title\n$cmd\n$out$err" unless $ret_no != 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr};
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr};
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
ok($_, 1, $@);
|
||||
cleanup $_, $WORKDIR, ++$tno;
|
||||
clean_up $_, $WORKDIR, ++$tno;
|
||||
|
||||
# 4-23: Mixing different formats
|
||||
for (my $i = 0; $i < @LOGFMTS; $i++) {
|
||||
for (my $j = 0; $j < @LOGFMTS; $j++) {
|
||||
for (my $i = 0; $i < @LOG_FORMATS; $i++) {
|
||||
for (my $j = 0; $j < @LOG_FORMATS; $j++) {
|
||||
next if $i == $j;
|
||||
$_ = eval {
|
||||
my ($title, $cmd, $retno, $out, $err, @vardump, %logfiles);
|
||||
my ($title, $cmd, $ret_no, $out, $err, @var_dump, %logfiles);
|
||||
my ($fr, $frb, @fle, $fle, $flr, %cef, %crf, %tef, %trf);
|
||||
my ($num, $swan, @fs, @cs, $opref, $oprfb);
|
||||
rmtree $WORKDIR;
|
||||
mkpath $WORKDIR;
|
||||
$title = join ",", "Mixing formats", ${$LOGFMTS[$i]}{"title"},
|
||||
${$LOGFMTS[$j]}{"title"};
|
||||
$title = join ",", "Mixing formats", ${$LOG_FORMATS[$i]}{"title"},
|
||||
${$LOG_FORMATS[$j]}{"title"};
|
||||
# 3-5 log files
|
||||
$num = 3 + int rand 3;
|
||||
$swan = 1 + int rand($num - 1);
|
||||
@fs = qw();
|
||||
@cs = qw();
|
||||
@vardump = qw();
|
||||
@var_dump = qw();
|
||||
@fle = qw();
|
||||
%logfiles = qw();
|
||||
for (my $k = 0; $k < $num; $k++) {
|
||||
my ($logfile, $cs, $vardump);
|
||||
do { $logfile = randword } until !exists $logfiles{$logfile};
|
||||
my ($logfile, $cs, $var_dump);
|
||||
do { $logfile = random_word } until !exists $logfiles{$logfile};
|
||||
$logfiles{$logfile} = 1;
|
||||
push @fs, catfile($WORKDIR, $logfile);
|
||||
my %by_months;
|
||||
if ($k != $swan) {
|
||||
($cs, $vardump, %_) = &{${$LOGFMTS[$i]}{"sub"}}($fs[$k]);
|
||||
($cs, $var_dump, %by_months) = &{${$LOG_FORMATS[$i]}{"sub"}}($fs[$k]);
|
||||
} else {
|
||||
($cs, $vardump, %_) = &{${$LOGFMTS[$j]}{"sub"}}($fs[$k]);
|
||||
($cs, $var_dump, %by_months) = &{${$LOG_FORMATS[$j]}{"sub"}}($fs[$k]);
|
||||
}
|
||||
push @cs, $cs;
|
||||
push @fle, $logfile;
|
||||
push @vardump, $vardump;
|
||||
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
|
||||
push @fle, "$logfile.vardump";
|
||||
push @var_dump, $var_dump;
|
||||
write_raw_file(catfile($WORKDIR, "$logfile.var-dump"), $var_dump);
|
||||
push @fle, "$logfile.var-dump";
|
||||
}
|
||||
prsrvsrc $WORKDIR;
|
||||
do { $oprfb = randword } until !exists $logfiles{$oprfb};
|
||||
preserve_source $WORKDIR;
|
||||
do { $oprfb = random_word } until !exists $logfiles{$oprfb};
|
||||
$opref = catfile($WORKDIR, $oprfb);
|
||||
@_ = ($arclog, qw(-d -d -d -c n), @fs, $opref);
|
||||
$cmd = join " ", @_;
|
||||
($retno, $out, $err) = runcmd "", @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), flist $WORKDIR);
|
||||
($ret_no, $out, $err) = run_cmd "", @_;
|
||||
($fle, $flr) = (join(" ", sort @fle), list_files $WORKDIR);
|
||||
%cef = qw(); # Expected content by file
|
||||
%tef = qw(); # Expected file type by file
|
||||
%crf = qw(); # Resulted content by file
|
||||
@ -283,26 +283,26 @@ for (my $i = 0; $i < @LOGFMTS; $i++) {
|
||||
for (my $k = 0; $k < $num; $k++) {
|
||||
$fr = $fs[$k];
|
||||
$frb = basename($fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($cs[$k], TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
$frb = "$frb.vardump";
|
||||
($cef{$frb}, $tef{$frb}) = ($cs[$k], TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
$frb = "$frb.var-dump";
|
||||
$fr = catfile($WORKDIR, $frb);
|
||||
($cef{$frb}, $tef{$frb}) = ($vardump[$k], TYPE_PLAIN);
|
||||
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
|
||||
($cef{$frb}, $tef{$frb}) = ($var_dump[$k], TYPE_TEXT);
|
||||
($crf{$frb}, $trf{$frb}) = (read_file $fr, file_type $fr);
|
||||
}
|
||||
die "$title\n$cmd\n$out$err" unless $retno != 0;
|
||||
die "$title\n$cmd\n$out$err" unless $ret_no != 0;
|
||||
die "$title\n$cmd\nresult files incorrect.\nGot: $flr\nExpected: $fle\nOutput:\n$out$err"
|
||||
unless $flr eq $fle;
|
||||
foreach $fr (@fle) {
|
||||
die "$title\n$cmd\n$fr: result type incorrect.\nGot: $trf{$fr}\nExpected: $tef{$fr}\nOutput:\n$out$err"
|
||||
unless nofile || $trf{$fr} eq $tef{$fr};
|
||||
unless has_no_file || $trf{$fr} eq $tef{$fr};
|
||||
die "$title\n$cmd\n$fr: result incorrect.\nGot:\n$crf{$fr}\nExpected:\n$cef{$fr}\nOutput:\n$out$err"
|
||||
unless $crf{$fr} eq $cef{$fr};
|
||||
}
|
||||
1;
|
||||
};
|
||||
ok($_, 1, $@);
|
||||
cleanup $_, $WORKDIR, ++$tno;
|
||||
clean_up $_, $WORKDIR, ++$tno;
|
||||
die unless $_;
|
||||
}
|
||||
}
|
||||
|
1035
t/_helper.pm
1035
t/_helper.pm
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user