mirror of https://github.com/ecmwf/eccodes.git
ECC-1847: GRIB: Setting invalid value for 'typeOfLevel' does not fail
This commit is contained in:
parent
eff3c07e19
commit
1a21092eac
|
@ -41,6 +41,6 @@ padto padding_loc2_2(offsetSection1 + 328);
|
||||||
|
|
||||||
|
|
||||||
constant unknown="-";
|
constant unknown="-";
|
||||||
concept_nofail clusteringDomain(unknown,"cluster_domain.def",conceptsMasterDir,conceptsLocalDirAll);
|
concept clusteringDomain(unknown,"cluster_domain.def",conceptsMasterDir,conceptsLocalDirAll);
|
||||||
alias number = clusterNumber;
|
alias number = clusterNumber;
|
||||||
alias domain = clusteringDomain;
|
alias domain = clusteringDomain;
|
||||||
|
|
|
@ -2,14 +2,12 @@
|
||||||
# created: 6 Oct 2011
|
# created: 6 Oct 2011
|
||||||
# modified: 13 Sep 2013
|
# modified: 13 Sep 2013
|
||||||
#
|
#
|
||||||
|
|
||||||
alias ls.dataType = marsType;
|
alias ls.dataType = marsType;
|
||||||
|
|
||||||
if (localDefinitionNumber == 83 ) {
|
if (localDefinitionNumber == 83 ) {
|
||||||
|
concept ls.timerepres (unknown,"timeRepresConcept.def",conceptsLocalDirAll,conceptsMasterDir);
|
||||||
concept_nofail ls.timerepres (unknown,"timeRepresConcept.def",conceptsLocalDirAll,conceptsMasterDir);
|
concept ls.sort (unknown,"sortConcept.def",conceptsLocalDirAll,conceptsMasterDir);
|
||||||
concept_nofail ls.sort (unknown,"sortConcept.def",conceptsLocalDirAll,conceptsMasterDir);
|
concept ls.landtype (unknown,"landTypeConcept.def",conceptsLocalDirAll,conceptsMasterDir);
|
||||||
concept_nofail ls.landtype (unknown,"landTypeConcept.def",conceptsLocalDirAll,conceptsMasterDir);
|
concept ls.aerosolbinnumber (unknown,"aerosolConcept.def",conceptsLocalDirAll,conceptsMasterDir);
|
||||||
concept_nofail ls.aerosolbinnumber (unknown,"aerosolConcept.def",conceptsLocalDirAll,conceptsMasterDir);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,6 @@ if ( localDefinitionNumber == 83 ) {
|
||||||
alias mars.landtype = matchLandType;
|
alias mars.landtype = matchLandType;
|
||||||
alias mars.aerosolbinnumber = matchAerosolBinNumber;
|
alias mars.aerosolbinnumber = matchAerosolBinNumber;
|
||||||
|
|
||||||
concept_nofail matchAerosolPacking (unknown,"aerosolPackingConcept.def",conceptsLocalMarsDirAll,conceptsMasterMarsDir);
|
concept matchAerosolPacking (unknown,"aerosolPackingConcept.def",conceptsLocalMarsDirAll,conceptsMasterMarsDir);
|
||||||
alias mars.aerosolpacking = matchAerosolPacking;
|
alias mars.aerosolpacking = matchAerosolPacking;
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,8 +58,8 @@ alias levelType=indicatorOfTypeOfLevel;
|
||||||
|
|
||||||
transient pressureUnits="hPa";
|
transient pressureUnits="hPa";
|
||||||
|
|
||||||
concept_nofail typeOfLevelECMF (unknown, "typeOfLevel.def",conceptsMasterDir,conceptsLocalDirECMF);
|
concept typeOfLevelECMF (unknown, "typeOfLevel.def",conceptsMasterDir,conceptsLocalDirECMF);
|
||||||
concept_nofail vertical.typeOfLevel (typeOfLevelECMF, "typeOfLevel.def",conceptsDir2,conceptsDir1);
|
concept vertical.typeOfLevel (typeOfLevelECMF, "typeOfLevel.def",conceptsDir2,conceptsDir1);
|
||||||
|
|
||||||
when ( typeOfLevel is "isobaricInPa" ) { set pressureUnits="Pa"; }
|
when ( typeOfLevel is "isobaricInPa" ) { set pressureUnits="Pa"; }
|
||||||
else { set pressureUnits="hPa";}
|
else { set pressureUnits="hPa";}
|
||||||
|
|
|
@ -2,10 +2,10 @@
|
||||||
|
|
||||||
# See ECC-1846
|
# See ECC-1846
|
||||||
if (centre is "ecmf" or datasetForLocal is "era6") {
|
if (centre is "ecmf" or datasetForLocal is "era6") {
|
||||||
concept_nofail modelName(unknown, "modelNameConcept.def", conceptsMasterDir, conceptsLocalDirAll): no_copy, dump, read_only;
|
concept modelName(unknown, "modelNameConcept.def", conceptsMasterDir, conceptsLocalDirAll): no_copy, dump, read_only;
|
||||||
|
|
||||||
if (!(modelName is "unknown")) {
|
if (!(modelName is "unknown")) {
|
||||||
concept_nofail modelVersion(unknown, "modelVersionConcept_[modelName].def", conceptsMasterDir, conceptsLocalDirAll): no_copy, dump, read_only;
|
concept modelVersion(unknown, "modelVersionConcept_[modelName].def", conceptsMasterDir, conceptsLocalDirAll): no_copy, dump, read_only;
|
||||||
# alias ls.model = modelName;
|
# alias ls.model = modelName;
|
||||||
# alias mars.model = modelName;
|
# alias mars.model = modelName;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,16 +1,15 @@
|
||||||
# author: Sebastien Villaume
|
# author: Sebastien Villaume
|
||||||
# created: 14 Feb 2014
|
# created: 14 Feb 2014
|
||||||
#
|
#
|
||||||
|
|
||||||
constant g1conceptsMasterDir="grib1" : hidden;
|
constant g1conceptsMasterDir="grib1" : hidden;
|
||||||
constant g1conceptsLocalDirAll="grib1/localConcepts/[centre:s]" : hidden;
|
constant g1conceptsLocalDirAll="grib1/localConcepts/[centre:s]" : hidden;
|
||||||
|
|
||||||
alias ls.dataType = marsType;
|
alias ls.dataType = marsType;
|
||||||
|
|
||||||
if (localDefinitionNumber == 83 ) {
|
if (localDefinitionNumber == 83 ) {
|
||||||
concept_nofail ls.timerepres (unknown,"timeRepresConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
concept ls.timerepres (unknown,"timeRepresConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
||||||
concept_nofail ls.sort (unknown,"sortConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
concept ls.sort (unknown,"sortConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
||||||
concept_nofail ls.landtype (unknown,"landTypeConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
concept ls.landtype (unknown,"landTypeConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
||||||
concept_nofail ls.aerosolbinnumber (unknown,"aerosolConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
concept ls.aerosolbinnumber (unknown,"aerosolConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ if ( localDefinitionNumber == 83 ) {
|
||||||
alias mars.landtype = matchLandType;
|
alias mars.landtype = matchLandType;
|
||||||
alias mars.aerosolbinnumber = matchAerosolBinNumber;
|
alias mars.aerosolbinnumber = matchAerosolBinNumber;
|
||||||
|
|
||||||
concept_nofail matchAerosolPacking (unknown,"aerosolPackingConcept.def",conceptsLocalMarsDirAll,conceptsMasterMarsDir);
|
concept matchAerosolPacking (unknown,"aerosolPackingConcept.def",conceptsLocalMarsDirAll,conceptsMasterMarsDir);
|
||||||
alias mars.aerosolpacking = matchAerosolPacking;
|
alias mars.aerosolpacking = matchAerosolPacking;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ unsigned[4] scaledValueOfSecondFixedSurface = missing() : can_be_missing,dump,ed
|
||||||
|
|
||||||
transient pressureUnits="hPa";
|
transient pressureUnits="hPa";
|
||||||
|
|
||||||
concept_nofail vertical.typeOfLevel (unknown,"typeOfLevelConcept.def",conceptsDir2,conceptsDir1);
|
concept vertical.typeOfLevel (unknown,"typeOfLevelConcept.def",conceptsDir2,conceptsDir1);
|
||||||
|
|
||||||
alias levelType=typeOfFirstFixedSurface;
|
alias levelType=typeOfFirstFixedSurface;
|
||||||
|
|
||||||
|
|
|
@ -4,19 +4,15 @@
|
||||||
# created: 14 Feb 2014
|
# created: 14 Feb 2014
|
||||||
#
|
#
|
||||||
#########################
|
#########################
|
||||||
|
|
||||||
constant g1conceptsMasterDir="grib1" : hidden;
|
constant g1conceptsMasterDir="grib1" : hidden;
|
||||||
constant g1conceptsLocalDirAll="grib1/localConcepts/[centre:s]" : hidden;
|
constant g1conceptsLocalDirAll="grib1/localConcepts/[centre:s]" : hidden;
|
||||||
|
|
||||||
|
|
||||||
alias ls.dataType = marsType;
|
alias ls.dataType = marsType;
|
||||||
|
|
||||||
if (localDefinitionNumber == 83 ) {
|
if (localDefinitionNumber == 83 ) {
|
||||||
|
concept ls.timerepres (unknown,"timeRepresConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
||||||
concept_nofail ls.timerepres (unknown,"timeRepresConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
concept ls.sort (unknown,"sortConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
||||||
concept_nofail ls.sort (unknown,"sortConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
concept ls.landtype (unknown,"landTypeConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
||||||
concept_nofail ls.landtype (unknown,"landTypeConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
concept ls.aerosolbinnumber (unknown,"aerosolConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
||||||
concept_nofail ls.aerosolbinnumber (unknown,"aerosolConcept.def",g1conceptsLocalDirAll,g1conceptsMasterDir);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ if ( localDefinitionNumber == 83 ) {
|
||||||
alias mars.landtype = matchLandType;
|
alias mars.landtype = matchLandType;
|
||||||
alias mars.aerosolbinnumber = matchAerosolBinNumber;
|
alias mars.aerosolbinnumber = matchAerosolBinNumber;
|
||||||
|
|
||||||
concept_nofail matchAerosolPacking (unknown,"aerosolPackingConcept.def",conceptsLocalMarsDirAll,conceptsMasterMarsDir);
|
concept matchAerosolPacking (unknown,"aerosolPackingConcept.def",conceptsLocalMarsDirAll,conceptsMasterMarsDir);
|
||||||
alias mars.aerosolpacking = matchAerosolPacking;
|
alias mars.aerosolpacking = matchAerosolPacking;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@ unsigned[4] scaledValueOfSecondFixedSurface = missing() : can_be_missing,dump,ed
|
||||||
|
|
||||||
transient pressureUnits="hPa";
|
transient pressureUnits="hPa";
|
||||||
|
|
||||||
concept_nofail vertical.typeOfLevel (unknown) {
|
concept vertical.typeOfLevel (unknown) {
|
||||||
#set uses the last one
|
#set uses the last one
|
||||||
#get returns the first match
|
#get returns the first match
|
||||||
'surface' = { typeOfFirstFixedSurface=1; typeOfSecondFixedSurface=255; }
|
'surface' = { typeOfFirstFixedSurface=1; typeOfSecondFixedSurface=255; }
|
||||||
|
|
|
@ -14,7 +14,7 @@ unsigned[4] scaledValueOfFirstFixedSurface = missing() : can_be_missing,dump,ed
|
||||||
####
|
####
|
||||||
transient pressureUnits="hPa";
|
transient pressureUnits="hPa";
|
||||||
|
|
||||||
concept_nofail vertical.typeOfLevel (unknown) {
|
concept vertical.typeOfLevel (unknown) {
|
||||||
#set uses the last one
|
#set uses the last one
|
||||||
#get returns the first match
|
#get returns the first match
|
||||||
'surface' = { typeOfFirstFixedSurface=1; }
|
'surface' = { typeOfFirstFixedSurface=1; }
|
||||||
|
|
|
@ -26,7 +26,7 @@ unsigned[4] scaledValueOfSecondFixedSurface = missing() : can_be_missing,dump,ed
|
||||||
#######
|
#######
|
||||||
transient pressureUnits="hPa";
|
transient pressureUnits="hPa";
|
||||||
|
|
||||||
concept_nofail vertical.typeOfLevel (unknown) {
|
concept vertical.typeOfLevel (unknown) {
|
||||||
#set uses the last one
|
#set uses the last one
|
||||||
#get returns the first match
|
#get returns the first match
|
||||||
'surface' = { typeOfFirstFixedSurface=1; typeOfSecondFixedSurface=255; }
|
'surface' = { typeOfFirstFixedSurface=1; typeOfSecondFixedSurface=255; }
|
||||||
|
|
|
@ -12,12 +12,16 @@
|
||||||
|
|
||||||
label="grib_typeOfLevel_test"
|
label="grib_typeOfLevel_test"
|
||||||
temp=temp.$label.txt
|
temp=temp.$label.txt
|
||||||
|
tempGrib=temp.$label.grib
|
||||||
|
|
||||||
if [ ! -d "$ECCODES_DEFINITION_PATH" ]; then
|
if [ ! -d "$ECCODES_DEFINITION_PATH" ]; then
|
||||||
echo "Test $0 disabled. No definitions directory"
|
echo "Test $0 disabled. No definitions directory"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
sample_g1=$ECCODES_SAMPLES_PATH/GRIB1.tmpl
|
||||||
|
sample_g2=$ECCODES_SAMPLES_PATH/GRIB2.tmpl
|
||||||
|
|
||||||
# Make sure all typeOfLevel values are unique
|
# Make sure all typeOfLevel values are unique
|
||||||
def_file="$ECCODES_DEFINITION_PATH/grib2/typeOfLevelConcept.def"
|
def_file="$ECCODES_DEFINITION_PATH/grib2/typeOfLevelConcept.def"
|
||||||
|
|
||||||
|
@ -35,4 +39,16 @@ else
|
||||||
echo "No duplicates in $def_file"
|
echo "No duplicates in $def_file"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm -f $temp
|
# ECC-1847: Setting invalid value for 'typeOfLevel' does not fail
|
||||||
|
for sample in $sample_g1 $sample_g2; do
|
||||||
|
set +e
|
||||||
|
${tools_dir}/grib_set -s typeOfLevel=rubbish $sample $tempGrib 2>$temp
|
||||||
|
status=$?
|
||||||
|
set -e
|
||||||
|
[ $status -ne 0 ]
|
||||||
|
grep -q "Concept no match" $temp
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
# Clean up
|
||||||
|
rm -f $temp $tempGrib
|
||||||
|
|
Loading…
Reference in New Issue