BUFR operator 203YYY: encoding test

This commit is contained in:
Shahram Najm 2022-04-25 16:45:17 +01:00
parent 796beac27c
commit 0a54b2a763
3 changed files with 66 additions and 2 deletions

View File

@ -161,6 +161,7 @@ if( HAVE_BUILD_TOOLS )
bufr_ecc-288
bufr_ecc-313
bufr_ecc-616
bufr_ecc-680
bufr_ecc-686
bufr_ecc-690
bufr_ecc-379

View File

@ -11,8 +11,8 @@
. ./include.ctest.sh
# ---------------------------------------------------------
# This is the test for the JIRA issue ECC-616.
# It tests encoding a BUFR file which uses the operator 203YYY.
# This is the test for the JIRA issue ECC-616:
# Cannot extract subsets when operator 203YYY is present
# ---------------------------------------------------------
label="bufr_ecc-616-test"
tempRules=temp.${label}.filter

63
tests/bufr_ecc-680.sh Executable file
View File

@ -0,0 +1,63 @@
#!/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
# ---------------------------------------------------------
# This is the test for the JIRA issue ECC-680:
# BUFR operator 203YYY: implement encoding
# ---------------------------------------------------------
label="bufr_ecc-680-test"
tempBufr=temp.$label.bufr
tempFilt=temp.${label}.filter
tempText=temp.${label}.txt
sample_bufr4=$ECCODES_SAMPLES_PATH/BUFR4.tmpl
# Try it without overriding the reference values
# ---------------------------------------------
cat > $tempFilt <<EOF
set unexpandedDescriptors = { 307080 };
set heightOfStationGroundAboveMeanSeaLevel = -415;
set heightOfBarometerAboveMeanSeaLevel = -417;
set pack = 1;
write;
EOF
# Should fail
set +e
${tools_dir}/codes_bufr_filter -o $tempBufr $tempFilt $sample_bufr4 2>$tempText
status=$?
set -e
[ $status -ne 0 ]
grep -q "Value .* out of range" $tempText
# Now provide the 203YYY operator
# ---------------------------------
cat > $tempFilt <<EOF
set inputOverriddenReferenceValues = { -5000, -5000 };
set unexpandedDescriptors = { 203014, 7030, 7031, 203255, 307080 };
set heightOfStationGroundAboveMeanSeaLevel = -415;
set heightOfBarometerAboveMeanSeaLevel = -417;
set pack = 1;
write;
EOF
${tools_dir}/codes_bufr_filter -o $tempBufr $tempFilt $sample_bufr4
val=`${tools_dir}/bufr_get -s unpack=1 -p heightOfStationGroundAboveMeanSeaLevel $tempBufr`
[ "$val" = "-415" ]
val=`${tools_dir}/bufr_get -s unpack=1 -p heightOfBarometerAboveMeanSeaLevel $tempBufr`
[ "$val" = "-417" ]
rm -f $tempBufr $tempFilt $tempText