arclog/t/03-fallback.t
2021-02-01 15:05:57 +08:00

257 lines
9.9 KiB
Perl
Executable File

#! /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/>.
use 5.005;
use strict;
use warnings;
use diagnostics;
use Test;
BEGIN { plan tests => 5 }
use File::Basename qw(basename);
use File::Path qw(mkpath rmtree);
use File::Spec::Functions qw(catdir catfile updir);
use FindBin;
use lib $FindBin::Bin;
use _helper;
use vars qw($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) {
next if $$kt{"stdin"} || $$kt{"title"} eq "keep all";
$_ = eval {
my ($title, $cmd, $retno, $out, $err, @vardump, %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];
# A random available compression
do {
$rt = $RESTYPES[int rand @RESTYPES];
} until !($$rt{"type"} eq TYPE_GZIP && nogzip)
&& !($$rt{"type"} eq TYPE_BZIP2 && nobzip2);
$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);
$num = $_ + int rand $_;
$stdin = int rand $num;
%_ = 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;
}
# Set random compression on the rest files
foreach (grep !exists $_{$_}, (0...$num-1)) {
do {
$_{$_} = $SRCTYPES[int rand @SRCTYPES];
} until !(${$_{$_}}{"type"} eq TYPE_GZIP && nogzip)
&& !(${$_{$_}}{"type"} eq TYPE_BZIP2 && nobzip2);
}
@st = map $_{$_}, (0...$num-1);
@fs = qw();
@cs = qw();
@cem = qw();
@vardump = qw();
@fle = qw();
%logfiles = qw();
for (my $k = 0; $k < $num; $k++) {
my ($logfile, $cs, $vardump);
do { $logfile = randword } until !exists $logfiles{$logfile};
$logfiles{$logfile} = 1;
$logfile .= ${$st[$k]}{"suf"};
push @fs, catfile($WORKDIR, $logfile);
($cs, $vardump, %_) = &{$$fmt{"sub"}}($fs[$k]);
push @cs, $cs;
push @cem, {%_};
push @fle, $logfile;
push @vardump, $vardump;
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
push @fle, "$logfile.vardump";
}
%_ = qw();
%_ = (%_, map { $_ => 1 } keys %$_) foreach @cem;
@mle = sort keys %_;
do { $oprfb = randword } until !exists $logfiles{$oprfb};
$opref = catfile($WORKDIR, $oprfb);
%cof = mkrndlog_existing $$fmt{"sub"},
$WORKDIR, "$oprfb.%s" . $$rt{"suf"}, @mle;
push @fle, map "$oprfb.$_" . $$rt{"suf"}, @mle;
prsrvsrc $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);
%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
for (my $k = 0; $k < $num; $k++) {
$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";
$frb = basename($fr);
($cef{$frb}, $tef{$frb}) = ($vardump[$k], TYPE_PLAIN);
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
}
foreach my $m (@mle) {
$fr = "$opref.$m" . $$rt{"suf"};
$frb = basename($fr);
$cef{$frb} = $cof{$frb}
. join "", map(exists $$_{$m}? $$_{$m}: "", @cem);
$tef{$frb} = $$rt{"type"};
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $fr);
}
die "$title\n$cmd\n$out$err" unless $retno == 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};
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;
}
# 5: STDIN override ask fall back
$_ = eval {
my ($title, $cmd, $retno, $out, $err, @vardump, %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];
# A random available compression
do {
$rt = $RESTYPES[int rand @RESTYPES];
} until !($$rt{"type"} eq TYPE_GZIP && nogzip)
&& !($$rt{"type"} eq TYPE_BZIP2 && nobzip2);
$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);
$num = $_ + int rand $_;
$stdin = int rand $num;
%_ = 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;
}
# Set random compression on the rest files
foreach (grep !exists $_{$_}, (0...$num-1)) {
do {
$_{$_} = $SRCTYPES[int rand @SRCTYPES];
} until !(${$_{$_}}{"type"} eq TYPE_GZIP && nogzip)
&& !(${$_{$_}}{"type"} eq TYPE_BZIP2 && nobzip2);
}
@st = map $_{$_}, (0...$num-1);
@fs = qw();
@cs = qw();
@cem = qw();
@vardump = qw();
@fle = qw();
%logfiles = qw();
for (my $k = 0; $k < $num; $k++) {
my ($logfile, $cs, $vardump);
do { $logfile = randword } until !exists $logfiles{$logfile};
$logfiles{$logfile} = 1;
$logfile .= ${$st[$k]}{"suf"};
push @fs, catfile($WORKDIR, $logfile);
($cs, $vardump, %_) = &{$$fmt{"sub"}}($fs[$k]);
push @cs, $cs;
push @cem, {%_};
push @fle, $logfile;
push @vardump, $vardump;
frwrite(catfile($WORKDIR, "$logfile.vardump"), $vardump);
push @fle, "$logfile.vardump";
}
%_ = qw();
%_ = (%_, map { $_ => 1 } keys %$_) foreach @cem;
@mle = sort keys %_;
do { $oprfb = randword } until !exists $logfiles{$oprfb};
$opref = catfile($WORKDIR, $oprfb);
%cof = mkrndlog_existing $$fmt{"sub"},
$WORKDIR, "$oprfb.%s" . $$rt{"suf"}, @mle;
push @fle, grep $cof{$_} ne "", keys %cof;
prsrvsrc $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);
%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
for (my $k = 0; $k < $num; $k++) {
$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";
$frb = basename($fr);
($cef{$frb}, $tef{$frb}) = ($vardump[$k], TYPE_PLAIN);
($crf{$frb}, $trf{$frb}) = (fread $fr, ftype $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);
}
die "$title\n$cmd\n$out$err" unless $retno != 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};
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;