#!/bin/sh
# PCP QA Test No. 1569
# checkout pmlogcompress
#
# Copyright (c) 2024 Ken McDonell.  All Rights Reserved.
#

if [ $# -eq 0 ]
then
    seq=`basename $0`
    echo "QA output created by $seq"
else
    # use $seq from caller, unless not set
    [ -n "$seq" ] || seq=`basename $0`
    echo "QA output created by `basename $0` $*"
fi

# get standard environment, filters and checks
. ./common.product
. ./common.filter
. ./common.check

$sudo rm -rf $tmp $tmp.* $seq.full

which pmlogcompress >/dev/null 2>&1 || _notrun "pmlogcompress not installed"

_cleanup()
{
    cd $here
    $sudo rm -rf $tmp $tmp.*
}

status=0	# success is the default!
trap "_cleanup; exit \$status" 0 1 2 3 15

# much of this is pandering to older versions of xz where
# --block-size is not supported, and/or the compressed file
# sizes are a little different between xz versions
#
_filter()
{
    sed \
	-e "s@$tmp@TMP@g" \
	-e "s@$here@HERE@g" \
	-e '/+ xz -0 foo/s/0/0 --block-size=10MiB/' \
	-e '/pcp-meminfo.0.xz/s/1032/892/' \
	-e '/pcp-meminfo.0.xz/s/900/892/' \
	-e '/pcp-meminfo.meta.xz/s/3644/3640/' \
	-e '/pcp-meminfo.meta.xz/s/3648/3640/' \
    # end
}

_doit()
{
    echo "--- $* ---" | _filter
    pmlogcompress "$@" 2>$tmp.err >$tmp.out
    sts=$?
    _filter <$tmp.out
    if [ -s $tmp.err ]
    then
	echo "stderr ..."
	cat $tmp.err | _filter
    fi
    [ $sts != 0 ] && echo "exit status $sts"
}

_check()
{
    if pmlogdump -z "$1" >$tmp.tmp
    then
	diff "$tmp.$1.dump" $tmp.tmp >$tmp.out
	if [ -s $tmp.out ]
	then
	    echo "pmlogdump diffs!!"
	    cat $tmp.out
	fi
    else
	echo "pmlogdump failed!"
    fi
}

# real QA test starts here
echo "=== some error cases ==="
_doit -x $tmp archives/pcp-meminfo 2>&1 \
| sed -e 's/.*[Ii]llegal/Illegal/' -e 's/ -- c/ -c/'
_doit -d -t $tmp archives/pcp-meminfo
_doit -NV no-such-archive
mkdir $tmp
touch $tmp/pcp-meminfo.0
_doit -d -t $tmp archives/pcp-meminfo
touch $tmp/pcp-meminfo.index $tmp/pcp-meminfo.meta
_doit -d -V $tmp/pcp-meminfo
_doit -c foocompress -d foobar
_doit -A arg1 -A arg2 -A "arg3 and arg4" -d foobar
_doit -f gzip --decompress foobar
_doit --decompress -l 0 foobar
_doit -o size -d foobar
_doit -o foo foobar
cp $here/archives/foo+.* $tmp
_doit -l 0 -z -c no-such-prog $tmp/foo+
_doit -l 0 -z -f no-such-prog $tmp/foo+
_doit -l 0 -z -c no-such-prog:even-less-likely-prog $tmp/foo+
_doit -f xz -o size foobar
_doit -o cpu -f bzip foobar

echo
echo "=== some decompress success cases ==="
cd $tmp
rm -f *
cp $here/archives/pcp-meminfo* .
pmlogdump -z pcp-meminfo >$tmp.pcp-meminfo.dump
stat --format='%n %s' pcp-meminfo* | _filter
_doit -d -N pcp-meminfo
stat --format='%n %s' pcp-meminfo* | _filter

_doit -d pcp-meminfo
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo
rm -f $tmp/*

cd $here
[ -d tmp ] || mkdir tmp
_doit -d -V -t tmp archives/pcp-meminfo
stat --format='%n %s' tmp/pcp-meminfo* | _filter
cd tmp
_check pcp-meminfo
rm -f pcp-meminfo*
cd $here

cd $tmp
rm -f *
_doit -d -t . $here/archives/pcp-meminfo
echo "+++ lzma +++"
xz --format=lzma pcp-meminfo.0
_doit -d -V pcp-meminfo
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo
echo "+++ bz2 +++"
bzip2 pcp-meminfo.0
bzip2 pcp-meminfo.meta
# some bzip2 versions choke on files with link
# count > 1, so make a copy of the .index file
#
cp pcp-meminfo.index eek
rm -f pcp-meminfo.index
mv eek pcp-meminfo.index
bzip2 pcp-meminfo.index
_doit -d -V pcp-meminfo
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo
echo "+++ bz +++"
bzip2 pcp-meminfo.0
mv pcp-meminfo.0.bz2 pcp-meminfo.0.bz
_doit -d -V pcp-meminfo
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo
echo "+++ gz +++"
gzip pcp-meminfo.0
gzip pcp-meminfo.meta
_doit -d -V pcp-meminfo
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo
echo "+++ z +++"
gzip pcp-meminfo.0
mv pcp-meminfo.0.gz pcp-meminfo.0.z
_doit -d -V pcp-meminfo
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo

echo
echo "=== some compress (and decompress) success cases ==="
cp $here/archives/foo+.* .
stat --format='%n %s' foo+* | _filter
pmlogdump -z foo+ >$tmp.foo+.dump
_doit -NV -l10240 foo+
_doit --lower-limit=0 --compress --show-me --verbose foo+
_doit -l 0 -z -V -c gzip foo+
stat --format='%n %s' foo+* | _filter
_check foo+
_doit --decompress foo+
stat --format='%n %s' foo+* | _filter
_doit -l0 -c no-such-prog -c gzip -c bzip2 -V foo+
stat --format='%n %s' foo+* | _filter
_check foo+
_doit --decompress foo+
stat --format='%n %s' foo+* | _filter
# -N so no change here
_doit -l0 -A 'foo' -A '--bar' -A '--fumble' -f xz -N foo+
_doit -l0 -f xz pcp-meminfo
# skip already compresed files ...
_doit -l0 -f xz -V pcp-meminfo
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo
# args are files, not archive basename
_doit --decompress pcp-meminfo.meta.xz
stat --format='%n %s' pcp-meminfo* | _filter
_doit --decompress pcp-meminfo.0.xz blah
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo
_doit --compress -l0 -f xz pcp-meminfo.meta
stat --format='%n %s' pcp-meminfo* | _filter
_doit --compress -l0 -f xz pcp-meminfo.0 blah
stat --format='%n %s' pcp-meminfo* | _filter
_check pcp-meminfo

# success, all done
exit
