eccodes/tests/utils.sh

52 lines
1.3 KiB
Bash
Raw Normal View History

2022-08-02 14:37:20 +00:00
#!/bin/sh
2020-01-28 14:32:34 +00:00
# (C) Copyright 2005- ECMWF.
2015-04-30 09:14:58 +00:00
#
# 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.
#
set -ea
#
# Utility functions for testing
#
# Check the key(s) in the given grib file have the expected value(s)
# Assumes the file has only ONE message otherwise output goes on to
# several lines
2016-01-21 16:52:24 +00:00
grib_check_key_equals()
2015-04-30 09:14:58 +00:00
{
a_file=$1
a_key=$2
a_expected=$3
2017-02-03 14:21:24 +00:00
a_result=`${tools_dir}/grib_get -p $a_key $a_file`
if [ "$a_result" != "$a_expected" ]; then
echo "File: '$a_file'"
echo "Key(s): '$a_key'"
echo "Expected: '$a_expected'"
echo "Result: '$a_result'"
exit 1
fi
2015-04-30 09:14:58 +00:00
}
2016-01-21 16:52:24 +00:00
grib_check_key_exists()
{
a_file=$1
a_key=$2
2016-01-21 16:52:24 +00:00
# grib_get will fail if the key is not found
$tools_dir/grib_get -p $a_key $a_file >/dev/null
2016-01-21 16:52:24 +00:00
}
# This is useful in situations where we intend a key to have
# a single value (size=1). For example when we redefine a transient
grib_check_key_is_scalar()
{
a_file=$1
a_key=$2
a_val=$3
result=$(echo "print '|[$a_key]|';" | ${tools_dir}/grib_filter - $a_file)
[ "$result" = "|$a_val|" ]
}