eccodes/tests/bufr_dump_encode_python.sh

57 lines
1.4 KiB
Bash
Executable File

#!/bin/sh
# Copyright 2005-2017 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
#Define a common label for all the tmp files
label="bufr_dump_encode_python_test"
#Create log file
fLog=${label}".log"
rm -f $fLog
tempBufr=outfile.bufr
tempDir=${label}.dir
mkdir -p $tempDir
cd $tempDir
bufr_files=`cat ${data_dir}/bufr/bufr_data_files.txt`
for file in ${bufr_files}
do
inputBufr=${data_dir}/bufr/$file
tempSrc=$label.$file.py
# Too large for this test
if [ "$file" = "ias1_240.bufr" ]; then
continue
fi
# Generate Python code from BUFR file
${tools_dir}/bufr_dump -Epython $inputBufr > $tempSrc
# The python code always creates an output file called outfile.bufr
$PYTHON $tempSrc
# Check original BUFR file against one we generated from sample
${tools_dir}/bufr_compare $inputBufr $tempBufr
TEMP_JSON1=${label}.$file.json
TEMP_JSON2=${label}.$tempBufr.json
${tools_dir}/bufr_dump $inputBufr > $TEMP_JSON1
${tools_dir}/bufr_dump $tempBufr > $TEMP_JSON2
diff $TEMP_JSON1 $TEMP_JSON2 2>/dev/null
rm -f $TEMP_JSON1 $TEMP_JSON2
rm -f $tempSrc $tempBufr
done
cd $test_dir
rm -fr $tempDir