Skip to content

Commit

Permalink
Fix error code on file open error with test
Browse files Browse the repository at this point in the history
  • Loading branch information
wddgit committed Jul 12, 2023
1 parent debf659 commit c41f603
Show file tree
Hide file tree
Showing 11 changed files with 131 additions and 4 deletions.
7 changes: 7 additions & 0 deletions FWCore/Catalog/interface/FileLocator.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,12 @@ namespace edm {

class FileLocator {
public:
FileLocator(
edm::CatalogAttributes const& catAttr,
bool& fatalExceptionOccurred,
unsigned iCatalog = 0,
//storageDescriptionPath is used to override path provided by SiteLocalConfig. This is used in FileLocator_t.cpp tests
std::string const& storageDescriptionPath = std::string());
explicit FileLocator(
edm::CatalogAttributes const& catAttr,
unsigned iCatalog = 0,
Expand Down Expand Up @@ -45,6 +51,7 @@ namespace edm {
void parseRuleTrivialCatalog(tinyxml2::XMLElement* ruleNode, ProtocolRules& rules);
//using data-access
void init(edm::CatalogAttributes const& input_dataCatalog,
bool& fatalExceptionOccurred,
unsigned iCatalog,
std::string const& storageDescriptionPath);
void parseRule(boost::property_tree::ptree::value_type const& storageRule,
Expand Down
22 changes: 21 additions & 1 deletion FWCore/Catalog/src/FileLocator.cc
Original file line number Diff line number Diff line change
Expand Up @@ -50,10 +50,19 @@ namespace edm {
}

FileLocator::FileLocator(edm::CatalogAttributes const& catAttr,
bool& fatalExceptionOccurred,
unsigned iCatalog,
std::string const& storageDescriptionPath)
: m_destination("any") {
init(catAttr, iCatalog, storageDescriptionPath);
init(catAttr, fatalExceptionOccurred, iCatalog, storageDescriptionPath);
}

FileLocator::FileLocator(edm::CatalogAttributes const& catAttr,
unsigned iCatalog,
std::string const& storageDescriptionPath)
: m_destination("any") {
bool fatalExceptionOccurred = false;
init(catAttr, fatalExceptionOccurred, iCatalog, storageDescriptionPath);
}

FileLocator::~FileLocator() {}
Expand Down Expand Up @@ -220,6 +229,7 @@ namespace edm {
}

void FileLocator::init(edm::CatalogAttributes const& input_dataCatalog,
bool& fatalExceptionOccurred,
unsigned iCatalog,
std::string const& storageDescriptionPath) {
Service<SiteLocalConfig> localconfservice;
Expand Down Expand Up @@ -295,6 +305,16 @@ namespace edm {
m_prefix = found_protocol->second.get("prefix", kEmptyString);
if (m_prefix == kEmptyString) {
//get rules
if (found_protocol->second.find("rules") == found_protocol->second.not_found()) {
fatalExceptionOccurred = true;
cms::Exception ex("FileCatalog");
ex << "protocol must contain either a prefix or rules, "
<< "neither found for protocol \"" << aCatalog.protocol << "\" for the storage site \""
<< aCatalog.storageSite << "\" and volume \"" << aCatalog.volume
<< "\" in storage.json. Check site-local-config.xml <data-access> and storage.json";
ex.addContext("edm::FileLocator:init()");
throw ex;
}
const pt::ptree& rules = found_protocol->second.find("rules")->second;
//loop over rules
for (pt::ptree::value_type const& storageRule : rules) {
Expand Down
6 changes: 5 additions & 1 deletion FWCore/Catalog/src/InputFileCatalog.cc
Original file line number Diff line number Diff line change
Expand Up @@ -102,9 +102,13 @@ namespace edm {
fileLocators_.clear();
//Construct all file locators from data catalogs. If a data catalog is invalid (wrong protocol for example), it is skipped and no file locator is constructed (an exception is thrown out from FileLocator::init).
for (const auto& catalog : tmp_dataCatalogs) {
bool fatalExceptionOccurred = false;
try {
fileLocators_.push_back(std::make_unique<FileLocator>(catalog));
fileLocators_.push_back(std::make_unique<FileLocator>(catalog, fatalExceptionOccurred));
} catch (cms::Exception const& e) {
if (fatalExceptionOccurred) {
throw;
}
edm::LogWarning("InputFileCatalog")
<< "Caught an exception while constructing a file locator in InputFileCatalog::init: " << e.what()
<< "Skip this catalog";
Expand Down
5 changes: 3 additions & 2 deletions IOPool/Input/src/RootInputFileSequence.cc
Original file line number Diff line number Diff line change
Expand Up @@ -252,14 +252,15 @@ namespace edm {
}
for (std::vector<std::string>::const_iterator it = fNames.begin(); it != fNames.end(); ++it) {
try {
usedFallback_ = (it != fNames.begin());
std::unique_ptr<char[]> name(gSystem->ExpandPathName(it->c_str()));
filePtr = std::make_shared<InputFile>(name.get(), " Initiating request to open file ", inputType);
usedFallback_ = (it != fNames.begin());
break;
} catch (cms::Exception const& e) {
if (!skipBadFiles && std::next(it) == fNames.end()) {
InputFile::reportSkippedFile((*it), logicalFileName());
Exception ex(errors::FileOpenError, "", e);
errors::ErrorCodes errorCode = usedFallback_ ? errors::FallbackFileOpenError : errors::FileOpenError;
Exception ex(errorCode, "", e);
ex.addContext("Calling RootInputFileSequence::initTheFile()");
std::ostringstream out;
out << "Input file " << (*it) << " could not be opened.";
Expand Down
1 change: 1 addition & 0 deletions IOPool/Input/test/BuildFile.xml
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,5 @@

<test name="TestIOPoolInputRepeating" command="testRepeatingCachedRootSource.sh"/>
<test name="TestIOPoolInputNoParentDictionary" command="testNoParentDictionary.sh"/>
<test name="TestFileOpenErrorExitCode" command="testFileOpenErrorExitCode.sh"/>
</environment>
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
[
{ "site": "DUMMY",
"volume": "DummyVolume",
"protocols": [
{ "protocol": "protocolThatDoesNotExist",
"prefix": "abc"
}
]
}
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<site-local-config>
<site name="DUMMY">
<data-access>
<catalog volume="DummyVolume" protocol="protocolThatDoesNotExist"/>
</data-access>
</site>
</site-local-config>
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
[
{ "site": "DUMMY",
"volume": "DummyVolume1",
"protocols": [
{ "protocol": "protocolThatDoesNotExist1",
"prefix": "abc"
}
]
},
{ "site": "DUMMY",
"volume": "DummyVolume2",
"protocols": [
{ "protocol": "protocolThatDoesNotExist2",
"prefix": "abc"
}
]
}
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
<site-local-config>
<site name="DUMMY">
<data-access>
<catalog volume="DummyVolume1" protocol="protocolThatDoesNotExist1"/>
<catalog volume="DummyVolume2" protocol="protocolThatDoesNotExist2"/>
</data-access>
</site>
</site-local-config>
34 changes: 34 additions & 0 deletions IOPool/Input/test/testFileOpenErrorExitCode.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
#!/bin/bash

# Pass in name and status
function die { echo $1: status $2 ; exit $2; }

mkdir -p SITECONF
mkdir -p SITECONF/local
mkdir -p SITECONF/local/JobConfig

export SITECONFIG_PATH=${PWD}/SITECONF/local
LOCAL_TEST_DIR=${SCRAM_TEST_PATH}

cp ${LOCAL_TEST_DIR}/sitelocalconfig/noFallbackFile/site-local-config.xml ${SITECONFIG_PATH}/JobConfig/
cp ${LOCAL_TEST_DIR}/sitelocalconfig/noFallbackFile/local/storage.json ${SITECONFIG_PATH}/
F1=${LOCAL_TEST_DIR}/test_fileOpenErrorExitCode_cfg.py
cmsRun -j NoFallbackFile_jobreport.xml $F1 -- --input FileThatDoesNotExist.root && die "$F1 should have failed but didn't, exit code was 0" 1

CMSRUN_EXIT_CODE=$(edmFjrDump --exitCode NoFallbackFile_jobreport.xml)
echo "Exit code after first run of test_fileOpenErrorExitCode_cfg.py is ${CMSRUN_EXIT_CODE}"
if [ "x${CMSRUN_EXIT_CODE}" != "x8020" ]; then
echo "Unexpected cmsRun exit code after FileOpenError, exit code from jobReport ${CMSRUN_EXIT_CODE} which is different from the expected 8020"
exit 1
fi

cp ${LOCAL_TEST_DIR}/sitelocalconfig/useFallbackFile/site-local-config.xml ${SITECONFIG_PATH}/JobConfig/
cp ${LOCAL_TEST_DIR}/sitelocalconfig/useFallbackFile/local/storage.json ${SITECONFIG_PATH}/
cmsRun -j UseFallbackFile_jobreport.xml $F1 -- --input FileThatDoesNotExist.root && die "$F1 should have failed after file fallback but didn\'t, exit code was 0" 1

CMSRUN_EXIT_CODE=$(edmFjrDump --exitCode UseFallbackFile_jobreport.xml)
echo "Exit code after second run of test_fileOpenErrorExitCode_cfg.py is ${CMSRUN_EXIT_CODE}"
if [ "x${CMSRUN_EXIT_CODE}" != "x8028" ]; then
echo "Unexpected cmsRun exit code after FallbackFileOpenError, exit code from jobReport ${CMSRUN_EXIT_CODE} which is different from the expected 8028"
exit 1
fi
17 changes: 17 additions & 0 deletions IOPool/Input/test/test_fileOpenErrorExitCode_cfg.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import FWCore.ParameterSet.Config as cms
import argparse
import sys

parser = argparse.ArgumentParser(prog=sys.argv[0], description="Test FileOpenErrorExitCode")
parser.add_argument("--input", type=str, default=[], nargs="*", help="Optional list of input files")

argv = sys.argv[:]
if '--' in argv:
argv.remove("--")
args, unknown = parser.parse_known_args(argv)

process = cms.Process("TEST")

process.source = cms.Source("PoolSource",
fileNames = cms.untracked.vstring("/store/"+x for x in args.input)
)

0 comments on commit c41f603

Please sign in to comment.