#!/bin/sh # PCP QA Test No. 986 # Exercise the dmcache PMDA using the running kernel. # # Copyright (c) 2014 Red Hat. # seq=`basename $0` echo "QA output created by $seq" # get standard environment, filters and checks . ./common.product . ./common.filter . ./common.check status=1 # failure is the default! $sudo rm -f $tmp.* $seq.full _filter_dmcache() { # cull message resulting from no dmcache devices grep -v 'No value(s) available' } pmdadmcache_remove() { echo echo "=== remove dmcache agent ===" $sudo ./Remove >$tmp.out 2>&1 _filter_pmda_remove <$tmp.out } pmdadmcache_install() { # start from known starting points cd $PCP_PMDAS_DIR/dmcache $sudo ./Remove >/dev/null 2>&1 $sudo $PCP_RC_DIR/pmcd stop echo echo "=== dmcache agent installation ===" $sudo ./Install $tmp.out 2>&1 # Check dmcache metrics have appeared ... X metrics and Y values _filter_pmda_install <$tmp.out \ | sed \ -e '/^Waiting for pmcd/s/\.\.\.[. ]*$/DOTS/' \ -e 's/[0-9][0-9]* warnings, //' \ | $PCP_AWK_PROG ' /Check dmcache metrics have appeared/ { if ($7 >= 16 && $7 <= 20) $7 = "X" if ($10 >= 0 && $10 <= 80) $10 = "Y" } { print }' } _prepare_pmda dmcache trap "_cleanup_pmda dmcache; exit \$status" 0 1 2 3 15 # real QA test starts here pmdadmcache_install # pmcd should have been started by the Install process - check if pminfo -v dmcache > $tmp.info 2> $tmp.err then : else echo "... failed! ... here is the Install log ..." cat $tmp.out fi cat $tmp.info $tmp.err | _filter_dmcache pmdadmcache_remove status=0 exit