diff --git a/FWCore/Framework/bin/cmsRun.cpp b/FWCore/Framework/bin/cmsRun.cpp index f9948c544d8a6..9121c4ea2a64b 100644 --- a/FWCore/Framework/bin/cmsRun.cpp +++ b/FWCore/Framework/bin/cmsRun.cpp @@ -293,12 +293,15 @@ int main(int argc, char* argv[]) { // check the "options" ParameterSet std::shared_ptr pset = processDesc->getProcessPSet(); - if (pset->existsAs("options", false)) { + // Note: it is important to not check the type or trackedness in + // exists() call to ensure that the getUntrackedParameter() calls + // will fail if the parameters have an incorrect type + if (pset->exists("options")) { auto const& ops = pset->getUntrackedParameterSet("options"); - if (ops.existsAs("numberOfThreads", false)) { + if (ops.exists("numberOfThreads")) { nThreads = ops.getUntrackedParameter("numberOfThreads"); } - if (ops.existsAs("sizeOfStackForThreadsInKB", false)) { + if (ops.exists("sizeOfStackForThreadsInKB")) { stackSize = ops.getUntrackedParameter("sizeOfStackForThreadsInKB"); } } @@ -318,7 +321,7 @@ int main(int argc, char* argv[]) { // update the numberOfThreads and sizeOfStackForThreadsInKB in the "options" ParameterSet edm::ParameterSet newOp; - if (pset->existsAs("options", false)) { + if (pset->exists("options")) { newOp = pset->getUntrackedParameterSet("options"); } newOp.addUntrackedParameter("numberOfThreads", nThreads); diff --git a/FWCore/Framework/test/BuildFile.xml b/FWCore/Framework/test/BuildFile.xml index 1cdb60e5f72fd..6bbaa05c295a1 100644 --- a/FWCore/Framework/test/BuildFile.xml +++ b/FWCore/Framework/test/BuildFile.xml @@ -325,3 +325,8 @@ + + + + + diff --git a/FWCore/Framework/test/run_wrongOptionsType.sh b/FWCore/Framework/test/run_wrongOptionsType.sh new file mode 100755 index 0000000000000..9e929cac18360 --- /dev/null +++ b/FWCore/Framework/test/run_wrongOptionsType.sh @@ -0,0 +1,10 @@ +#!/bin/bash + +NAME=$1 +VALUE=$2 + +function die { echo $1: status $2 ; echo === Log file === ; cat ${3:-/dev/null} ; echo === End log file === ; exit $2; } + +cmsRun ${LOCALTOP}/src/FWCore/Framework/test/test_wrongOptionsType_cfg.py -- --name=${NAME} --value="$VALUE" > ${NAME}.log 2>&1 && die "cmsRun for ${NAME} succeeded, should have failed" 1 ${NAME}.log +grep -E "(The type in the configuration is incorrect)|(ValueError type of .* is expected to be .* but declared as)" ${NAME}.log > /dev/null || die "cmsRun for ${NAME} failed for other reason than incorrect configuration type" $? ${NAME}.log + diff --git a/FWCore/Framework/test/test_wrongOptionsType_cfg.py b/FWCore/Framework/test/test_wrongOptionsType_cfg.py new file mode 100644 index 0000000000000..f1b43aa129166 --- /dev/null +++ b/FWCore/Framework/test/test_wrongOptionsType_cfg.py @@ -0,0 +1,22 @@ +import FWCore.ParameterSet.Config as cms + +import argparse +import sys + +parser = argparse.ArgumentParser(prog=sys.argv[0], description='Test wrong process.options parameter types') + +parser.add_argument("--name", help="Name of parameter", type=str) +parser.add_argument("--value", help="Value of the parameter", type=str) + +argv = sys.argv[:] +if '--' in argv: + argv.remove("--") +args, unknown = parser.parse_known_args(argv) + +process = cms.Process("TEST") +process.source = cms.Source("EmptySource") + +process.maxEvents = cms.untracked.PSet(input = cms.untracked.int32(2)) + +process.options = cms.untracked.PSet() +setattr(process.options, args.name, eval(str(args.value)))