File: 054

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 (55 lines) | stat: -rwxr-xr-x 1,754 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
#! /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