#!/bin/sh # (C) Copyright 2005- 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.ctest.sh # Define a common label for all the tmp files label="bufr_dump_data_test" fLog=temp.$label.log fJsonTmp=temp.$label.json if [ $HAVE_MEMFS -eq 1 ]; then unset ECCODES_DEFINITION_PATH unset ECCODES_SAMPLES_PATH fi #============================================== # Test downloaded data files #============================================== bufr_files=`cat ${data_dir}/bufr/bufr_data_files.txt` for file in ${bufr_files}; do ${tools_dir}/bufr_dump -O ${data_dir}/bufr/$file >/dev/null done # Check "subsetNumber" key is in the dump for uncompressed # BUFRs with numberOfSubsets > 1 files='delayed_repl_01.bufr synop_multi_subset.bufr' for f in $files; do ${tools_dir}/bufr_dump -p ${data_dir}/bufr/$f > $fLog grep -q "^subsetNumber=[1-9]" $fLog done #============================================== # Testing output when ECCODES_DEBUG is enabled #============================================== file="aaen_55.bufr" export ECCODES_DEBUG=1 # By default debug output goes to stderr ${tools_dir}/bufr_dump -O ${data_dir}/bufr/$file > $fLog 2>&1 grep -q "parsing include file" $fLog # Redirect it to stdout rm $fLog export ECCODES_LOG_STREAM=stdout ${tools_dir}/bufr_dump -O ${data_dir}/bufr/$file > $fLog grep -q "parsing include file" $fLog unset ECCODES_DEBUG unset ECCODES_LOG_STREAM # This one should fail file=${data_dir}/bufr/vos308014_v3_26.bufr set +e ${tools_dir}/bufr_dump -ja $file status=$? set -e [ $status -ne 0 ] set +e ${tools_dir}/bufr_dump $file status=$? set -e [ $status -ne 0 ] set +e ${tools_dir}/bufr_dump -p $file status=$? set -e [ $status -ne 0 ] #============================================== # Testing a malformed bufr file (see ECC-110) #============================================== # find another way to test malformed bufr #echo "Test: malformed bufr file " >> $fLog #rm -f $fJsonTmp #fBufr=${data_dir}/bufr/"bad.bufr" # See ECC-276 # In v0.16.0 we changed the shortNames so we use a newer ref file #fJsonRef=${data_dir}/bufr/"bad.bufr.json.v0.16.0.ref" #${tools_dir}/bufr_dump -js $fBufr > $fJsonTmp #diff $fJsonTmp $fJsonRef #============================================== # Testing change of scale (see ECC-111) #============================================== # FIND another way to test this operator #echo "Test: operator 207003 " >> $fLog #rm -f $fJsonTmp #fBufr=${data_dir}/bufr/"207003.bufr" #fJsonRef=${data_dir}/bufr/"207003.bufr.json.ref" # #${tools_dir}/bufr_dump -ja $fBufr > $fJsonTmp # #diff $fJsonTmp $fJsonRef # # Clean up #rm -f $fLog #rm -f $fJsonTmp rm -f $fLog