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
|
#! /bin/sh
# PCP QA Test No. 054
# Server, not client, hostname in archive label, ...
# also exposed pmlogger "dump core when no more events" problem!
#
# Copyright (c) 1995-2002 Silicon Graphics, Inc. All Rights Reserved.
#
seq=`basename $0`
echo "QA output created by $seq"
# get standard filters
. ./common.product
. ./common.filter
. ./common.check
trap "rm -f $tmp $tmp.*; exit" 0 1 2 3 15
# real QA test starts here
host=`./getpmcdhosts -L -n1 2>$tmp.out` # choose a non-local host (foreign server)
if [ -z "$host" ]
then
_notrun "`cat $tmp.out`"
# NOTREACHED
fi
eval realhost=`pmprobe -v -h $host pmcd.hostname | $PCP_AWK_PROG '{ print $3 }'`
[ $realhost = Unknown ] && realhost=`pmhostname $host`
echo "Using host: $host" >> $seq_full
echo "Using realhost: $realhost" >> $seq_full
# Note:
# This used to log just hinv.ncpu, but as of late 2019 I started seeing
# this test hanging and the QA runs never finished across a number of
# machines in the QA Farm. The problem is the remote pmcd (usually, but
# not always, vm01 for me), where the pmDesc for hinv.ncpu was unavailable
# because there was no PMCD agent for the domain ... this means the linux
# PMDA was dead, but pmcd was alive.
# Added sample.seconds in the hope that this will avoid the problem for
# this test ... leaving the linux PMDA issue to be investigated separately.
#
echo "log mandatory on once { hinv.ncpu sample.seconds }" >$tmp.config
pmlogger -c $tmp.config -l $tmp.log -s 1 -h $host $tmp
_filter_pmlogger_log <$tmp.log
echo "host should be HOST ..."
pmdumplog -l $tmp 2>&1 \
| sed -e 's/host /Host /' \
-e "s/$realhost\$/HOST/" \
-e "s/$host\$/HOST/" \
| _filter_pmdumplog --any-version \
| sed -e 's/Host /host /'
exit 0
|