eccodes/tests/bufr_json_data.sh

97 lines
2.5 KiB
Bash
Raw Normal View History

#!/bin/sh
2020-01-28 14:32:34 +00:00
# (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
label="bufr_json_data_test"
tempRules=temp.${label}.filter
tempOut=temp.${label}.txt
tempBufr=temp.${label}.bufr
2024-01-09 13:13:32 +00:00
if [ $ECCODES_ON_WINDOWS -eq 1 ]; then
echo "$0: This test is currently disabled on Windows"
exit 0
fi
REDIRECT=/dev/null
2018-10-23 16:36:18 +00:00
2018-08-23 08:50:04 +00:00
cd ${data_dir}/bufr
if [ $HAVE_MEMFS -eq 1 ]; then
unset ECCODES_DEFINITION_PATH
unset ECCODES_SAMPLES_PATH
2018-08-23 08:50:04 +00:00
fi
# Decide if we have the JSON verifier commandline utility
JSON_VERIF="json_xs"
JSON_CHECK=""
if command -v $JSON_VERIF >/dev/null 2>&1; then
JSON_CHECK=$JSON_VERIF
fi
# ECC-1119: Check the json_xs command actually works!
set +e
echo '[]' | json_xs > $REDIRECT 2>&1
if [ $? -ne 0 ]; then JSON_CHECK=""; fi
set -e
echo "Using $JSON_CHECK ..."
2018-10-23 16:36:18 +00:00
# Test downloaded BUFR files
# -------------------------
bufr_files=`cat bufr_data_files.txt`
2018-10-23 16:36:18 +00:00
for file in ${bufr_files}; do
# Test the various JSON dump modes: 'structure', 'all' and 'flat'
for mode in s a f; do
2018-10-23 16:36:18 +00:00
rm -f ${file}.json
${tools_dir}/bufr_dump -j$mode $file 2> $REDIRECT > ${file}.json
2018-10-23 16:36:18 +00:00
if test "x$JSON_CHECK" != "x"; then
json_xs < ${file}.json >$REDIRECT 2> $REDIRECT
fi
done
rm -f ${file}.json
done
# ECC-233: Test JSON dump when selecting messages with '-w' switch
2022-06-09 17:02:55 +00:00
# -----------------------------------------------------------------
file=tropical_cyclone.bufr
for c in 1 3 1/3; do
${tools_dir}/bufr_dump -w count=$c $file 2> $REDIRECT > ${file}.json
if test "x$JSON_CHECK" != "x"; then
json_xs < ${file}.json >$REDIRECT 2> $REDIRECT
fi
2020-06-27 14:39:05 +00:00
rm -f ${file}.json
done
# ECC-272
2022-06-09 17:02:55 +00:00
# ------------
2018-10-23 16:36:18 +00:00
file=aaen_55.bufr
${tools_dir}/bufr_dump -jf $file | grep -q -w channelRadiance
# ECC-1401: BUFR: bufr_dump generates invalid JSON
2022-06-09 17:02:55 +00:00
# -------------------------------------------------
cat > $tempRules <<EOF
set unexpandedDescriptors = { 1015 };
set stationOrSiteName = 'Contains "bad" chars';
set pack = 1;
write;
EOF
2022-06-09 17:02:55 +00:00
${tools_dir}/codes_bufr_filter -o $tempBufr $tempRules $samp_dir/BUFR4.tmpl
${tools_dir}/bufr_dump $tempBufr > $tempOut
if test "x$JSON_CHECK" != "x"; then
json_xs -t none < $tempOut
fi
rm -f $tempRules $tempOut $tempBufr