#!/bin/sh
#
# smidump-FORMAT.test --
#
# smidump test for various output formats and conversions.
#
# FORMAT=xxx :
# Check `smidump -f xxx' output for all TESTMIBS read from the libsmi MIB
# repository against nominal dumps/xxx/ files.
#
# FORMAT=xxx-yyy :
# Check `smidump -f yyy' output for all TESTMIBS read from dumps/xxx/
# against nominal dumps/yyy-xxx/ files.
#
# FORMAT=orig-yyy :
# Check `smidump -f yyy' output for all TESTMIBS read from the libsmi MIB
# repository against the original files from the repository. This is done
# by extracting unified characteristics of both files of each check
# (see the filter shell function) and comparing the diff with the nominal
# diff in dumps/orig-yyy/.
#
FORMAT=`echo $0 | sed -e 's/^.*smidump-\(.*\).test/\1/'`
ACTUALDIR=smidump-${FORMAT}.out
NOMINALDIR=dumps/${FORMAT}
INFORMAT=`echo -$FORMAT | sed -e 's/-[^-]*$//' -e 's/-//'`
OUTFORMAT=`echo $FORMAT | sed -e 's/[a-z0-9]*-//'`
filter() {
# 1. strip off comments
# 2. condens white space
# 3. remove ambigious white space
# 4. strip off texts enclosed in double qoutes
# 5. convert blanks back to nl, and finally
# 6. sort
sed -e 's/\"[a-z]*\"//g' | \
sed -e 's/--[^\"-]*--//g' -e 's/--[^\"]*$//' | \
tr '\t\n' ' ' | \
sed -e 's/ */ /g' | \
sed -e 's/SIZE (/SIZE(/g' -e 's/ }/}/g' | \
sed -e 's/\"[^\"]*\"/\"\"/g' | \
tr ' ' '\n' | \
sort
}
rm -rf ${ACTUALDIR}
mkdir ${ACTUALDIR}
RC=0
FAILED=""
for mib in ${TESTMIBS} ; do
if [ "$INFORMAT" -a "$INFORMAT" != "orig" ] ; then
input=../dumps/${INFORMAT}/$mib
else
input=$mib
fi
echo "comparing \`smidump -f ${OUTFORMAT} $input' output with ${NOMINALDIR}/*."
cd ${ACTUALDIR}
../../tools/smidump -c/dev/null -f ${OUTFORMAT} $input > $mib 2>/dev/null
if [ ! -s $mib ] ; then
rm $mib
FILES=""
else
FILES="$mib"
fi
FILES="$FILES "`ls -1 | grep -v '\.diff' | grep '\.'`
cd ..
for file in $FILES ; do
if [ "$INFORMAT" != "orig" ] ; then
/usr/bin/diff --ignore-matching-lines='generated by smidump' --ignore-matching-lines='$Id.*$' --ignore-matching-lines='@author.*smidump' ${ACTUALDIR}/$file ${NOMINALDIR}/$file >> ${ACTUALDIR}/$file.diff
else
filter < ../mibs/ietf/$mib > ${ACTUALDIR}/$file.orig
filter < ${ACTUALDIR}/$mib > ${ACTUALDIR}/$file.out
/usr/bin/diff --ignore-matching-lines='generated by smidump' --ignore-matching-lines='$Id.*$' --ignore-matching-lines='@author.*smidump' ${ACTUALDIR}/$file.orig ${ACTUALDIR}/$file.out > ${ACTUALDIR}/$file
/usr/bin/diff --ignore-matching-lines='generated by smidump' --ignore-matching-lines='$Id.*$' --ignore-matching-lines='@author.*smidump' ${ACTUALDIR}/$file ${NOMINALDIR}/$file > ${ACTUALDIR}/$file.diff
fi
if [ ! -s ${ACTUALDIR}/$file.diff ] ; then
rm ${ACTUALDIR}/$file.diff
else
FAILED=1
fi
echo "cmp -s ${ACTUALDIR}/$file ${NOMINALDIR}/$file || \$CMDPREFIX cp -v ${ACTUALDIR}/$file ${NOMINALDIR}/$file" >> sync-dumps
done
rm -f ${ACTUALDIR}/*.orig ${ACTUALDIR}/*.out
done
if [ "$FAILED" ] ; then
echo "*** smidump output differs, see ${ACTUALDIR}/*.diff"
RC=1
fi
exit ${RC}