"""
Provides CLI interface for :meth:`tokio.tools.topology.get_job_diameter`.
"""
import json
import argparse
import tokio.tools.topology
[docs]def main(argv=None):
"""Entry point for the CLI interface
"""
parser = argparse.ArgumentParser()
group = parser.add_mutually_exclusive_group(required=True)
group.add_argument("--jobinfo-cache", default=None, type=str,
help="path to jobinfo (e.g., Slurm) cache file")
parser.add_argument("--nodemap-cache", default=None, type=str,
help="path to xtdb2proc cache file")
parser.add_argument("-o", "--output", type=str, default=None, help="output file")
group.add_argument("jobid", nargs='?', default=None, help="Slurm job id of interest")
args = parser.parse_args(argv)
topology_result = tokio.tools.topology.get_job_diameter(jobid=args.jobid,
nodemap_cache_file=args.nodemap_cache,
jobinfo_cache_file=args.jobinfo_cache)
# Serialize the object
cache_file = args.output
if cache_file is None:
print(json.dumps(topology_result, indent=4, sort_keys=True))
else:
print("Caching to %s" % cache_file)
json.dump(topology_result, open(cache_file, 'w'))