1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
|
#!/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_split_by_rdbSubtype"
temp=$label.temp
fRules=${label}.filter
# Do all the work in a temporary directory
temp_dir=tempdir.${label}
rm -rf $temp_dir
mkdir -p $temp_dir
cd $temp_dir
cat > $fRules <<EOF
write "out.filter_by_rdbSubtype.[rdbSubtype].bufr";
EOF
bufr_files=`cat ${data_dir}/bufr/bufr_data_files.txt`
for f in ${bufr_files}; do
fpath=${data_dir}/bufr/$f
# This will create output files like out.filter_by_rdbSubtype.*
${tools_dir}/codes_bufr_filter $fRules $fpath
# This will create output files like split_rdbSubtype*.bufr
${tools_dir}/bufr_split_by_rdbSubtype -v $fpath
for sp in out.filter_by_rdbSubtype.*; do
st=`echo $sp | awk -F. '{print $3}'`
${tools_dir}/bufr_compare $sp split_rdbSubtype.$st.bufr
done
rm -f split_rdbSubtype*.bufr
rm -f out.filter_by_rdbSubtype.*
done
# Failing cases
# ----------------
set +e
${tools_dir}/bufr_split_by_rdbSubtype
status=$?
set -e
[ $status -eq 1 ]
set +e
${tools_dir}/bufr_split_by_rdbSubtype $data_dir
status=$?
set -e
[ $status -eq 1 ]
# Clean up
# -------------
cd $test_dir
rm -fr $temp_dir
|