diff options
author | Igor Pashev <pashev.igor@gmail.com> | 2014-10-26 12:33:50 +0400 |
---|---|---|
committer | Igor Pashev <pashev.igor@gmail.com> | 2014-10-26 12:33:50 +0400 |
commit | 47e6e7c84f008a53061e661f31ae96629bc694ef (patch) | |
tree | 648a07f3b5b9d67ce19b0fd72e8caa1175c98f1a /qa/528 | |
download | pcp-debian.tar.gz |
Debian 3.9.10debian/3.9.10debian
Diffstat (limited to 'qa/528')
-rwxr-xr-x | qa/528 | 68 |
1 files changed, 68 insertions, 0 deletions
@@ -0,0 +1,68 @@ +#!/bin/sh +# PCP QA Test No. 528 +# Exercising log import API batching extensions. +# +# Copyright (c) 2013 Red Hat. +# + +seq=`basename $0` +echo "QA output created by $seq" + +# get standard environment, filters and checks +. ./common.product +. ./common.filter +. ./common.check + +test $PCP_VER -ge 3801 || _notrun "No support for log import batching" +[ -f ${PCP_LIB_DIR}/libpcp_import.${DSO_SUFFIX} ] || \ + _notrun "No support for libpcp_import" +perl -e "use PCP::LogImport" 2>/dev/null || \ + _notrun "Perl PCP::LogImport module is not installed" + +status=1 # failure is the default! +$sudo rm -rf $tmp.* $seq.full +trap "cd $here; rm -rf $tmp.*; exit \$status" 0 1 2 3 15 + +_filter1() +{ + sed \ + -e '/pmResult/s/ .* numpmid/ ... numpmid/' \ + -e '/[0-9][0-9]:[0-9][0-9]:[0-9][0-9]/s/[^ ]*/TIMESTAMP/' \ + -e '/^EXPORT_FAIL$/d' \ + -e '/::EXPORT_FAIL$/d' +} + +_filter2() +{ + _filter_pmdumplog \ + | sed \ + -e '/PID for pmlogger:/s/[0-9][0-9]*/PID/' +} + +_filter3() +{ + $PCP_AWK_PROG ' +BEGIN { part = "part1" } +NF == 0 { part = "part2" } + { print >part }' + if [ -f part1 ] + then + # first part of output is in non-deterministic order, so sort it + # + _filter1 <part1 | LC_COLLATE=POSIX sort + fi + [ -f part2 ] && _filter1 <part2 +} + +mkdir $tmp.dir +cd $tmp.dir + +# real QA test starts here +rm -f myarchive.* +perl $here/src/batch_import.perl 2>&1 | tee -a $here/$seq.full | _filter3 +pminfo -dm -a myarchive +pmdumplog -a myarchive 2>&1 | _filter2 + +# success, all done +status=0 +exit |