Generalize task status output
This commit is contained in:
parent
262babc63d
commit
eb1d61a8b9
|
@ -550,7 +550,7 @@ def cli_cluster_maintenance_off():
|
|||
)
|
||||
@format_opt(
|
||||
{
|
||||
"pretty": cli_provisioner_status_format_pretty,
|
||||
"pretty": cli_cluster_task_format_pretty,
|
||||
"raw": lambda d: "\n".join([t["id"] for t in d])
|
||||
if isinstance(d, list)
|
||||
else d["state"],
|
||||
|
|
|
@ -47,7 +47,6 @@ from pvc.lib.provisioner import format_list_userdata as provisioner_format_userd
|
|||
from pvc.lib.provisioner import format_list_script as provisioner_format_script_list
|
||||
from pvc.lib.provisioner import format_list_ova as provisioner_format_ova_list
|
||||
from pvc.lib.provisioner import format_list_profile as provisioner_format_profile_list
|
||||
from pvc.lib.provisioner import format_list_task as provisioner_format_task_status
|
||||
|
||||
|
||||
# Define colour values for use in formatters
|
||||
|
@ -262,6 +261,160 @@ def cli_cluster_status_format_short(CLI_CONFIG, data):
|
|||
return "\n".join(output)
|
||||
|
||||
|
||||
def cli_cluster_task_format_pretty(CLI_CONFIG, task_data):
|
||||
"""
|
||||
Pretty format the output of cli_cluster_task
|
||||
"""
|
||||
if not isinstance(task_data, list):
|
||||
job_state = task_data["state"]
|
||||
if job_state == "RUNNING":
|
||||
retdata = "Job state: RUNNING\nStage: {}/{}\nStatus: {}".format(
|
||||
task_data["current"], task_data["total"], task_data["status"]
|
||||
)
|
||||
elif job_state == "FAILED":
|
||||
retdata = "Job state: FAILED\nStatus: {}".format(task_data["status"])
|
||||
elif job_state == "COMPLETED":
|
||||
retdata = "Job state: COMPLETED\nStatus: {}".format(task_data["status"])
|
||||
else:
|
||||
retdata = "Job state: {}\nStatus: {}".format(
|
||||
task_data["state"], task_data["status"]
|
||||
)
|
||||
return retdata
|
||||
|
||||
task_list_output = []
|
||||
|
||||
# Determine optimal column widths
|
||||
task_id_length = 7
|
||||
task_type_length = 7
|
||||
task_worker_length = 7
|
||||
task_arg_name_length = 5
|
||||
task_arg_data_length = 10
|
||||
|
||||
tasks = list()
|
||||
for task in task_data:
|
||||
# task_id column
|
||||
_task_id_length = len(str(task["id"])) + 1
|
||||
if _task_id_length > task_id_length:
|
||||
task_id_length = _task_id_length
|
||||
# task_worker column
|
||||
_task_worker_length = len(str(task["worker"])) + 1
|
||||
if _task_worker_length > task_worker_length:
|
||||
task_worker_length = _task_worker_length
|
||||
# task_type column
|
||||
_task_type_length = len(str(task["type"])) + 1
|
||||
if _task_type_length > task_type_length:
|
||||
task_type_length = _task_type_length
|
||||
|
||||
updated_kwargs = list()
|
||||
for arg_name, arg_data in task["kwargs"].items():
|
||||
# task_arg_name column
|
||||
_task_arg_name_length = len(str(arg_name)) + 1
|
||||
if _task_arg_name_length > task_arg_name_length:
|
||||
task_arg_name_length = _task_arg_name_length
|
||||
|
||||
if len(str(arg_data)) > 30:
|
||||
arg_data = arg_data[:30]
|
||||
|
||||
# task_arg_data column
|
||||
_task_arg_data_length = len(str(arg_data)) + 1
|
||||
if _task_arg_data_length > task_arg_data_length:
|
||||
task_arg_data_length = _task_arg_data_length
|
||||
|
||||
updated_kwargs.append({"name": arg_name, "data": arg_data})
|
||||
task["kwargs"] = updated_kwargs
|
||||
tasks.append(task)
|
||||
|
||||
# Format the string (header)
|
||||
task_list_output.append(
|
||||
"{bold}{task_header: <{task_header_length}} {arg_header: <{arg_header_length}}{end_bold}".format(
|
||||
bold=ansii["bold"],
|
||||
end_bold=ansii["end"],
|
||||
task_header_length=task_id_length
|
||||
+ task_type_length
|
||||
+ task_worker_length
|
||||
+ 2,
|
||||
arg_header_length=task_arg_name_length + task_arg_data_length,
|
||||
task_header="Tasks "
|
||||
+ "".join(
|
||||
[
|
||||
"-"
|
||||
for _ in range(
|
||||
6, task_id_length + task_type_length + task_worker_length + 1
|
||||
)
|
||||
]
|
||||
),
|
||||
arg_header="Arguments "
|
||||
+ "".join(
|
||||
["-" for _ in range(12, task_arg_name_length + task_arg_data_length)]
|
||||
),
|
||||
)
|
||||
)
|
||||
|
||||
task_list_output.append(
|
||||
"{bold}{task_id: <{task_id_length}} {task_type: <{task_type_length}} \
|
||||
{task_worker: <{task_worker_length}} \
|
||||
{task_arg_name: <{task_arg_name_length}} \
|
||||
{task_arg_data: <{task_arg_data_length}}{end_bold}".format(
|
||||
task_id_length=task_id_length,
|
||||
task_type_length=task_type_length,
|
||||
task_worker_length=task_worker_length,
|
||||
task_arg_name_length=task_arg_name_length,
|
||||
task_arg_data_length=task_arg_data_length,
|
||||
bold=ansii["bold"],
|
||||
end_bold=ansii["end"],
|
||||
task_id="Job ID",
|
||||
task_type="Status",
|
||||
task_worker="Worker",
|
||||
task_arg_name="Name",
|
||||
task_arg_data="Data",
|
||||
)
|
||||
)
|
||||
|
||||
# Format the string (elements)
|
||||
for task in sorted(tasks, key=lambda i: i.get("type", None)):
|
||||
task_list_output.append(
|
||||
"{bold}{task_id: <{task_id_length}} {task_type: <{task_type_length}} \
|
||||
{task_worker: <{task_worker_length}} \
|
||||
{task_arg_name: <{task_arg_name_length}} \
|
||||
{task_arg_data: <{task_arg_data_length}}{end_bold}".format(
|
||||
task_id_length=task_id_length,
|
||||
task_type_length=task_type_length,
|
||||
task_worker_length=task_worker_length,
|
||||
task_arg_name_length=task_arg_name_length,
|
||||
task_arg_data_length=task_arg_data_length,
|
||||
bold="",
|
||||
end_bold="",
|
||||
task_id=task["id"],
|
||||
task_type=task["type"],
|
||||
task_worker=task["worker"],
|
||||
task_arg_name=str(task["kwargs"][0]["name"]),
|
||||
task_arg_data=str(task["kwargs"][0]["data"]),
|
||||
)
|
||||
)
|
||||
for arg in task["kwargs"][1:]:
|
||||
task_list_output.append(
|
||||
"{bold}{task_id: <{task_id_length}} {task_type: <{task_type_length}} \
|
||||
{task_worker: <{task_worker_length}} \
|
||||
{task_arg_name: <{task_arg_name_length}} \
|
||||
{task_arg_data: <{task_arg_data_length}}{end_bold}".format(
|
||||
task_id_length=task_id_length,
|
||||
task_type_length=task_type_length,
|
||||
task_worker_length=task_worker_length,
|
||||
task_arg_name_length=task_arg_name_length,
|
||||
task_arg_data_length=task_arg_data_length,
|
||||
bold="",
|
||||
end_bold="",
|
||||
task_id="",
|
||||
task_type="",
|
||||
task_worker="",
|
||||
task_arg_name=str(arg["name"]),
|
||||
task_arg_data=str(arg["data"]),
|
||||
)
|
||||
)
|
||||
|
||||
return "\n".join(task_list_output)
|
||||
|
||||
|
||||
def cli_connection_list_format_pretty(CLI_CONFIG, data):
|
||||
"""
|
||||
Pretty format the output of cli_connection_list
|
||||
|
@ -724,11 +877,3 @@ def cli_provisioner_profile_list_format_pretty(CLI_CONFIG, data):
|
|||
"""
|
||||
|
||||
return provisioner_format_profile_list(CLI_CONFIG, data)
|
||||
|
||||
|
||||
def cli_provisioner_status_format_pretty(CLI_CONFIG, data):
|
||||
"""
|
||||
Pretty format the output of cli_provisioner_status
|
||||
"""
|
||||
|
||||
return provisioner_format_task_status(CLI_CONFIG, data)
|
||||
|
|
|
@ -1783,158 +1783,3 @@ def format_list_profile(config, profile_data):
|
|||
)
|
||||
|
||||
return "\n".join(profile_list_output)
|
||||
|
||||
|
||||
def format_list_task(config, task_data):
|
||||
if not isinstance(task_data, list):
|
||||
job_state = task_data["state"]
|
||||
if job_state == "RUNNING":
|
||||
retdata = "Job state: RUNNING\nStage: {}/{}\nStatus: {}".format(
|
||||
task_data["current"], task_data["total"], task_data["status"]
|
||||
)
|
||||
elif job_state == "FAILED":
|
||||
retdata = "Job state: FAILED\nStatus: {}".format(task_data["status"])
|
||||
elif job_state == "COMPLETED":
|
||||
retdata = "Job state: COMPLETED\nStatus: {}".format(task_data["status"])
|
||||
else:
|
||||
retdata = "Job state: {}\nStatus: {}".format(
|
||||
task_data["state"], task_data["status"]
|
||||
)
|
||||
return retdata
|
||||
|
||||
task_list_output = []
|
||||
|
||||
# Determine optimal column widths
|
||||
task_id_length = 7
|
||||
task_type_length = 7
|
||||
task_worker_length = 7
|
||||
task_vm_name_length = 5
|
||||
task_vm_profile_length = 8
|
||||
task_vm_define_length = 8
|
||||
task_vm_start_length = 7
|
||||
|
||||
for task in task_data:
|
||||
# task_id column
|
||||
_task_id_length = len(str(task["id"])) + 1
|
||||
if _task_id_length > task_id_length:
|
||||
task_id_length = _task_id_length
|
||||
# task_worker column
|
||||
_task_worker_length = len(str(task["worker"])) + 1
|
||||
if _task_worker_length > task_worker_length:
|
||||
task_worker_length = _task_worker_length
|
||||
# task_type column
|
||||
_task_type_length = len(str(task["type"])) + 1
|
||||
if _task_type_length > task_type_length:
|
||||
task_type_length = _task_type_length
|
||||
# task_vm_name column
|
||||
_task_vm_name_length = len(str(task["vm_name"])) + 1
|
||||
if _task_vm_name_length > task_vm_name_length:
|
||||
task_vm_name_length = _task_vm_name_length
|
||||
# task_vm_profile column
|
||||
_task_vm_profile_length = len(str(task["vm_profile"])) + 1
|
||||
if _task_vm_profile_length > task_vm_profile_length:
|
||||
task_vm_profile_length = _task_vm_profile_length
|
||||
# task_vm_define column
|
||||
_task_vm_define_length = len(str(task["vm_define"])) + 1
|
||||
if _task_vm_define_length > task_vm_define_length:
|
||||
task_vm_define_length = _task_vm_define_length
|
||||
# task_vm_start column
|
||||
_task_vm_start_length = len(str(task["vm_start"])) + 1
|
||||
if _task_vm_start_length > task_vm_start_length:
|
||||
task_vm_start_length = _task_vm_start_length
|
||||
|
||||
# Format the string (header)
|
||||
task_list_output.append(
|
||||
"{bold}{task_header: <{task_header_length}} {vms_header: <{vms_header_length}}{end_bold}".format(
|
||||
bold=ansiprint.bold(),
|
||||
end_bold=ansiprint.end(),
|
||||
task_header_length=task_id_length
|
||||
+ task_type_length
|
||||
+ task_worker_length
|
||||
+ 2,
|
||||
vms_header_length=task_vm_name_length
|
||||
+ task_vm_profile_length
|
||||
+ task_vm_define_length
|
||||
+ task_vm_start_length
|
||||
+ 3,
|
||||
task_header="Tasks "
|
||||
+ "".join(
|
||||
[
|
||||
"-"
|
||||
for _ in range(
|
||||
6, task_id_length + task_type_length + task_worker_length + 1
|
||||
)
|
||||
]
|
||||
),
|
||||
vms_header="VM Details "
|
||||
+ "".join(
|
||||
[
|
||||
"-"
|
||||
for _ in range(
|
||||
11,
|
||||
task_vm_name_length
|
||||
+ task_vm_profile_length
|
||||
+ task_vm_define_length
|
||||
+ task_vm_start_length
|
||||
+ 2,
|
||||
)
|
||||
]
|
||||
),
|
||||
)
|
||||
)
|
||||
|
||||
task_list_output.append(
|
||||
"{bold}{task_id: <{task_id_length}} {task_type: <{task_type_length}} \
|
||||
{task_worker: <{task_worker_length}} \
|
||||
{task_vm_name: <{task_vm_name_length}} \
|
||||
{task_vm_profile: <{task_vm_profile_length}} \
|
||||
{task_vm_define: <{task_vm_define_length}} \
|
||||
{task_vm_start: <{task_vm_start_length}}{end_bold}".format(
|
||||
task_id_length=task_id_length,
|
||||
task_type_length=task_type_length,
|
||||
task_worker_length=task_worker_length,
|
||||
task_vm_name_length=task_vm_name_length,
|
||||
task_vm_profile_length=task_vm_profile_length,
|
||||
task_vm_define_length=task_vm_define_length,
|
||||
task_vm_start_length=task_vm_start_length,
|
||||
bold=ansiprint.bold(),
|
||||
end_bold=ansiprint.end(),
|
||||
task_id="Job ID",
|
||||
task_type="Status",
|
||||
task_worker="Worker",
|
||||
task_vm_name="Name",
|
||||
task_vm_profile="Profile",
|
||||
task_vm_define="Define?",
|
||||
task_vm_start="Start?",
|
||||
)
|
||||
)
|
||||
|
||||
# Format the string (elements)
|
||||
for task in sorted(task_data, key=lambda i: i.get("type", None)):
|
||||
task_list_output.append(
|
||||
"{bold}{task_id: <{task_id_length}} {task_type: <{task_type_length}} \
|
||||
{task_worker: <{task_worker_length}} \
|
||||
{task_vm_name: <{task_vm_name_length}} \
|
||||
{task_vm_profile: <{task_vm_profile_length}} \
|
||||
{task_vm_define: <{task_vm_define_length}} \
|
||||
{task_vm_start: <{task_vm_start_length}}{end_bold}".format(
|
||||
task_id_length=task_id_length,
|
||||
task_type_length=task_type_length,
|
||||
task_worker_length=task_worker_length,
|
||||
task_vm_name_length=task_vm_name_length,
|
||||
task_vm_profile_length=task_vm_profile_length,
|
||||
task_vm_define_length=task_vm_define_length,
|
||||
task_vm_start_length=task_vm_start_length,
|
||||
bold="",
|
||||
end_bold="",
|
||||
task_id=task["id"],
|
||||
task_type=task["type"],
|
||||
task_worker=task["worker"],
|
||||
task_vm_name=task["vm_name"],
|
||||
task_vm_profile=task["vm_profile"],
|
||||
task_vm_define=task["vm_define"],
|
||||
task_vm_start=task["vm_start"],
|
||||
)
|
||||
)
|
||||
|
||||
return "\n".join(task_list_output)
|
||||
|
|
Loading…
Reference in New Issue