Skip to content

Commit

Permalink
fix site-local-config.xml parsing when subsite tag has no children
Browse files Browse the repository at this point in the history
  • Loading branch information
nhduongvn committed Apr 7, 2023
1 parent 0a65cc0 commit b95045c
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 23 deletions.
43 changes: 26 additions & 17 deletions FWCore/Services/src/SiteLocalConfigService.cc
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
#include <sstream>
#include <memory>
#include <boost/algorithm/string.hpp>

//<<<<<< PRIVATE DEFINES >>>>>>
//<<<<<< PRIVATE CONSTANTS >>>>>>
//<<<<<< PRIVATE TYPES >>>>>>
Expand Down Expand Up @@ -192,19 +191,29 @@ namespace edm {
if (aDataCatalog.site == aDataCatalog.storageSite) {
//it is a site (no defined subSite), use local path given in SITECONFIG_PATH
if (aDataCatalog.subSite.empty())
filename_storage = siteconfig_path + "/storage.json";
filename_storage = siteconfig_path;
//it is a subsite, move one level up
else
filename_storage = siteconfig_path + "/../storage.json";
filename_storage = siteconfig_path + "/..";
} else { //cross site
//it is a site (no defined subSite), move one level up
if (aDataCatalog.subSite.empty())
filename_storage = siteconfig_path + "/../" + aDataCatalog.storageSite + "/storage.json";
filename_storage = siteconfig_path + "/../" + aDataCatalog.storageSite;
//it is a subsite, move two levels up
else
filename_storage = siteconfig_path + "/../../" + aDataCatalog.storageSite + "/storage.json";
filename_storage = siteconfig_path + "/../../" + aDataCatalog.storageSite;
}
filename_storage /= "storage.json";
try {
filename_storage = std::filesystem::canonical(filename_storage);
} catch (std::exception &e) {
cms::Exception ex("SiteLocalConfigService");
ex << "Fail to convert path to the storage description, " << filename_storage.string()
<< ", to the canonical absolute path"
<< ". Path exists?";
ex.addContext("edm::SiteLocalConfigService::storageDescriptionPath()");
throw ex;
}

return filename_storage;
}

Expand Down Expand Up @@ -341,7 +350,7 @@ namespace edm {
// The Site Config has the following format
// <site-local-config>
// <site name="FNAL">
// <subsite name="FNAL_SUBSITE">
// <subsite name="FNAL_SUBSITE"/>
// <event-data>
// <catalog url="trivialcatalog_file:/x/y/z.xml"/>
// <rfiotype value="castor"/>
Expand All @@ -365,7 +374,6 @@ namespace edm {
// <protocol prefix="file"/>
// </native-protocols>
// </source-config>
// </subsite>
// </site>
// </site-local-config>

Expand All @@ -378,13 +386,20 @@ namespace edm {
// Parse the site name
m_siteName = safe(site->Attribute("name"));
m_subSiteName = std::string();
if (subSite)
if (subSite) {
//check to make sure subSite has no children
auto subSite_first_child = subSite->FirstChild();
if (subSite_first_child) {
cms::Exception ex("SiteLocalConfigService");
ex << "Invalid site-local-config.xml. Subsite node has children!";
ex.addContext("edm::SiteLocalConfigService::parse()");
throw ex;
}
m_subSiteName = safe(subSite->Attribute("name"));
}

// Parsing of the event data section
auto eventData = site->FirstChildElement("event-data");
if (subSite)
eventData = subSite->FirstChildElement("event-data");
if (eventData) {
auto catalog = eventData->FirstChildElement("catalog");
if (catalog) {
Expand All @@ -411,8 +426,6 @@ namespace edm {
//2. if SUBSITE is empty, this is a site. Otherwise, this is a subsite. These are used to define the path to locate the storage.json in FileLocator. This path is provided by storageDescriptionPath() method of this class.
//get data-access
auto dataAccess = site->FirstChildElement("data-access");
if (subSite)
dataAccess = subSite->FirstChildElement("data-access");
if (dataAccess) {
//get catalogs
auto catalog = dataAccess->FirstChildElement("catalog");
Expand All @@ -432,8 +445,6 @@ namespace edm {

// Parsing of the calib-data section
auto calibData = site->FirstChildElement("calib-data");
if (subSite)
calibData = subSite->FirstChildElement("calib-data");

if (calibData) {
auto frontierConnect = calibData->FirstChildElement("frontier-connect");
Expand All @@ -458,8 +469,6 @@ namespace edm {

// Parsing of the source config section
auto sourceConfig = site->FirstChildElement("source-config");
if (subSite)
sourceConfig = subSite->FirstChildElement("source-config");

if (sourceConfig) {
auto cacheTempDir = sourceConfig->FirstChildElement("cache-temp-dir");
Expand Down
3 changes: 1 addition & 2 deletions FWCore/Services/test/full-site-local-config.testfile
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<site-local-config>
<site name="DUMMY">
<subsite name="DUMMY_SUB_SITE">
<subsite name="DUMMY_SUB_SITE"/>
<event-data>
<catalog url="trivialcatalog_file:/dummy/storage.xml?protocol=dcap"/>
</event-data>
Expand Down Expand Up @@ -30,6 +30,5 @@
<statistics-destination name="cms-udpmon-collector.cern.ch:9331" info ="dn"/>
<timeout-in-seconds value="7200" />
</source-config>
</subsite>
</site>
</site-local-config>
3 changes: 1 addition & 2 deletions FWCore/Services/test/no-source-site-local-config.testfile
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<site-local-config>
<site name="DUMMY">
<subsite name="DUMMY_SUB_SITE">
<subsite name="DUMMY_SUB_SITE"/>
<event-data>
<catalog url="trivialcatalog_file:/dummy/storage.xml?protocol=dcap"/>
</event-data>
Expand All @@ -18,6 +18,5 @@
<proxy url="http://cmsfrontier.dummy.foo:3128"/>
</frontier-connect>
</calib-data>
</subsite>
</site>
</site-local-config>
3 changes: 1 addition & 2 deletions FWCore/Services/test/source-site-local-config.testfile
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<site-local-config>
<site name="DUMMY">
<subsite name="DUMMY_SUB_SITE">
<subsite name="DUMMY_SUB_SITE"/>
<event-data>
<catalog url="trivialcatalog_file:/dummy/storage.xml?protocol=dcap"/>
</event-data>
Expand All @@ -27,6 +27,5 @@
<protocol prefix="file"/>
</native-protocols>
</source-config>
</subsite>
</site>
</site-local-config>

0 comments on commit b95045c

Please sign in to comment.