Skip to content

Commit

Permalink
Merge pull request #135 from PalNilsson/next
Browse files Browse the repository at this point in the history
3.7.8.21
  • Loading branch information
PalNilsson authored Jul 3, 2024
2 parents 08ddf7a + 04603ed commit 2d660a1
Show file tree
Hide file tree
Showing 25 changed files with 542 additions and 364 deletions.
2 changes: 1 addition & 1 deletion PILOTVERSION
Original file line number Diff line number Diff line change
@@ -1 +1 @@
3.7.7.3
3.7.8.21
25 changes: 22 additions & 3 deletions pilot.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
import time
from os import getcwd, chdir, environ
from os.path import exists, join
from re import match
from shutil import rmtree
from typing import Any

Expand Down Expand Up @@ -243,6 +244,25 @@ def str2bool(var: str) -> bool:
return ret


def validate_resource_type(value: str) -> str:
"""
Validate the resource type.
:param value: resource type (str)
:return: resource type (str)
:raises: argparse.ArgumentTypeError if the resource type is invalid.
"""
# Define the allowed patterns
allowed_patterns = ["SCORE", "MCORE", "SCORE_*", "MCORE_*"]
if value in allowed_patterns:
return value
# Check for pattern matching
for pattern in allowed_patterns:
if pattern.endswith('*') and match(f"^{pattern[:-1]}", value):
return value
raise argparse.ArgumentTypeError(f"Invalid resource type: {value}")


def get_args() -> Any:
"""
Return the args from the arg parser.
Expand Down Expand Up @@ -548,9 +568,8 @@ def get_args() -> Any:
"--resource-type",
dest="resource_type",
default="",
type=str,
choices=["SCORE", "MCORE", "SCORE_HIMEM", "MCORE_HIMEM"],
help="Resource type; MCORE, SCORE, SCORE_HIMEM or MCORE_HIMEM",
type=validate_resource_type,
help="Resource type; MCORE, SCORE or patterns like SCORE_* and MCORE_*",
)
arg_parser.add_argument(
"--use-https",
Expand Down
5 changes: 5 additions & 0 deletions pilot/control/job.py
Original file line number Diff line number Diff line change
Expand Up @@ -788,9 +788,14 @@ def get_data_structure(job: Any, state: str, args: Any, xml: str = "", metadata:
extra = {'readbyterate': readfrac}
else:
logger.debug('read_bytes info not yet available')

# extract and remove any GPU info from data since it will be reported with job metrics
add_gpu_info(data, extra)

# add the lsetup time if set
if job.lsetuptime:
extra['lsetup_time'] = job.lsetuptime

job_metrics = get_job_metrics(job, extra=extra)
if job_metrics:
data['jobMetrics'] = job_metrics
Expand Down
Loading

0 comments on commit 2d660a1

Please sign in to comment.