diff --git a/Database/AthenaPOOL/EventSelectorAthenaPool/CMakeLists.txt b/Database/AthenaPOOL/EventSelectorAthenaPool/CMakeLists.txt index a929c62272a130aa2e1453b4496098238ee1bd15..5d9257e6ba333731796b3039042c1d9cb026f21a 100644 --- a/Database/AthenaPOOL/EventSelectorAthenaPool/CMakeLists.txt +++ b/Database/AthenaPOOL/EventSelectorAthenaPool/CMakeLists.txt @@ -39,3 +39,8 @@ atlas_add_component( EventSelectorAthenaPool atlas_install_python_modules( python/*.py ) atlas_install_joboptions( share/*.py ) + +atlas_add_test( CondProxyProviderConfig_test + SCRIPT python -m EventSelectorAthenaPool.CondProxyProviderConfig + LOG_SELECT_PATTERN "ComponentAccumulator|^---|^CondProxyProvider" ) + diff --git a/Database/AthenaPOOL/EventSelectorAthenaPool/python/CondProxyProviderConfig.py b/Database/AthenaPOOL/EventSelectorAthenaPool/python/CondProxyProviderConfig.py new file mode 100644 index 0000000000000000000000000000000000000000..02ecf31fe608ff70409bf3c17dee80b2bf74d82f --- /dev/null +++ b/Database/AthenaPOOL/EventSelectorAthenaPool/python/CondProxyProviderConfig.py @@ -0,0 +1,44 @@ +# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration + +# File: EventSelectorAthenaPool/python/CondProxyProviderConfig.py +# Created: Jun 2020, sss +# Purpose: Configure CondProxyProvider. + +from __future__ import print_function + +from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator +from AthenaConfiguration.ComponentFactory import CompFactory + + +def CondProxyProviderCfg (flags, poolFiles): + if not isinstance (poolFiles, list): + poolFiles = [poolFiles] + + result = ComponentAccumulator() + + ProxyProviderSvc = CompFactory.ProxyProviderSvc # SGComps + pps = ProxyProviderSvc (ProviderNames = ['CondProxyProvider']) + result.addService (pps) + + CondProxyProvider = CompFactory.CondProxyProvider # EventSelectorAthenaPool + cpp = CondProxyProvider (InputCollections = poolFiles) + result.addService (cpp) + + return result + + +if __name__ == "__main__": + from AthenaCommon.Configurable import Configurable + Configurable.configurableRun3Behavior=1 + from AthenaConfiguration.AllConfigFlags import ConfigFlags + ConfigFlags.loadAllDynamicFlags() + + flags1 = ConfigFlags.clone() + flags1.lock() + acc1 = ComponentAccumulator() + acc1.merge (CondProxyProviderCfg (flags1, 'file1')) + acc1.merge (CondProxyProviderCfg (flags1, ['file2', 'file3'])) + acc1.printConfig (summariseProps=True) + print ('CondProxyProvider:', acc1.getService('CondProxyProvider')) + acc1.wasMerged() + diff --git a/Database/AthenaPOOL/EventSelectorAthenaPool/share/CondProxyProviderConfig_test.ref b/Database/AthenaPOOL/EventSelectorAthenaPool/share/CondProxyProviderConfig_test.ref new file mode 100644 index 0000000000000000000000000000000000000000..494822f7cad636702a71366ad6d9e155fb9ff209 --- /dev/null +++ b/Database/AthenaPOOL/EventSelectorAthenaPool/share/CondProxyProviderConfig_test.ref @@ -0,0 +1,16 @@ +Py:Athena INFO using release [WorkDir-22.0.15] [x86_64-centos7-gcc8-opt] [config.EventSelectorAthenaPool-20200617/24fa4eb1a41] -- built on [2020-06-17T2014] +Py:ComponentAccumulator INFO Event Inputs +Py:ComponentAccumulator INFO Event Algorithm Sequences +Py:ComponentAccumulator INFO Top sequence 0 +Py:ComponentAccumulator INFO \__ AthAlgSeq (seq: SEQ AND) +Py:ComponentAccumulator INFO Condition Algorithms +Py:ComponentAccumulator INFO Services +Py:ComponentAccumulator INFO ['ProxyProviderSvc', 'CondProxyProvider'] +Py:ComponentAccumulator INFO Public Tools +Py:ComponentAccumulator INFO [ +Py:ComponentAccumulator INFO ] +Py:ComponentAccumulator INFO Private Tools +Py:ComponentAccumulator INFO [ +Py:ComponentAccumulator INFO ] +Py:ComponentAccumulator INFO TheApp properties +CondProxyProvider: CondProxyProvider('CondProxyProvider', InputCollections=['file1', 'file2', 'file3']) diff --git a/Database/AthenaPOOL/EventSelectorAthenaPool/src/CondProxyProvider.cxx b/Database/AthenaPOOL/EventSelectorAthenaPool/src/CondProxyProvider.cxx index 9e3b2859b48bf9669ec3ecd0d3cd0bab24b5625b..7d761658725d488bf3379c92b3c8f15894df92f1 100755 --- a/Database/AthenaPOOL/EventSelectorAthenaPool/src/CondProxyProvider.cxx +++ b/Database/AthenaPOOL/EventSelectorAthenaPool/src/CondProxyProvider.cxx @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration */ /** @file CondProxyProvider.cxx @@ -33,7 +33,6 @@ CondProxyProvider::CondProxyProvider(const std::string& name, ISvcLocator* pSvcL m_athenaPoolCnvSvc("AthenaPoolCnvSvc", name), m_poolCollectionConverter(0), m_headerIterator(0) { - declareProperty("InputCollections", m_inputCollectionsProp); } //________________________________________________________________________________ CondProxyProvider::~CondProxyProvider() { diff --git a/Database/AthenaPOOL/EventSelectorAthenaPool/src/CondProxyProvider.h b/Database/AthenaPOOL/EventSelectorAthenaPool/src/CondProxyProvider.h index 761bee1d20cf13d80e5e05a9061d32598b266e1b..6f8d5c0726fa1ac6ad29f18a2776f94be3ba9248 100755 --- a/Database/AthenaPOOL/EventSelectorAthenaPool/src/CondProxyProvider.h +++ b/Database/AthenaPOOL/EventSelectorAthenaPool/src/CondProxyProvider.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration */ #ifndef CONDPROXYPROVIDER_H @@ -63,7 +63,8 @@ private: // data private: // properties /// InputCollections, vector with names of the input collections. - StringArrayProperty m_inputCollectionsProp; + StringArrayProperty m_inputCollectionsProp + { this, "InputCollections", {}, "Files to read", "OrderedSet<std::string>" }; mutable std::vector<std::string>::const_iterator m_inputCollectionsIterator; private: // internal helper functions