File: 1180

package info (click to toggle)
pcp 7.1.0-1
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 252,748 kB
  • sloc: ansic: 1,483,656; sh: 182,366; xml: 160,462; cpp: 83,813; python: 24,980; perl: 18,327; yacc: 6,877; lex: 2,864; makefile: 2,738; awk: 165; fortran: 60; java: 52
file content (72 lines) | stat: -rwxr-xr-x 1,714 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#!/bin/sh
# PCP QA Test No. 1180
# test pmlogger_daily_report(1)
#
# NOTE: if any of pmrep :sar-FOO configs get changed, then it's likely
# the qualified output for this test will need to be remade.
#
# Copyright (c) 2018 Red Hat.  All Rights Reserved.
#
# check-group-include: pmrep

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

# get standard environment, filters and checks
. ./common.python

$python -c "from pcp import pmapi" >/dev/null 2>&1
[ $? -eq 0 ] || _notrun "python pcp pmapi module not installed"

[ -x $PCP_BINADM_DIR/pmlogger_daily_report ] || \
	_notrun pmlogger_daily_report not installed

[ "$PCP_PLATFORM" = freebsd ] && _notrun "Insufficient metrics on FreeBSD to exercise sar-like reporting"

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

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

_filter()
{
    sed \
	-e '/^Host: /s/: .*/: .../' \
	-e '/^Report created: /s/: .*/: .../' \
	-e "s@$tmp@TMP@g" \
    # end
}

# real QA test starts here
mkdir -p $tmp
$sudo chown $PCP_USER:$PCP_GROUP $tmp
if xzcat archives/crontab-sar-report.tar.xz >$tmp.tar
then
    :
else
    echo "Arrgh: xzcat failed"
    exit
fi
if $sudo -u $PCP_USER tar xf $tmp.tar -C $tmp
then
    :
else
    echo "Arrgh: tar failed"
    exit
fi
ls -lR $tmp/crontab-sar-report* >>$seq_full
$sudo -u $PCP_USER -g $PCP_GROUP $PCP_BINADM_DIR/pmlogger_daily_report -A -a $tmp/crontab-sar-report -l $tmp/LOG -f $tmp/OUT -t 30m || exit
[ -f $tmp/LOG ] && $sudo cat $tmp/LOG >> $seq_full
$sudo cat $tmp/OUT | tee -a $seq_full | _filter

# optional stuff if your test has verbose output to help resolve problems
echo
echo "If failure, check $seq.full"

# success, all done
status=0
exit