eccodes/tests/grib_data_quality_checks.sh

97 lines
2.8 KiB
Bash
Raw Normal View History

2019-11-27 18:11:57 +00:00
#!/bin/sh
# Copyright 2005-2019 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
set -u
# ---------------------------------------------------------
# Tests for data quality checks
2019-11-27 18:11:57 +00:00
# ---------------------------------------------------------
label="grib_data_quality"
2019-11-29 14:45:55 +00:00
tempOut=temp.1.${label}.out
temp2=temp.2.${label}.out
2019-11-27 18:11:57 +00:00
tempErr=temp.${label}.err
2019-11-29 14:45:55 +00:00
# Start with clean environment
unset ECCODES_GRIB_DATA_QUALITY_CHECKS
unset ECCODES_EXTRA_DEFINITION_PATH
2019-11-27 18:11:57 +00:00
input1=${data_dir}/reduced_gaussian_surface.grib1
input2=${data_dir}/reduced_gaussian_surface.grib2
grib_check_key_equals $input1 paramId 167
grib_check_key_equals $input2 paramId 167
2019-11-27 18:11:57 +00:00
2019-11-29 14:45:55 +00:00
# Data quality checks disabled. Create huge values for temperature
2019-11-27 18:11:57 +00:00
${tools_dir}/grib_set -s scaleValuesBy=100 $input1 $tempOut
${tools_dir}/grib_set -s scaleValuesBy=100 $input2 $tempOut
2019-11-29 14:45:55 +00:00
# Data quality checks enabled. Repacking should fail
export ECCODES_GRIB_DATA_QUALITY_CHECKS=1
set +e
${tools_dir}/grib_copy -r $tempOut /dev/null 2>$tempErr
status=$?
set -e
[ $status -ne 0 ]
grep -q 'more than the allowable limit' $tempErr
2019-11-29 14:45:55 +00:00
# Data quality checks enabled but only as a warning. Repacking should pass
export ECCODES_GRIB_DATA_QUALITY_CHECKS=2
${tools_dir}/grib_copy -r $tempOut /dev/null 2>$tempErr
grep -q 'more than the allowable limit' $tempErr
2019-11-29 14:45:55 +00:00
# Data quality checks enabled. Scaling should fail
2019-11-27 18:11:57 +00:00
export ECCODES_GRIB_DATA_QUALITY_CHECKS=1
set +e
${tools_dir}/grib_set -s scaleValuesBy=100 $input1 $tempOut 2>$tempErr
status=$?
set -e
[ $status -ne 0 ]
grep -q 'GRIB1 simple packing: unable to set values' $tempErr
grep -q 'allowable limit' $tempErr
2019-11-27 18:11:57 +00:00
set +e
${tools_dir}/grib_set -s scaleValuesBy=100 $input2 $tempOut 2>$tempErr
status=$?
set -e
[ $status -ne 0 ]
grep -q 'GRIB2 simple packing: unable to set values' $tempErr
grep -q 'allowable limit' $tempErr
2019-11-27 18:11:57 +00:00
# Override the defaults
# ----------------------
tempDir=tempdir.$label
rm -rf $tempDir
mkdir -p $tempDir
# Set a large limit for temperature
cat > $tempDir/param_limits.def <<EOF
constant default_min_val = -1e9 : long_type, hidden;
constant default_max_val = +1e9 : long_type, hidden;
concept param_value_min(default_min_val) {
0 = { paramId=167; }
} : long_type, hidden;
concept param_value_max(default_max_val) {
40000 = { paramId=167; }
} : long_type, hidden;
EOF
2019-11-29 14:45:55 +00:00
# Command should succeed
export ECCODES_GRIB_DATA_QUALITY_CHECKS=1
2019-11-29 14:45:55 +00:00
export ECCODES_EXTRA_DEFINITION_PATH=$test_dir/$tempDir
${tools_dir}/grib_set -s scaleValuesBy=100 $input1 $tempOut
2019-11-27 18:11:57 +00:00
# Clean up
rm -rf $tempDir
2019-11-27 18:11:57 +00:00
rm -f $tempOut $tempErr