#!/bin/sh
# PCP QA Test No. 920
# pmlogger_check with Martins Innus <minnus@buffalo.edu> style
# multi-level directory structure.
#
# Copyright (c) 2017 Ken McDonell.  All Rights Reserved.
#
# check-group-include: logutil
#

seq=`basename $0`
echo "QA output created by $seq"

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

_check_job_scheduler

status=1	# failure is the default!
needclean=true
$sudo rm -rf $tmp $tmp.* $seq.full
trap "_cleanup; exit \$status" 0 1 2 3 15

pmlogger_farm_was_active=false
if which systemctl >/dev/null 2>&1
then
    eval `systemctl show pmlogger.service --property=ActiveState`
    if [ "$ActiveState" = active ]
    then
	pmlogger_farm_was_active=true
    fi
fi

_cleanup()
{
    if $needclean
    then
	_service pmlogger stop 2>&1 | _filter_pcp_stop
	_service pmlogger_farm stop 2>&1 | _filter_pcp_stop
	_restore_config $control
	needclean=false
	_service pmlogger start 2>&1 | _filter_pcp_start
	_wait_for_pmlogger
	$pmlogger_farm_was_active && _service pmlogger_farm start >>$seq.full
	_restore_job_scheduler $tmp.cron $tmp.systemd $sudo
    fi
    cd $here
    $sudo rm -rf $tmp $tmp.*
}

_report()
{
    # Note: some versions of ls(1), e.g. OS X, don't report directory
    # names from the command line (so no pmlogger: line below)
    #
    if [ ! -d $tmp ]
    then
	echo "Arrgh: directory $tmp not created"
	$PCP_PS_PROG $PCP_PS_ALL_FLAGS | egrep '[P]ID|[p]mlogger'
	return
    fi

    (cd $tmp; ls -lR pmlogger ) | $PCP_AWK_PROG '
$1 == "pmlogger:"	{ next }
NF < 4		{ print; next }
		{ print "mode=" $1 " user=" $3 " group=" $4 " name=" $NF }' \
    | sed \
	-e '/^total /d' \
	-e '/name=Latest/d' \
	-e '/name=lock/d' \
	-e 's/[2-9][0-9][0-9][0-9]:$/YYYY:/' \
	-e 's/[2-9][0-9][0-9][0-9]\/[01][0-9]:$/YYYY\/MM:/' \
	-e 's/[2-9][0-9][0-9][0-9]\/[01][0-9]\/[0-3][0-9]:$/YYYY\/MM\/DD:/' \
	-e 's/=[2-9][0-9][0-9][0-9]$/=YYYY/' \
	-e 's/=[0-3][0-9]$/=NN/' \
	-e 's/[2-9][0-9][0-9][0-9][01][0-9][0-3][0-9]/YYYYMMDD/' \
	-e 's/[012][0-9]\.[0-5][0-9]\./HH.MM./' \
	-e 's/\. user=/ user=/' \
    # end
}

_filter_pmlogger_check()
{
    sed \
	-e '/pmlogger_check.service/d' \
	-e '/pmlogger_check.timer/d' \
	-e '/pmlogger_check.path/d' \
    #end
}

control=$PCP_PMLOGGERCONTROL_PATH
[ -f $PCP_PMLOGGERCONTROL_PATH.d/local ] && \
control=$PCP_PMLOGGERCONTROL_PATH.d/local

export PMLOGGER_CHECK_SKIP_LOGCONF=yes

# real QA test starts here
_remove_job_scheduler $tmp.cron $tmp.systemd $sudo

cat <<End-of-File >$tmp.control
# dummy file created by qa/$seq on `date`
# the goal here is to have a non-primary logger that has a deeply
# nested directory structure for the logs
\$version=1.1
LOCALHOSTNAME   n   n   $tmp/pmlogger/myhost/2017/02/12 -c /dev/null -L -l $tmp.log.1
LOCALHOSTNAME	y   n	PCP_ARCHIVE_DIR/LOCALHOSTNAME	-r -T24h10m -c config.default -v 100Mb -l $tmp.log.2
End-of-File
_save_config $control
$sudo cp $tmp.control $control

_service pmlogger restart | _filter_pcp_start
_service pmlogger_farm start | _filter_pcp_start

# wait up to 20 seconds for our pmlogger to start
#
i=0
while [ $i -lt 20 ]
do
    if $PCP_PS_PROG $PCP_PS_ALL_FLAGS | grep '[p]mlogger.* -c /dev/null -L' >/dev/null
    then
	break
    fi
    sleep 1
    i=`expr $i + 1`
done

# pmlogger process has started, give it a chance to create the archive files
#
sleep 1

_report
echo

# wait for primary pmlogger ... our pmlogger may have got started first
# ... without this the _service stop in _cleanup() risks clobbering the
# previous start for the primary pmlogger before it is finished starting
# up, and this may lead to systemd complaints
#
_wait_for_pmlogger

# save pmlogger logs for triage
#
echo "=== pmlogger -c /dev/null -L" >>$seq.full
ls -lR $tmp/pmlogger/myhost/2017/02/12 >>$seq.full
cat $tmp.log.1 >>$seq.full
echo "=== pmlogger -c config.default" >>$seq.full
cat $tmp.log.2 >>$seq.full

# success, all done
status=0
exit
