#!/bin/sh # Copyright 2005-2016 ECMWF. # # This software is licensed under the terms of the Apache Licence Version 2.0 # which can be obtained at http://www.apache.org/licenses/LICENSE-2.0. # # In applying this licence, ECMWF does not waive the privileges and immunities granted to it by # virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction. # . ./include.sh #set -x #Enter data dir cd ${data_dir}/bufr #Define a common label for all the tmp files label="bufr_compare_test" #Create log file fLog=${label}".log" rm -f $fLog touch $fLog #Define tmp bufr file fBufrTmp=${label}".bufr.tmp" fBufrInput1=${label}".bufr.input1" fBufrInput2=${label}".bufr.input2" #---------------------------------------------------- # Test: comparing same files #---------------------------------------------------- f="syno_1.bufr" echo "Test: comparing the same files" >> $fLog echo "file: $f" >> $fLog ${tools_dir}/bufr_compare $f $f >> $fLog #---------------------------------------------------- # Test: comparing two completely different files #---------------------------------------------------- set +e f1="syno_1.bufr" f2="aaen_55.bufr" echo "Test: comparing two completely different files" >> $fLog echo "file: $f" >> $fLog ${tools_dir}/bufr_compare $f1 $f2 >> $fLog if [ $? -eq 0 ]; then echo "bufr_compare should have failed if files are completely different" >&2 exit 1 fi set -e #---------------------------------------------------- # Test: comparing with and witout the -b switch #---------------------------------------------------- f="syno_1.bufr" echo "Test: comparing with and witout the -b switch" >> $fLog echo "file: $f" >> $fLog #Alter a key in the file ${tools_dir}/bufr_set -s dataCategory=2 $f ${fBufrTmp} >> $fLog set +e ${tools_dir}/bufr_compare $f ${fBufrTmp}>> $fLog if [ $? -eq 0 ]; then echo "bufr_compare should have failed if files are different" >&2 exit 1 fi set -e #Now compare with -b switch. No difference should be found. ${tools_dir}/bufr_compare -b dataCategory $f ${fBufrTmp}>> $fLog #---------------------------------------------------- # Test: comparing with the -r switch #---------------------------------------------------- #Create a bufr file with various message types cat syno_multi.bufr temp_101.bufr > $fBufrInput1 cat temp_101.bufr syno_multi.bufr > $fBufrInput2 set +e ${tools_dir}/bufr_compare ${fBufrInput1} ${fBufrInput2} >> $fLog if [ $? -eq 0 ]; then echo "bufr_compare should have failed if the message order in the files is different" >&2 exit 1 fi ${tools_dir}/bufr_compare -r ${fBufrInput1} ${fBufrInput2}>> $fLog #---------------------------------------------------- # Change subCentre and compare #---------------------------------------------------- ${tools_dir}bufr_set -s subCentre=12 aaen_55.bufr $fBufrTmp set +e ${tools_dir}bufr_compare aaen_55.bufr $fBufrTmp >/dev/null status=$? set -e [ $status -eq 1 ] #---------------------------------------------------- # Compare file with directory #---------------------------------------------------- temp_dir=tempdir.bufr_compare mkdir -p $temp_dir infile=aaen_55.bufr cp $infile $temp_dir ${tools_dir}bufr_compare $infile $temp_dir >/dev/null #Clean up rm -f $fLog rm -f $fBufrTmp | true rm -f $fBufrInput1 | true rm -f $fBufrInput2 | true rm -rf $temp_dir