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

Public Member Functions

None __init__ (self, str ID, WorkflowRun run, WorkflowType type, List[str] steps, TestSetup setup, str extra_args="")
 
None run_reference (self)
 
None run_validation (self)
 
bool run_checks (self, List[WorkflowCheck] performance_checks)
 

Public Attributes

 command
 
 skip_performance_checks
 
 output_checks
 
 ID
 
 tag
 
 steps
 
 digest_checks
 
 run
 
 type
 
 setup
 
 logger
 

Detailed Description

Derivations test.

Definition at line 200 of file StandardTests.py.

Constructor & Destructor Documentation

◆ __init__()

None python.StandardTests.DerivationTest.__init__ (   self,
str  ID,
WorkflowRun  run,
WorkflowType  type,
List[str steps,
TestSetup  setup,
str   extra_args = "" 
)

Definition at line 203 of file StandardTests.py.

203  def __init__(self, ID: str, run: WorkflowRun, type: WorkflowType, steps: List[str], setup: TestSetup, extra_args: str = "") -> None:
204  test_def = ID.split("_")
205  data_type = test_def[0].lower()
206  formats = [format.upper() for format in test_def[1:-1]]
207 
208  threads = 0
209  if setup.custom_threads is not None:
210  threads = setup.custom_threads
211 
212  if "maxEvents" not in extra_args:
213  base_events = 100
214  events = threads * base_events + 1
215  flush = 80
216 
217  extra_args += f" --maxEvents {events}"
218  format_flush = ", ".join([f"\"DAOD_{format}\": {flush}" for format in formats])
219  extra_args += f" --preExec 'flags.Output.TreeAutoFlush={{{format_flush}}}'"
220  if "inputAODFile" not in extra_args:
221  extra_args += f" --inputAODFile {input_AOD[run][data_type]}"
222 
223  # could also use p5503
224  self.command = \
225  (f"ATHENA_CORE_NUMBER={threads} Derivation_tf.py"
226  f" --formats {' '.join(formats)}"
227  " --multiprocess --multithreadedFileValidation True"
228  " --athenaMPMergeTargetSize 'DAOD_*:0'"
229  " --sharedWriter True"
230  " --outputDAODFile myOutput.pool.root"
231  f" --imf False {extra_args}")
232 
233  # skip performance checks for now
234  self.skip_performance_checks = True
235 
236  self.output_checks = []
237  for format in formats:
238  self.output_checks.append(FrozenTier0PolicyCheck(setup, f"DAOD_{format}", 10))
239  self.output_checks.append(MetadataCheck(setup, f"DAOD_{format}"))
240 
241  super().__init__(ID, run, type, steps, setup)
242 
243 

Member Function Documentation

◆ run_checks()

bool python.Test.WorkflowTest.run_checks (   self,
List[WorkflowCheck performance_checks 
)
inherited

Definition at line 198 of file Tools/WorkflowTestRunner/python/Test.py.

198  def run_checks(self, performance_checks: List[WorkflowCheck]) -> bool:
199  self.logger.info("-----------------------------------------------------")
200  self.logger.info(f"----------- Post-processing of {self.ID} Test -----------")
201  result = True
202 
203  # digest checks
204  for check in self.digest_checks:
205  result = check.run(self) and result
206 
207  # output checks
208  if not self.setup.disable_output_checks:
209  for check in self.output_checks:
210  result = check.run(self) and result
211 
212  if self.setup.validation_only or self.skip_performance_checks:
213  return result # Performance checks against static references not possible
214 
215  # performance checks
216  for check in performance_checks:
217  result = check.run(self) and result
218 
219  return result

◆ run_reference()

None python.Test.WorkflowTest.run_reference (   self)
inherited

Definition at line 161 of file Tools/WorkflowTestRunner/python/Test.py.

161  def run_reference(self) -> None:
162  self.logger.info(f"Running reference in rel {self.setup.release_reference}")
163  self.logger.info(f"\"{self.command}\"")
164 
165  self.reference_path.mkdir(parents=True, exist_ok=True)
166 
167  cmd = (f"cd {self.reference_path};"
168  f"source $AtlasSetup/scripts/asetup.sh {self.setup.release_reference} >& /dev/null;")
169  cmd += f"TRF_NOECHO=1 {self.command} > {self.ID}.log 2>&1"
170 
171  subprocess.call(cmd, shell=True)
172 
173  self.logger.info(f"Finished clean in rel {self.setup.release_reference}")
174  self.logger.info(f"\"{self.command}\"")
175 

◆ run_validation()

None python.Test.WorkflowTest.run_validation (   self)
inherited

Definition at line 176 of file Tools/WorkflowTestRunner/python/Test.py.

176  def run_validation(self) -> None:
177  self.logger.info(f"Running validation in rel {self.setup.release_validation}")
178  self.logger.info(f"\"{self.command}\"")
179 
180  self.validation_path.mkdir(parents=True, exist_ok=True)
181 
182  cmd = f"cd {self.validation_path};"
183  if self.setup.disable_release_setup or not self.setup.release_validation:
184  pass
185  elif "WorkDir_DIR" in environ:
186  cmake_build_dir = environ["WorkDir_DIR"]
187  cmd += (f"source $AtlasSetup/scripts/asetup.sh {self.setup.release_validation} >& /dev/null;"
188  f"source {cmake_build_dir}/setup.sh;")
189  else:
190  cmd += f"source $AtlasSetup/scripts/asetup.sh {self.setup.release_validation} >& /dev/null;"
191  cmd += f"TRF_NOECHO=1 {self.command} > {self.ID}.log 2>&1"
192 
193  subprocess.call(cmd, shell=True)
194 
195  self.logger.info(f"Finished validation in rel {self.setup.release_validation}")
196  self.logger.info(f"\"{self.command}\"")
197 

Member Data Documentation

◆ command

python.StandardTests.DerivationTest.command

Definition at line 224 of file StandardTests.py.

◆ digest_checks

python.Test.WorkflowTest.digest_checks
inherited

Definition at line 149 of file Tools/WorkflowTestRunner/python/Test.py.

◆ ID

python.Test.WorkflowTest.ID
inherited

Definition at line 134 of file Tools/WorkflowTestRunner/python/Test.py.

◆ logger

python.Test.WorkflowTest.logger
inherited

Definition at line 157 of file Tools/WorkflowTestRunner/python/Test.py.

◆ output_checks

python.StandardTests.DerivationTest.output_checks

Definition at line 236 of file StandardTests.py.

◆ run

python.Test.WorkflowTest.run
inherited

Definition at line 154 of file Tools/WorkflowTestRunner/python/Test.py.

◆ setup

python.Test.WorkflowTest.setup
inherited

Definition at line 156 of file Tools/WorkflowTestRunner/python/Test.py.

◆ skip_performance_checks

python.StandardTests.DerivationTest.skip_performance_checks

Definition at line 234 of file StandardTests.py.

◆ steps

python.Test.WorkflowTest.steps
inherited

Definition at line 140 of file Tools/WorkflowTestRunner/python/Test.py.

◆ tag

python.Test.WorkflowTest.tag
inherited

Definition at line 137 of file Tools/WorkflowTestRunner/python/Test.py.

◆ type

python.Test.WorkflowTest.type
inherited

Definition at line 155 of file Tools/WorkflowTestRunner/python/Test.py.


The documentation for this class was generated from the following file:
grepfile.info
info
Definition: grepfile.py:38
plot_material.mkdir
def mkdir(path, recursive=True)
Definition: plot_material.py:16
dumpHVPathFromNtuple.append
bool append
Definition: dumpHVPathFromNtuple.py:91
TCS::join
std::string join(const std::vector< std::string > &v, const char c=',')
Definition: Trigger/TrigT1/L1Topo/L1TopoCommon/Root/StringUtils.cxx:10
python.processes.powheg.ZZ.ZZ.__init__
def __init__(self, base_directory, **kwargs)
Constructor: all process options are set here.
Definition: ZZ.py:18
python.ScriptUtils.run_checks
bool run_checks(TestSetup setup, List[WorkflowTest] tests, List[WorkflowCheck] performance_checks)
Definition: ScriptUtils.py:269