reqmgr2ms-output 2.2.0rc4__tar.gz → 2.2.0rc5__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (254) hide show
  1. {reqmgr2ms-output-2.2.0rc4/src/python/reqmgr2ms_output.egg-info → reqmgr2ms-output-2.2.0rc5}/PKG-INFO +1 -1
  2. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/DBS/DBS3Reader.py +70 -55
  3. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/__init__.py +1 -1
  4. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5/src/python/reqmgr2ms_output.egg-info}/PKG-INFO +1 -1
  5. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/LICENSE +0 -0
  6. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/MANIFEST.in +0 -0
  7. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/NOTICE +0 -0
  8. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/README.md +0 -0
  9. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/HWMon/wmcore-SysStat +0 -0
  10. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/acdcserver-tools +0 -0
  11. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/ParseSpecCmsswdist.py +0 -0
  12. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/checkDsetFileCount.py +0 -0
  13. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/checkStuckLQE.py +0 -0
  14. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/drainAgent.py +0 -0
  15. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/getWQStatusByWorkflow.py +0 -0
  16. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/mongoInit.py +0 -0
  17. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/parseUnifiedCampaigns.py +0 -0
  18. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/setrequeststatus.py +0 -0
  19. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/summaryWMStatsFailures.py +0 -0
  20. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/updateTotalStats.py +0 -0
  21. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/adhoc-scripts/workflowCompletion.py +0 -0
  22. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/attempt-to-patch.sh +0 -0
  23. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/buildrelease.sh +0 -0
  24. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/check-ACDC-parentage +0 -0
  25. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/check-phedex-dbs-status +0 -0
  26. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/check-request-wq-status +0 -0
  27. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/clean-oracle +0 -0
  28. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/combineMinifyWMStats.py +0 -0
  29. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/couch-thrash.py +0 -0
  30. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/couch_archiver.py +0 -0
  31. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/create-iam-token.sh +0 -0
  32. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/createStoreResults.py +0 -0
  33. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/dbsbuffer-file-fix.py +0 -0
  34. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/deploy-rpm-to-jenkins.sh +0 -0
  35. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/fix-dbs-parentage +0 -0
  36. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/inject-to-config-cache +0 -0
  37. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/kill-workflow-in-agent +0 -0
  38. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/kill-workflow-in-global +0 -0
  39. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/make-local-clones.sh +0 -0
  40. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/outputmodules-from-config +0 -0
  41. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/patchComponent.sh +0 -0
  42. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/paused-jobs +0 -0
  43. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/purgeDeletedCouchDoc.py +0 -0
  44. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/reqmgr-put-default-config +0 -0
  45. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/reqmgr-sw-update +0 -0
  46. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/vaildateCMSSWMergeVersion +0 -0
  47. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmagent-couchapp-init +0 -0
  48. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmagent-delete-couchdb-workflow +0 -0
  49. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmagent-mod-config +0 -0
  50. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmagent-resource-control +0 -0
  51. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmagent-unregister-wmstats +0 -0
  52. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmagent-upload-config +0 -0
  53. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmagent-workqueue +0 -0
  54. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmc-dist-patch +0 -0
  55. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmc-dist-unpatch +0 -0
  56. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmc-httpd +0 -0
  57. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmcore-db-init +0 -0
  58. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmcore-new-config +0 -0
  59. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmcore-new-flow +0 -0
  60. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/bin/wmcoreD +0 -0
  61. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/requirements.txt +0 -0
  62. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/setup.cfg +0 -0
  63. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/setup.py +0 -0
  64. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/setup_build.py +0 -0
  65. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/setup_dependencies.py +0 -0
  66. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/CPMetrics.py +0 -0
  67. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/CertTools.py +0 -0
  68. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/EmailAlert.py +0 -0
  69. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/ExtendedUnitTestCase.py +0 -0
  70. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/FileTools.py +0 -0
  71. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/IteratorTools.py +0 -0
  72. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/MathUtils.py +0 -0
  73. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/MemoryCache.py +0 -0
  74. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/Patterns.py +0 -0
  75. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/Pipeline.py +0 -0
  76. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/PortForward.py +0 -0
  77. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/ProcessStats.py +0 -0
  78. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/PythonVersion.py +0 -0
  79. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/Signals.py +0 -0
  80. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/TemporaryEnvironment.py +0 -0
  81. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/Throttled.py +0 -0
  82. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/Timers.py +0 -0
  83. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/TokenManager.py +0 -0
  84. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/Tracing.py +0 -0
  85. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/TwPrint.py +0 -0
  86. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/Utilities.py +0 -0
  87. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/Utils/__init__.py +0 -0
  88. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Algorithms/Alarm.py +0 -0
  89. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Algorithms/MathAlgos.py +0 -0
  90. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Algorithms/MiscAlgos.py +0 -0
  91. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Algorithms/ParseXMLFile.py +0 -0
  92. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Algorithms/Permissions.py +0 -0
  93. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Algorithms/Singleton.py +0 -0
  94. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Algorithms/SubprocessAlgos.py +0 -0
  95. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Algorithms/__init__.py +0 -0
  96. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Cache/GenericDataCache.py +0 -0
  97. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Cache/WMConfigCache.py +0 -0
  98. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Cache/__init__.py +0 -0
  99. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Configuration.py +0 -0
  100. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DAOFactory.py +0 -0
  101. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/File.py +0 -0
  102. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/Fileset.py +0 -0
  103. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/Job.py +0 -0
  104. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/JobGroup.py +0 -0
  105. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/JobPackage.py +0 -0
  106. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/LumiList.py +0 -0
  107. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/Mask.py +0 -0
  108. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/Pickleable.py +0 -0
  109. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/Run.py +0 -0
  110. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/Subscription.py +0 -0
  111. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/WMObject.py +0 -0
  112. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/WorkUnit.py +0 -0
  113. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/Workflow.py +0 -0
  114. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/DataStructs/__init__.py +0 -0
  115. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/CMSCouch.py +0 -0
  116. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/ConfigDBMap.py +0 -0
  117. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/CouchUtils.py +0 -0
  118. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/DBCore.py +0 -0
  119. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/DBCreator.py +0 -0
  120. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/DBExceptionHandler.py +0 -0
  121. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/DBFactory.py +0 -0
  122. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/DBFormatter.py +0 -0
  123. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/Dialects.py +0 -0
  124. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/ExecuteDAO.py +0 -0
  125. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/MongoDB.py +0 -0
  126. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/MySQLCore.py +0 -0
  127. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/ResultSet.py +0 -0
  128. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/Transaction.py +0 -0
  129. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/__init__.py +0 -0
  130. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Database/ipy_profile_couch.py +0 -0
  131. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/GroupUser/CouchObject.py +0 -0
  132. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/GroupUser/Decorators.py +0 -0
  133. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/GroupUser/Group.py +0 -0
  134. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/GroupUser/Interface.py +0 -0
  135. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/GroupUser/User.py +0 -0
  136. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/GroupUser/__init__.py +0 -0
  137. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Lexicon.py +0 -0
  138. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/CherryPyThreads/HeartbeatMonitor.py +0 -0
  139. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/CherryPyThreads/__init__.py +0 -0
  140. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/DataStructs/DefaultStructs.py +0 -0
  141. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/DataStructs/__init__.py +0 -0
  142. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSCore/MSAuth.py +0 -0
  143. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSCore/MSCore.py +0 -0
  144. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSCore/MSManager.py +0 -0
  145. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSCore/TaskManager.py +0 -0
  146. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSCore/__init__.py +0 -0
  147. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSOutput/MSOutput.py +0 -0
  148. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSOutput/MSOutputStreamer.py +0 -0
  149. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSOutput/MSOutputTemplate.py +0 -0
  150. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSOutput/RelValPolicy.py +0 -0
  151. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/MSOutput/__init__.py +0 -0
  152. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/Service/Data.py +0 -0
  153. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/Service/RestApiHub.py +0 -0
  154. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/Service/__init__.py +0 -0
  155. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/Tools/Common.py +0 -0
  156. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/Tools/PycurlRucio.py +0 -0
  157. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/Tools/__init__.py +0 -0
  158. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/WebGui/FrontPage.py +0 -0
  159. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/MicroService/WebGui/__init__.py +0 -0
  160. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Auth.py +0 -0
  161. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/CherryPyPeriodicTask.py +0 -0
  162. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Error.py +0 -0
  163. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Format.py +0 -0
  164. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/HeartbeatMonitorBase.py +0 -0
  165. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Main.py +0 -0
  166. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Server.py +0 -0
  167. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Services.py +0 -0
  168. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Test.py +0 -0
  169. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Tools.py +0 -0
  170. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/Validation.py +0 -0
  171. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/REST/__init__.py +0 -0
  172. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/ReqMgr/DataStructs/RequestStatus.py +0 -0
  173. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/ReqMgr/DataStructs/RequestType.py +0 -0
  174. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/ReqMgr/DataStructs/__init__.py +0 -0
  175. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/ReqMgr/__init__.py +0 -0
  176. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/AlertManager/AlertManagerAPI.py +0 -0
  177. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/AlertManager/__init__.py +0 -0
  178. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/CRIC/CRIC.py +0 -0
  179. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/CRIC/__init__.py +0 -0
  180. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/DBS/DBSErrors.py +0 -0
  181. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/DBS/DBSReader.py +0 -0
  182. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/DBS/DBSUtils.py +0 -0
  183. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/DBS/DBSWriterObjects.py +0 -0
  184. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/DBS/ProdException.py +0 -0
  185. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/DBS/__init__.py +0 -0
  186. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/FWJRDB/FWJRDBAPI.py +0 -0
  187. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/FWJRDB/__init__.py +0 -0
  188. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/HTTPS/HTTPSAuthHandler.py +0 -0
  189. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/HTTPS/__init__.py +0 -0
  190. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/LogDB/LogDB.py +0 -0
  191. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/LogDB/LogDBBackend.py +0 -0
  192. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/LogDB/LogDBExceptions.py +0 -0
  193. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/LogDB/LogDBReport.py +0 -0
  194. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/LogDB/__init__.py +0 -0
  195. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/McM/McM.py +0 -0
  196. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/McM/__init__.py +0 -0
  197. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/MonIT/Grafana.py +0 -0
  198. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/MonIT/__init__.py +0 -0
  199. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/PyCondor/PyCondorAPI.py +0 -0
  200. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/PyCondor/PyCondorUtils.py +0 -0
  201. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/PyCondor/__init__.py +0 -0
  202. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/ReqMgr/ReqMgr.py +0 -0
  203. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/ReqMgr/__init__.py +0 -0
  204. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/ReqMgrAux/ReqMgrAux.py +0 -0
  205. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/ReqMgrAux/__init__.py +0 -0
  206. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/RequestDB/RequestDBReader.py +0 -0
  207. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/RequestDB/RequestDBWriter.py +0 -0
  208. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/RequestDB/__init__.py +0 -0
  209. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/Requests.py +0 -0
  210. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/Rucio/Rucio.py +0 -0
  211. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/Rucio/RucioUtils.py +0 -0
  212. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/Rucio/__init__.py +0 -0
  213. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/RucioConMon/RucioConMon.py +0 -0
  214. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/RucioConMon/__init__.py +0 -0
  215. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/Service.py +0 -0
  216. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/StompAMQ/__init__.py +0 -0
  217. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/TagCollector/TagCollector.py +0 -0
  218. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/TagCollector/XMLUtils.py +0 -0
  219. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/TagCollector/__init__.py +0 -0
  220. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/UUIDLib.py +0 -0
  221. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/UserFileCache/UserFileCache.py +0 -0
  222. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/UserFileCache/__init__.py +0 -0
  223. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMAgent/WMAgent.py +0 -0
  224. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMAgent/__init__.py +0 -0
  225. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMArchive/DataMap.py +0 -0
  226. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMArchive/WMArchive.py +0 -0
  227. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMArchive/__init__.py +0 -0
  228. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMBS/WMBS.py +0 -0
  229. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMBS/__init__.py +0 -0
  230. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMStats/DataStruct/RequestInfoCollection.py +0 -0
  231. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMStats/DataStruct/__init__.py +0 -0
  232. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMStats/WMStatsReader.py +0 -0
  233. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMStats/WMStatsWriter.py +0 -0
  234. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMStats/__init__.py +0 -0
  235. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMStatsServer/WMStatsServer.py +0 -0
  236. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WMStatsServer/__init__.py +0 -0
  237. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WorkQueue/WorkQueue.py +0 -0
  238. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/WorkQueue/__init__.py +0 -0
  239. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/__init__.py +0 -0
  240. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Services/pycurl_manager.py +0 -0
  241. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/WMBase.py +0 -0
  242. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/WMConnectionBase.py +0 -0
  243. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/WMException.py +0 -0
  244. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/WMExceptions.py +0 -0
  245. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/WMFactory.py +0 -0
  246. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/WMInit.py +0 -0
  247. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/WMLogging.py +0 -0
  248. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Wrappers/JsonWrapper/JSONThunker.py +0 -0
  249. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Wrappers/JsonWrapper/__init__.py +0 -0
  250. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/WMCore/Wrappers/__init__.py +0 -0
  251. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/reqmgr2ms_output.egg-info/SOURCES.txt +0 -0
  252. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/reqmgr2ms_output.egg-info/dependency_links.txt +0 -0
  253. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/reqmgr2ms_output.egg-info/requires.txt +0 -0
  254. {reqmgr2ms-output-2.2.0rc4 → reqmgr2ms-output-2.2.0rc5}/src/python/reqmgr2ms_output.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 1.2
2
2
  Name: reqmgr2ms-output
3
- Version: 2.2.0rc4
3
+ Version: 2.2.0rc5
4
4
  Summary: UNKNOWN
5
5
  Home-page: https://github.com/dmwm/WMCore
6
6
  Maintainer: CMS DMWM Group
@@ -857,41 +857,6 @@ class DBS3Reader(object):
857
857
  """
858
858
  return self.dbs.insertFileParents({"block_name": childBlockName, "child_parent_id_list": childParentsIDPairs})
859
859
 
860
- def findAndInsertMissingParentage(self, childBlockName, parentData, insertFlag=True):
861
- """
862
- :param childBlockName: child block name
863
- :param parentData: a dictionary with complete parent dataset file/run/lumi information
864
- :param insertFlag: boolean to allow parentage insertion into DBS or not
865
- :return: number of file parents pair inserted
866
- """
867
- # in the format of: {'fileid': [[run_num1, lumi1], [run_num1, lumi2], etc]
868
- # e.g. {'554307997': [[1, 557179], [1, 557178], [1, 557181],
869
- childBlockData = self.dbs.listBlockTrio(block_name=childBlockName)
870
-
871
- # runs the actual mapping logic, like {"child_id": ["parent_id", "parent_id2", ...], etc
872
- mapChildParent = {}
873
- # there should be only 1 item, but we better be safe
874
- for item in childBlockData:
875
- for childFileID in item:
876
- for runLumiPair in item[childFileID]:
877
- frozenKey = frozenset(runLumiPair)
878
- parentId = parentData.get(frozenKey)
879
- if parentId is None:
880
- msg = "Child file id: %s, with run/lumi: %s, has no match in the parent dataset"
881
- self.logger.warning(msg, childFileID, frozenKey)
882
- continue
883
- mapChildParent.setdefault(childFileID, set())
884
- mapChildParent[childFileID].add(parentId)
885
-
886
- if insertFlag and mapChildParent:
887
- # convert dictionary to list of unique childID, parentID tuples
888
- listChildParent = []
889
- for childID in mapChildParent:
890
- for parentID in mapChildParent[childID]:
891
- listChildParent.append([int(childID), int(parentID)])
892
- self.dbs.insertFileParents({"block_name": childBlockName, "child_parent_id_list": listChildParent})
893
- return len(mapChildParent)
894
-
895
860
  def listBlocksWithNoParents(self, childDataset):
896
861
  """
897
862
  :param childDataset: child dataset for
@@ -934,27 +899,51 @@ class DBS3Reader(object):
934
899
  :param childDataset: child dataset need to set the parentage correctly.
935
900
  :return: blocks which failed to insert parentage. for retry
936
901
  """
937
- pDatasets = self.listDatasetParents(childDataset)
938
- self.logger.info("Parent datasets for %s are: %s", childDataset, pDatasets)
939
- # print("parent datasets %s\n" % pDatasets)
940
- # pDatasets format is
941
- # [{'this_dataset': '/SingleMuon/Run2016D-03Feb2017-v1/MINIAOD', 'parent_dataset_id': 13265209, 'parent_dataset': '/SingleMuon/Run2016D-23Sep2016-v1/AOD'}]
942
- if not pDatasets:
902
+ parentDatasets = self.listDatasetParents(childDataset)
903
+ self.logger.info("Parent datasets for %s are: %s", childDataset, parentDatasets)
904
+ # parentDatasets format is
905
+ # [{'this_dataset': '/SingleMuon/Run2016D-03Feb2017-v1/MINIAOD',
906
+ # 'parent_dataset_id': 13265209,
907
+ # 'parent_dataset': '/SingleMuon/Run2016D-23Sep2016-v1/AOD'}]
908
+ if not parentDatasets:
943
909
  self.logger.warning("No parent dataset found for child dataset %s", childDataset)
944
910
  return {}
945
911
 
946
- parentFullInfo = self.getParentDatasetTrio(childDataset)
912
+ parentFlatData = self.getParentDatasetTrio(childDataset)
913
+
947
914
  blocks = self.listBlocksWithNoParents(childDataset)
948
915
  failedBlocks = []
949
916
  self.logger.info("Found %d blocks without parentage information", len(blocks))
950
917
  for blockName in blocks:
951
918
  try:
952
919
  self.logger.info("Fixing parentage for block: %s", blockName)
953
- numFiles = self.findAndInsertMissingParentage(blockName, parentFullInfo, insertFlag=insertFlag)
954
- self.logger.debug("%s file parentage added for block %s", numFiles, blockName)
920
+ childFlatData = self.getChildBlockTrio(blockName)
921
+ listChildParent = []
922
+
923
+ # first resolve parentage for all common runLumi pairs between childBlock and parentDataset
924
+ for runLumi in childFlatData.keys() & parentFlatData.keys():
925
+ childFileId = childFlatData[runLumi]
926
+ parentFileId = parentFlatData[runLumi]
927
+ listChildParent.append([childFileId, parentFileId])
928
+
929
+ # then add all run lumi pairs which are missing at the parent Dataset by appending None as parentage information
930
+ for runLumi in childFlatData.keys() - parentFlatData.keys():
931
+ childFileId = childFlatData[runLumi]
932
+ parentFileId = None
933
+ listChildParent.append([childFileId, parentFileId])
934
+ msg = "Child file id: %s, with run/lumi: %s, has no match in the parent dataset. "
935
+ msg += "Adding it with null parentage information to DBS."
936
+ self.logger.warning(msg, childFileId, runLumi)
937
+
938
+ # insert block parentage information to DBS
939
+ if insertFlag and any(listChildParent):
940
+ self.insertFileParents(blockName, listChildParent)
941
+ self.logger.info("Parentage information successfuly added to DBS for block %s", blockName)
942
+ else:
943
+ self.logger.warning("No parentage information added to DBS for block %s", blockName)
955
944
  except Exception as ex:
956
945
  self.logger.exception(
957
- "Parentage updated failed for block %s with error %s", blockName, str(ex))
946
+ "Parentage update failed for block %s with error %s", blockName, str(ex))
958
947
  failedBlocks.append(blockName)
959
948
 
960
949
  return failedBlocks
@@ -965,18 +954,44 @@ class DBS3Reader(object):
965
954
  - file ids, run number and lumi section
966
955
  NOTE: This API is meant to be used by the StepChainParentage thread only!!!
967
956
  :param childDataset: name of the child dataset
968
- :return: a dictionary where the key is a set of run/lumi, its value is the fileid
957
+ :return: A dictionary using (run, lumi) tuples as keys and fileIds as values
958
+ {(1, 5110): 2746490237,
959
+ (1, 5959): 2746487877,
960
+ (1, 5990): 2746487877,
961
+ ...}
969
962
  """
970
- # this will return data in the format of:
963
+ # the call to DBS from bellow will return data in the following format of:
971
964
  # {554307997: [[1, 557179], [1, 557178],...
972
965
  # such that: key is file id, in each list is [run_number, lumi_section_numer].
973
966
  parentFullInfo = self.dbs.listParentDSTrio(dataset=childDataset)
974
967
 
975
- # runs the actual mapping logic, like {"child_id": ["parent_id", "parent_id2", ...], etc
976
- parentFrozenData = {}
977
- for item in parentFullInfo:
978
- for fileId in item:
979
- for runLumiPair in item[fileId]:
980
- frozenKey = frozenset(runLumiPair)
981
- parentFrozenData[frozenKey] = fileId
982
- return parentFrozenData
968
+ parentFlatData = {}
969
+ for parentDataset in parentFullInfo:
970
+ for fileId in parentDataset:
971
+ for runLumiPair in parentDataset[fileId]:
972
+ parentFlatData[tuple(runLumiPair)] = fileId
973
+ return parentFlatData
974
+
975
+ def getChildBlockTrio(self, childBlock):
976
+ """
977
+ Provided a block name, return all block contents information, such as:
978
+ - file ids, run number and lumi section
979
+ NOTE: This API is meant to be used by the StepChainParentage thread only!!!
980
+ :param chilBlock: name of the child block
981
+ :return: A dictionary using (run, lumi) tuples as keys and fileIds as values
982
+ {(1, 5110): 2746490237,
983
+ (1, 5959): 2746487877,
984
+ (1, 5990): 2746487877,
985
+ ...}
986
+ """
987
+ # the call to DBS from bellow will return data in the following format of:
988
+ # {554307997: [[1, 557179], [1, 557178],...
989
+ # such that: key is file id, in each list is [run_number, lumi_section_numer].
990
+ childBlockInfo = self.dbs.listBlockTrio(block_name=childBlock)
991
+
992
+ childFlatData = {}
993
+ for childBlock in childBlockInfo:
994
+ for fileId in childBlock:
995
+ for runLumiPair in childBlock[fileId]:
996
+ childFlatData[tuple(runLumiPair)] = fileId
997
+ return childFlatData
@@ -6,5 +6,5 @@ Core libraries for Workload Management Packages
6
6
 
7
7
  """
8
8
 
9
- __version__ = '2.2.0rc4'
9
+ __version__ = '2.2.0rc5'
10
10
  __all__ = []
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 1.2
2
2
  Name: reqmgr2ms-output
3
- Version: 2.2.0rc4
3
+ Version: 2.2.0rc5
4
4
  Summary: UNKNOWN
5
5
  Home-page: https://github.com/dmwm/WMCore
6
6
  Maintainer: CMS DMWM Group