ATLAS Offline Software
Public Member Functions | Public Attributes | Private Member Functions | Private Attributes | List of all members
python.trfExe.scriptExecutor Class Reference
Inheritance diagram for python.trfExe.scriptExecutor:
Collaboration diagram for python.trfExe.scriptExecutor:

Public Member Functions

def __init__ (self, name='Script', trf=None, conf=None, inData=set(), outData=set(), exe=None, exeArgs=None, memMonitor=True)
 
def exe (self)
 
def exe (self, value)
 
def exeArgs (self)
 
def exeArgs (self, value)
 
def preExecute (self, input=set(), output=set())
 
def execute (self)
 
def postExecute (self)
 
def validate (self)
 
def inData (self)
 
def inData (self, value)
 
def outData (self)
 
def outData (self, value)
 
def myMerger (self)
 Now define properties for these data members. More...
 
def name (self)
 
def name (self, value)
 
def substep (self)
 
def trf (self)
 
def trf (self, value)
 
def inDataUpdate (self, value)
 
def outDataUpdate (self, value)
 
def input (self)
 
def output (self)
 
def extraMetadata (self)
 
def hasExecuted (self)
 
def rc (self)
 
def errMsg (self)
 
def validation (self)
 
def validation (self, value)
 
def hasValidated (self)
 
def isValidated (self)
 
def first (self)
 
def preExeStartTimes (self)
 
def exeStartTimes (self)
 
def exeStopTimes (self)
 
def valStartTimes (self)
 
def valStopTimes (self)
 
def preExeCpuTime (self)
 
def preExeWallTime (self)
 
def cpuTime (self)
 
def usrTime (self)
 
def sysTime (self)
 
def wallTime (self)
 
def memStats (self)
 
def memAnalysis (self)
 
def postExeCpuTime (self)
 
def postExeWallTime (self)
 
def validationCpuTime (self)
 
def validationWallTime (self)
 
def cpuTimeTotal (self)
 
def wallTimeTotal (self)
 
def eventCount (self)
 
def reSimEvent (self)
 
def athenaMP (self)
 
def dbMonitor (self)
 
def setPreExeStart (self)
 
def setValStart (self)
 
def doAll (self, input=set(), output=set())
 Convenience function. More...
 

Public Attributes

 conf
 Executor configuration: More...
 
 inData
 
 outData
 

Private Member Functions

def _buildStandardCommand (self)
 

Private Attributes

 _exe
 
 _exeArgs
 
 _echoOutput
 
 _cmd
 
 _memMonitor
 
 _input
 
 _output
 
 _logFileName
 
 _echologger
 
 _exeLogFile
 
 _echostream
 
 _hasExecuted
 
 _exeStart
 
 _memSummaryFile
 
 _memFullFile
 
 _rc
 Check rc. More...
 
 _exeStop
 
 _memStats
 
 _valStart
 
 _hasValidated
 
 _isValidated
 
 _errMsg
 
 _eventCount
 Check event counts (always do this by default) Do this here so that all script executors have this by default (covers most use cases with events) More...
 
 _valStop
 
 _name
 
 _inData
 
 _outData
 
 _extraMetadata
 
 _preExeStart
 
 _memLeakResult
 
 _athenaMP
 
 _athenaMT
 
 _athenaConcurrentEvents
 
 _dbMonitor
 
 _resimevents
 
 _alreadyInContainer
 
 _containerSetup
 
 _myMerger
 
 _trf
 
 _validation
 

Detailed Description

Definition at line 618 of file trfExe.py.

Constructor & Destructor Documentation

◆ __init__()

def python.trfExe.scriptExecutor.__init__ (   self,
  name = 'Script',
  trf = None,
  conf = None,
  inData = set(),
  outData = set(),
  exe = None,
  exeArgs = None,
  memMonitor = True 
)

Reimplemented in python.trfExe.DQMPostProcessExecutor, and python.trfExe.DQMergeExecutor.

Definition at line 619 of file trfExe.py.

619  def __init__(self, name = 'Script', trf = None, conf = None, inData = set(), outData = set(),
620  exe = None, exeArgs = None, memMonitor = True):
621  # Name of the script we want to execute
622  self._exe = exe
623 
624  # With arguments (currently this means paste in the corresponding _argdict entry)
625  self._exeArgs = exeArgs
626 
627  super(scriptExecutor, self).__init__(name=name, trf=trf, conf=conf, inData=inData, outData=outData)
628 
629  self._extraMetadata.update({'script' : exe})
630 
631  # Decide if we echo script output to stdout
632  self._echoOutput = False
633 
634  # Can either be written by base class or child
635  self._cmd = None
636 
637  self._memMonitor = memMonitor
638 

Member Function Documentation

◆ _buildStandardCommand()

def python.trfExe.scriptExecutor._buildStandardCommand (   self)
private

Definition at line 705 of file trfExe.py.

705  def _buildStandardCommand(self):
706  if self._exe:
707  self._cmd = [self.exe, ]
708  else:
709  raise trfExceptions.TransformExecutionException(trfExit.nameToCode('TRF_EXEC_SETUP_FAIL'),
710  'No executor set in {0}'.format(self.__class__.__name__))
711  for arg in self.exeArgs:
712  if arg in self.conf.argdict:
713  # If we have a list then add each element to our list, else just str() the argument value
714  # Note if there are arguments which need more complex transformations then
715  # consider introducing a special toExeArg() method.
716  if isinstance(self.conf.argdict[arg].value, list):
717  self._cmd.extend([ str(v) for v in self.conf.argdict[arg].value])
718  else:
719  self._cmd.append(str(self.conf.argdict[arg].value))
720 
721 

◆ athenaMP()

def python.trfExe.transformExecutor.athenaMP (   self)
inherited

Definition at line 451 of file trfExe.py.

451  def athenaMP(self):
452  return self._athenaMP
453 

◆ cpuTime()

def python.trfExe.transformExecutor.cpuTime (   self)
inherited

Definition at line 365 of file trfExe.py.

365  def cpuTime(self):
366  if self._exeStart and self._exeStop:
367  return calcCpuTime(self._exeStart, self._exeStop)
368  else:
369  return None
370 

◆ cpuTimeTotal()

def python.trfExe.transformExecutor.cpuTimeTotal (   self)
inherited

Definition at line 429 of file trfExe.py.

429  def cpuTimeTotal(self):
430  if self._preExeStart and self._valStop:
431  return calcCpuTime(self._preExeStart, self._valStop)
432  else:
433  return None
434 

◆ dbMonitor()

def python.trfExe.transformExecutor.dbMonitor (   self)
inherited

Definition at line 455 of file trfExe.py.

455  def dbMonitor(self):
456  return self._dbMonitor
457 
458 

◆ doAll()

def python.trfExe.transformExecutor.doAll (   self,
  input = set(),
  output = set() 
)
inherited

Convenience function.

Definition at line 498 of file trfExe.py.

498  def doAll(self, input=set(), output=set()):
499  self.preExecute(input, output)
500  self.execute()
501  self.postExecute()
502  self.validate()
503 

◆ errMsg()

def python.trfExe.transformExecutor.errMsg (   self)
inherited

Definition at line 303 of file trfExe.py.

303  def errMsg(self):
304  return self._errMsg
305 

◆ eventCount()

def python.trfExe.transformExecutor.eventCount (   self)
inherited

Definition at line 443 of file trfExe.py.

443  def eventCount(self):
444  return self._eventCount
445 

◆ exe() [1/2]

def python.trfExe.scriptExecutor.exe (   self)

Definition at line 640 of file trfExe.py.

640  def exe(self):
641  return self._exe
642 

◆ exe() [2/2]

def python.trfExe.scriptExecutor.exe (   self,
  value 
)

Definition at line 644 of file trfExe.py.

644  def exe(self, value):
645  self._exe = value
646  self._extraMetadata['script'] = value
647 

◆ exeArgs() [1/2]

def python.trfExe.scriptExecutor.exeArgs (   self)

Definition at line 649 of file trfExe.py.

649  def exeArgs(self):
650  return self._exeArgs
651 

◆ exeArgs() [2/2]

def python.trfExe.scriptExecutor.exeArgs (   self,
  value 
)

Definition at line 653 of file trfExe.py.

653  def exeArgs(self, value):
654  self._exeArgs = value
655 # self._extraMetadata['scriptArgs'] = value
656 

◆ execute()

def python.trfExe.scriptExecutor.execute (   self)

Reimplemented from python.trfExe.transformExecutor.

Reimplemented in python.trfExe.bsMergeExecutor, and python.trfExe.POOLMergeExecutor.

Definition at line 722 of file trfExe.py.

722  def execute(self):
723  self._hasExecuted = True
724  msg.info('Starting execution of {0} ({1})'.format(self._name, self._cmd))
725 
726  self._exeStart = os.times()
727  msg.debug('exeStart time is {0}'.format(self._exeStart))
728  if ('execOnly' in self.conf.argdict and self.conf.argdict['execOnly'] is True):
729  msg.info('execOnly flag is set - execution will now switch, replacing the transform')
730  os.execvp(self._cmd[0], self._cmd)
731 
732  encargs = {'encoding' : 'utf8'}
733  try:
734  # if we are already inside a container, then
735  # must map /srv of the nested container to /srv of the parent container:
736  # https://twiki.atlas-canada.ca/bin/view/AtlasCanada/Containers#Mount_point_summary
737  if self._alreadyInContainer and self._containerSetup is not None:
738  msg.info("chdir /srv to launch a nested container for the substep")
739  os.chdir("/srv")
740  p = subprocess.Popen(self._cmd, shell = False, stdout = subprocess.PIPE, stderr = subprocess.STDOUT, bufsize = 1, **encargs)
741  # go back to the original working directory immediately after to store prmon in it
742  if self._alreadyInContainer and self._containerSetup is not None:
743  msg.info("chdir {} after launching the nested container".format(self._workdir))
744  os.chdir(self._workdir)
745 
746  if self._memMonitor:
747  try:
748  self._memSummaryFile = 'prmon.summary.' + self._name + '.json'
749  self._memFullFile = 'prmon.full.' + self._name
750  memMonitorCommand = ['prmon', '--pid', str(p.pid), '--filename', 'prmon.full.' + self._name,
751  '--json-summary', self._memSummaryFile, '--log-filename', 'prmon.' + self._name + '.log',
752  '--interval', '30']
753  mem_proc = subprocess.Popen(memMonitorCommand, shell = False, close_fds=True, **encargs)
754  # TODO - link mem.full.current to mem.full.SUBSTEP
755  except Exception as e:
756  msg.warning('Failed to spawn memory monitor for {0}: {1}'.format(self._name, e))
757  self._memMonitor = False
758 
759  while p.poll() is None:
760  line = p.stdout.readline()
761  if line:
762  self._echologger.info(line.rstrip())
763  # Hoover up remaining buffered output lines
764  for line in p.stdout:
765  self._echologger.info(line.rstrip())
766 
767  self._rc = p.returncode
768  msg.info('%s executor returns %d', self._name, self._rc)
769  self._exeStop = os.times()
770  msg.debug('exeStop time is {0}'.format(self._exeStop))
771  except OSError as e:
772  errMsg = 'Execution of {0} failed and raised OSError: {1}'.format(self._cmd[0], e)
773  msg.error(errMsg)
774  raise trfExceptions.TransformExecutionException(trfExit.nameToCode('TRF_EXEC'), errMsg)
775  finally:
776  if self._memMonitor:
777  try:
778  mem_proc.send_signal(signal.SIGUSR1)
779  countWait = 0
780  while (not mem_proc.poll()) and countWait < 10:
781  time.sleep(0.1)
782  countWait += 1
783  except OSError:
784  pass
785 
786 

◆ exeStartTimes()

def python.trfExe.transformExecutor.exeStartTimes (   self)
inherited

Definition at line 335 of file trfExe.py.

335  def exeStartTimes(self):
336  return self._exeStart
337 

◆ exeStopTimes()

def python.trfExe.transformExecutor.exeStopTimes (   self)
inherited

Definition at line 339 of file trfExe.py.

339  def exeStopTimes(self):
340  return self._exeStop
341 

◆ extraMetadata()

def python.trfExe.transformExecutor.extraMetadata (   self)
inherited

Definition at line 291 of file trfExe.py.

291  def extraMetadata(self):
292  return self._extraMetadata
293 

◆ first()

def python.trfExe.transformExecutor.first (   self)
inherited
Note
At the moment only athenaExecutor sets this property, but that might be changed...

Definition at line 324 of file trfExe.py.

324  def first(self):
325  if hasattr(self, '_first'):
326  return self._first
327  else:
328  return None
329 

◆ hasExecuted()

def python.trfExe.transformExecutor.hasExecuted (   self)
inherited

Definition at line 295 of file trfExe.py.

295  def hasExecuted(self):
296  return self._hasExecuted
297 

◆ hasValidated()

def python.trfExe.transformExecutor.hasValidated (   self)
inherited

Definition at line 315 of file trfExe.py.

315  def hasValidated(self):
316  return self._hasValidated
317 

◆ inData() [1/2]

def python.trfExe.transformExecutor.inData (   self)
inherited

Definition at line 234 of file trfExe.py.

234  def inData(self):
235 
236  if '_inData' in dir(self):
237  return self._inData
238  return None
239 

◆ inData() [2/2]

def python.trfExe.transformExecutor.inData (   self,
  value 
)
inherited

Definition at line 241 of file trfExe.py.

241  def inData(self, value):
242  self._inData = set(value)
243 

◆ inDataUpdate()

def python.trfExe.transformExecutor.inDataUpdate (   self,
  value 
)
inherited

Definition at line 244 of file trfExe.py.

244  def inDataUpdate(self, value):
245 
246  if '_inData' in dir(self):
247  self._inData.update(value)
248  else:
249 
250  self.inData = value
251 
252 

◆ input()

def python.trfExe.transformExecutor.input (   self)
inherited
Note
This returns the actual input data with which this executor ran (c.f. inData which returns all the possible data types this executor could run with)

Definition at line 275 of file trfExe.py.

275  def input(self):
276 
277  if '_input' in dir(self):
278  return self._input
279  return None
280 

◆ isValidated()

def python.trfExe.transformExecutor.isValidated (   self)
inherited

Definition at line 319 of file trfExe.py.

319  def isValidated(self):
320  return self._isValidated
321 

◆ memAnalysis()

def python.trfExe.transformExecutor.memAnalysis (   self)
inherited

Definition at line 397 of file trfExe.py.

397  def memAnalysis(self):
398  return self._memLeakResult
399 

◆ memStats()

def python.trfExe.transformExecutor.memStats (   self)
inherited

Definition at line 393 of file trfExe.py.

393  def memStats(self):
394  return self._memStats
395 

◆ myMerger()

def python.trfExe.transformExecutor.myMerger (   self)
inherited

Now define properties for these data members.

Definition at line 206 of file trfExe.py.

206  def myMerger(self):
207  return self._myMerger
208 

◆ name() [1/2]

def python.trfExe.transformExecutor.name (   self)
inherited

Definition at line 210 of file trfExe.py.

210  def name(self):
211  return self._name
212 

◆ name() [2/2]

def python.trfExe.transformExecutor.name (   self,
  value 
)
inherited

Definition at line 214 of file trfExe.py.

214  def name(self, value):
215  self._name = value
216 

◆ outData() [1/2]

def python.trfExe.transformExecutor.outData (   self)
inherited

Definition at line 254 of file trfExe.py.

254  def outData(self):
255 
256  if '_outData' in dir(self):
257  return self._outData
258  return None
259 

◆ outData() [2/2]

def python.trfExe.transformExecutor.outData (   self,
  value 
)
inherited

Definition at line 261 of file trfExe.py.

261  def outData(self, value):
262  self._outData = set(value)
263 

◆ outDataUpdate()

def python.trfExe.transformExecutor.outDataUpdate (   self,
  value 
)
inherited

Definition at line 264 of file trfExe.py.

264  def outDataUpdate(self, value):
265 
266  if '_outData' in dir(self):
267  self._outData.update(value)
268  else:
269 
270  self.outData = value
271 

◆ output()

def python.trfExe.transformExecutor.output (   self)
inherited
Note
This returns the actual output data with which this executor ran (c.f. outData which returns all the possible data types this executor could run with)

Definition at line 284 of file trfExe.py.

284  def output(self):
285 
286  if '_output' in dir(self):
287  return self._output
288  return None
289 

◆ postExeCpuTime()

def python.trfExe.transformExecutor.postExeCpuTime (   self)
inherited

Definition at line 401 of file trfExe.py.

401  def postExeCpuTime(self):
402  if self._exeStop and self._valStart:
403  return calcCpuTime(self._exeStop, self._valStart)
404  else:
405  return None
406 

◆ postExecute()

def python.trfExe.scriptExecutor.postExecute (   self)

Reimplemented from python.trfExe.transformExecutor.

Reimplemented in python.trfExe.bsMergeExecutor, and python.trfExe.athenaExecutor.

Definition at line 787 of file trfExe.py.

787  def postExecute(self):
788  if hasattr(self._exeLogFile, 'close'):
789  self._exeLogFile.close()
790  if self._memMonitor:
791  try:
792  memFile = open(self._memSummaryFile)
793  self._memStats = json.load(memFile)
794  except Exception as e:
795  msg.warning('Failed to load JSON memory summmary file {0}: {1}'.format(self._memSummaryFile, e))
796  self._memMonitor = False
797  self._memStats = {}
798 
799 

◆ postExeWallTime()

def python.trfExe.transformExecutor.postExeWallTime (   self)
inherited

Definition at line 408 of file trfExe.py.

408  def postExeWallTime(self):
409  if self._exeStop and self._valStart:
410  return calcWallTime(self._exeStop, self._valStart)
411  else:
412  return None
413 

◆ preExeCpuTime()

def python.trfExe.transformExecutor.preExeCpuTime (   self)
inherited

Definition at line 351 of file trfExe.py.

351  def preExeCpuTime(self):
352  if self._preExeStart and self._exeStart:
353  return calcCpuTime(self._preExeStart, self._exeStart)
354  else:
355  return None
356 

◆ preExecute()

def python.trfExe.scriptExecutor.preExecute (   self,
  input = set(),
  output = set() 
)

Reimplemented from python.trfExe.transformExecutor.

Reimplemented in python.trfExe.archiveExecutor, python.trfExe.bsMergeExecutor, python.trfExe.NTUPMergeExecutor, python.trfExe.DQMPostProcessExecutor, python.trfExe.DQMergeExecutor, python.trfExe.reductionFrameworkExecutor, python.trfExe.POOLMergeExecutor, and python.trfExe.athenaExecutor.

Definition at line 657 of file trfExe.py.

657  def preExecute(self, input = set(), output = set()):
658  self.setPreExeStart()
659  msg.debug('scriptExecutor: Preparing for execution of {0} with inputs {1} and outputs {2}'.format(self.name, input, output))
660 
661  self._input = input
662  self._output = output
663 
664 
665  if self._cmd is None:
666  self._buildStandardCommand()
667  msg.info('Will execute script as %s', self._cmd)
668 
669  # Define this here to have it for environment detection messages
670  self._logFileName = "log.{0}".format(self._name)
671 
672 
674  if 'TRF_ECHO' in os.environ:
675  msg.info('TRF_ECHO envvar is set - enabling command echoing to stdout')
676  self._echoOutput = True
677  elif 'TRF_NOECHO' in os.environ:
678  msg.info('TRF_NOECHO envvar is set - disabling command echoing to stdout')
679  self._echoOutput = False
680  # PS1 is for sh, bash; prompt is for tcsh and zsh
681  elif isInteractiveEnv():
682  msg.info('Interactive environment detected (stdio or stdout is a tty) - enabling command echoing to stdout')
683  self._echoOutput = True
684  elif 'TZHOME' in os.environ:
685  msg.info('Tier-0 environment detected - enabling command echoing to stdout')
686  self._echoOutput = True
687  if self._echoOutput is False:
688  msg.info('Batch/grid running - command outputs will not be echoed. Logs for {0} are in {1}'.format(self._name, self._logFileName))
689 
690  # Now setup special loggers for logging execution messages to stdout and file
691  self._echologger = logging.getLogger(self._name)
692  self._echologger.setLevel(logging.INFO)
693  self._echologger.propagate = False
694 
695  encargs = {'encoding' : 'utf-8'}
696  self._exeLogFile = logging.FileHandler(self._logFileName, mode='w', **encargs)
697  self._exeLogFile.setFormatter(logging.Formatter('%(asctime)s %(message)s', datefmt='%H:%M:%S'))
698  self._echologger.addHandler(self._exeLogFile)
699 
700  if self._echoOutput:
701  self._echostream = logging.StreamHandler(_encoding_stream(sys.stdout))
702  self._echostream.setFormatter(logging.Formatter('%(name)s %(asctime)s %(message)s', datefmt='%H:%M:%S'))
703  self._echologger.addHandler(self._echostream)
704 

◆ preExeStartTimes()

def python.trfExe.transformExecutor.preExeStartTimes (   self)
inherited

Definition at line 331 of file trfExe.py.

331  def preExeStartTimes(self):
332  return self._preExeStart
333 

◆ preExeWallTime()

def python.trfExe.transformExecutor.preExeWallTime (   self)
inherited

Definition at line 358 of file trfExe.py.

358  def preExeWallTime(self):
359  if self._preExeStart and self._exeStart:
360  return calcWallTime(self._preExeStart, self._exeStart)
361  else:
362  return None
363 

◆ rc()

def python.trfExe.transformExecutor.rc (   self)
inherited

Definition at line 299 of file trfExe.py.

299  def rc(self):
300  return self._rc
301 

◆ reSimEvent()

def python.trfExe.transformExecutor.reSimEvent (   self)
inherited

Definition at line 447 of file trfExe.py.

447  def reSimEvent(self):
448  return self._resimevents
449 

◆ setPreExeStart()

def python.trfExe.transformExecutor.setPreExeStart (   self)
inherited

Definition at line 460 of file trfExe.py.

460  def setPreExeStart(self):
461  if self._preExeStart is None:
462  self._preExeStart = os.times()
463  msg.debug('preExeStart time is {0}'.format(self._preExeStart))
464 

◆ setValStart()

def python.trfExe.transformExecutor.setValStart (   self)
inherited

Definition at line 465 of file trfExe.py.

465  def setValStart(self):
466  if self._valStart is None:
467  self._valStart = os.times()
468  msg.debug('valStart time is {0}'.format(self._valStart))
469 

◆ substep()

def python.trfExe.transformExecutor.substep (   self)
inherited

Reimplemented in python.trfExe.athenaExecutor.

Definition at line 218 of file trfExe.py.

218  def substep(self):
219  if '_substep' in dir(self):
220  return self._substep
221  return None
222 

◆ sysTime()

def python.trfExe.transformExecutor.sysTime (   self)
inherited

Definition at line 379 of file trfExe.py.

379  def sysTime(self):
380  if self._exeStart and self._exeStop:
381  return self._exeStop[3] - self._exeStart[3]
382  else:
383  return None
384 

◆ trf() [1/2]

def python.trfExe.transformExecutor.trf (   self)
inherited

Definition at line 224 of file trfExe.py.

224  def trf(self):
225  if '_trf' in dir(self):
226  return self._trf
227  return None
228 

◆ trf() [2/2]

def python.trfExe.transformExecutor.trf (   self,
  value 
)
inherited

Definition at line 230 of file trfExe.py.

230  def trf(self, value):
231  self._trf = value
232 

◆ usrTime()

def python.trfExe.transformExecutor.usrTime (   self)
inherited

Definition at line 372 of file trfExe.py.

372  def usrTime(self):
373  if self._exeStart and self._exeStop:
374  return self._exeStop[2] - self._exeStart[2]
375  else:
376  return None
377 

◆ validate()

def python.trfExe.scriptExecutor.validate (   self)

Reimplemented from python.trfExe.transformExecutor.

Reimplemented in python.trfExe.DQMPostProcessExecutor, python.trfExe.DQMergeExecutor, python.trfExe.optionalAthenaExecutor, and python.trfExe.athenaExecutor.

Definition at line 800 of file trfExe.py.

800  def validate(self):
801  if self._valStart is None:
802  self._valStart = os.times()
803  msg.debug('valStart time is {0}'.format(self._valStart))
804  self._hasValidated = True
805 
806 
807  if self._rc == 0:
808  msg.info('Executor {0} validated successfully (return code {1})'.format(self._name, self._rc))
809  self._isValidated = True
810  self._errMsg = ''
811  else:
812  # Want to learn as much as possible from the non-zero code
813  # this is a bit hard in general, although one can do signals.
814  # Probably need to be more specific per exe, i.e., athena non-zero codes
815  self._isValidated = False
816  if self._rc < 0:
817  # Map return codes to what the shell gives (128 + SIGNUM)
818  self._rc = 128 - self._rc
819  if trfExit.codeToSignalname(self._rc) != "":
820  self._errMsg = '{0} got a {1} signal (exit code {2})'.format(self._name, trfExit.codeToSignalname(self._rc), self._rc)
821  else:
822  self._errMsg = 'Non-zero return code from %s (%d)' % (self._name, self._rc)
823  raise trfExceptions.TransformValidationException(trfExit.nameToCode('TRF_EXEC_FAIL'), self._errMsg)
824 
825 
827  if 'checkEventCount' in self.conf.argdict and self.conf.argdict['checkEventCount'].returnMyValue(exe=self) is False:
828  msg.info('Event counting for substep {0} is skipped'.format(self.name))
829  else:
830  checkcount=trfValidation.eventMatch(self)
831  checkcount.decide()
832  self._eventCount = checkcount.eventCount
833  msg.info('Event counting for substep {0} passed'.format(self.name))
834 
835  self._valStop = os.times()
836  msg.debug('valStop time is {0}'.format(self._valStop))
837 
838 
839 

◆ validation() [1/2]

def python.trfExe.transformExecutor.validation (   self)
inherited

Definition at line 307 of file trfExe.py.

307  def validation(self):
308  return self._validation
309 

◆ validation() [2/2]

def python.trfExe.transformExecutor.validation (   self,
  value 
)
inherited

Definition at line 311 of file trfExe.py.

311  def validation(self, value):
312  self._validation = value
313 

◆ validationCpuTime()

def python.trfExe.transformExecutor.validationCpuTime (   self)
inherited

Definition at line 415 of file trfExe.py.

415  def validationCpuTime(self):
416  if self._valStart and self._valStop:
417  return calcCpuTime(self._valStart, self._valStop)
418  else:
419  return None
420 

◆ validationWallTime()

def python.trfExe.transformExecutor.validationWallTime (   self)
inherited

Definition at line 422 of file trfExe.py.

422  def validationWallTime(self):
423  if self._valStart and self._valStop:
424  return calcWallTime(self._valStart, self._valStop)
425  else:
426  return None
427 

◆ valStartTimes()

def python.trfExe.transformExecutor.valStartTimes (   self)
inherited

Definition at line 343 of file trfExe.py.

343  def valStartTimes(self):
344  return self._valStart
345 

◆ valStopTimes()

def python.trfExe.transformExecutor.valStopTimes (   self)
inherited

Definition at line 347 of file trfExe.py.

347  def valStopTimes(self):
348  return self._valStop
349 

◆ wallTime()

def python.trfExe.transformExecutor.wallTime (   self)
inherited

Definition at line 386 of file trfExe.py.

386  def wallTime(self):
387  if self._exeStart and self._exeStop:
388  return calcWallTime(self._exeStart, self._exeStop)
389  else:
390  return None
391 

◆ wallTimeTotal()

def python.trfExe.transformExecutor.wallTimeTotal (   self)
inherited

Definition at line 436 of file trfExe.py.

436  def wallTimeTotal(self):
437  if self._preExeStart and self._valStop:
438  return calcWallTime(self._preExeStart, self._valStop)
439  else:
440  return None
441 

Member Data Documentation

◆ _alreadyInContainer

python.trfExe.transformExecutor._alreadyInContainer
privateinherited

Definition at line 197 of file trfExe.py.

◆ _athenaConcurrentEvents

python.trfExe.transformExecutor._athenaConcurrentEvents
privateinherited

Definition at line 194 of file trfExe.py.

◆ _athenaMP

python.trfExe.transformExecutor._athenaMP
privateinherited

Definition at line 192 of file trfExe.py.

◆ _athenaMT

python.trfExe.transformExecutor._athenaMT
privateinherited

Definition at line 193 of file trfExe.py.

◆ _cmd

python.trfExe.scriptExecutor._cmd
private

Definition at line 634 of file trfExe.py.

◆ _containerSetup

python.trfExe.transformExecutor._containerSetup
privateinherited

Definition at line 198 of file trfExe.py.

◆ _dbMonitor

python.trfExe.transformExecutor._dbMonitor
privateinherited

Definition at line 195 of file trfExe.py.

◆ _echologger

python.trfExe.scriptExecutor._echologger
private

Definition at line 691 of file trfExe.py.

◆ _echoOutput

python.trfExe.scriptExecutor._echoOutput
private
Note
Query the environment for echo configuration Let the manual envars always win over auto-detected settings

Definition at line 631 of file trfExe.py.

◆ _echostream

python.trfExe.scriptExecutor._echostream
private

Definition at line 701 of file trfExe.py.

◆ _errMsg

python.trfExe.scriptExecutor._errMsg
private

Definition at line 810 of file trfExe.py.

◆ _eventCount

python.trfExe.scriptExecutor._eventCount
private

Check event counts (always do this by default) Do this here so that all script executors have this by default (covers most use cases with events)

Definition at line 832 of file trfExe.py.

◆ _exe

python.trfExe.scriptExecutor._exe
private

Definition at line 621 of file trfExe.py.

◆ _exeArgs

python.trfExe.scriptExecutor._exeArgs
private

Definition at line 624 of file trfExe.py.

◆ _exeLogFile

python.trfExe.scriptExecutor._exeLogFile
private

Definition at line 696 of file trfExe.py.

◆ _exeStart

python.trfExe.scriptExecutor._exeStart
private

Definition at line 726 of file trfExe.py.

◆ _exeStop

python.trfExe.scriptExecutor._exeStop
private

Definition at line 769 of file trfExe.py.

◆ _extraMetadata

python.trfExe.transformExecutor._extraMetadata
privateinherited

Definition at line 180 of file trfExe.py.

◆ _hasExecuted

python.trfExe.scriptExecutor._hasExecuted
private

Definition at line 723 of file trfExe.py.

◆ _hasValidated

python.trfExe.scriptExecutor._hasValidated
private

Definition at line 804 of file trfExe.py.

◆ _inData

python.trfExe.transformExecutor._inData
privateinherited

Definition at line 143 of file trfExe.py.

◆ _input

python.trfExe.scriptExecutor._input
private

Definition at line 661 of file trfExe.py.

◆ _isValidated

python.trfExe.scriptExecutor._isValidated
private

Definition at line 809 of file trfExe.py.

◆ _logFileName

python.trfExe.scriptExecutor._logFileName
private
Note
If an inherited class has set self._cmd leave it alone

Definition at line 670 of file trfExe.py.

◆ _memFullFile

python.trfExe.scriptExecutor._memFullFile
private

Definition at line 749 of file trfExe.py.

◆ _memLeakResult

python.trfExe.transformExecutor._memLeakResult
privateinherited

Definition at line 189 of file trfExe.py.

◆ _memMonitor

python.trfExe.scriptExecutor._memMonitor
private

Definition at line 636 of file trfExe.py.

◆ _memStats

python.trfExe.scriptExecutor._memStats
private

Definition at line 793 of file trfExe.py.

◆ _memSummaryFile

python.trfExe.scriptExecutor._memSummaryFile
private

Definition at line 748 of file trfExe.py.

◆ _myMerger

python.trfExe.transformExecutor._myMerger
privateinherited

Definition at line 201 of file trfExe.py.

◆ _name

python.trfExe.transformExecutor._name
privateinherited

Definition at line 140 of file trfExe.py.

◆ _outData

python.trfExe.transformExecutor._outData
privateinherited

Definition at line 144 of file trfExe.py.

◆ _output

python.trfExe.scriptExecutor._output
private

Definition at line 662 of file trfExe.py.

◆ _preExeStart

python.trfExe.transformExecutor._preExeStart
privateinherited
Note
Place holders for resource consumption. CPU and walltime are available for all executors but currently only athena is instrumented to fill in memory stats (and then only if PerfMonSD is enabled).

Definition at line 185 of file trfExe.py.

◆ _rc

python.trfExe.scriptExecutor._rc
private

Check rc.

Definition at line 767 of file trfExe.py.

◆ _resimevents

python.trfExe.transformExecutor._resimevents
privateinherited

Definition at line 196 of file trfExe.py.

◆ _trf

python.trfExe.transformExecutor._trf
privateinherited

Definition at line 231 of file trfExe.py.

◆ _validation

python.trfExe.transformExecutor._validation
privateinherited

Definition at line 312 of file trfExe.py.

◆ _valStart

python.trfExe.scriptExecutor._valStart
private

Definition at line 802 of file trfExe.py.

◆ _valStop

python.trfExe.scriptExecutor._valStop
private

Definition at line 835 of file trfExe.py.

◆ conf

python.trfExe.transformExecutor.conf
inherited

Executor configuration:

Note
that if conf and trf are None then we'll probably set the conf up later (this is allowed and expected to be done once the master transform has figured out what it's doing for this job)

Definition at line 162 of file trfExe.py.

◆ inData

python.trfExe.transformExecutor.inData
inherited
Note
Protect against _inData not yet being defined
Use normal setter

Definition at line 250 of file trfExe.py.

◆ outData

python.trfExe.transformExecutor.outData
inherited
Note
Protect against _outData not yet being defined
Use normal setter

Definition at line 270 of file trfExe.py.


The documentation for this class was generated from the following file:
grepfile.info
info
Definition: grepfile.py:38
python.trfUtils.isInteractiveEnv
def isInteractiveEnv()
Definition: trfUtils.py:703
validation
Definition: validation.py:1
validation.validate
def validate(testSampleDir, thisSampleName, testSamplePath, weight_database, outputSamples)
Definition: validation.py:26
vtune_athena.format
format
Definition: vtune_athena.py:14
python.trfUtils.calcCpuTime
def calcCpuTime(start, stop)
Definition: trfUtils.py:1683
python.trfExe._encoding_stream
def _encoding_stream(s)
Definition: trfExe.py:44
dumpHVPathFromNtuple.append
bool append
Definition: dumpHVPathFromNtuple.py:91
LArG4FSStartPointFilterLegacy.execute
execute
Definition: LArG4FSStartPointFilterLegacy.py:20
pool::DbPrintLvl::setLevel
void setLevel(MsgLevel l)
Definition: DbPrint.h:32
PlotPulseshapeFromCool.input
input
Definition: PlotPulseshapeFromCool.py:106
beamspotman.dir
string dir
Definition: beamspotman.py:623
CxxUtils::set
constexpr std::enable_if_t< is_bitmask_v< E >, E & > set(E &lhs, E rhs)
Convenience function to set bits in a class enum bitmask.
Definition: bitmask.h:232
merge.output
output
Definition: merge.py:17
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
python.trfUtils.calcWallTime
def calcWallTime(start, stop)
Definition: trfUtils.py:1691
python.processes.powheg.ZZ.ZZ.__init__
def __init__(self, base_directory, **kwargs)
Constructor: all process options are set here.
Definition: ZZ.py:18
Trk::open
@ open
Definition: BinningType.h:40
ActsTrk::detail::MakeDerivedVariant::extend
constexpr std::variant< Args..., T > extend(const std::variant< Args... > &, const T &)
Definition: MakeDerivedVariant.h:17
DeMoScan.first
bool first
Definition: DeMoScan.py:536
str
Definition: BTagTrackIpAccessor.cxx:11
CaloLCW_tf.trf
trf
Definition: CaloLCW_tf.py:20
WriteBchToCool.update
update
Definition: WriteBchToCool.py:67