From fb1772b9d8f83db0a96e9ad27508713ba3c152dc Mon Sep 17 00:00:00 2001 From: AlanCoding Date: Thu, 12 Mar 2020 12:35:54 -0400 Subject: [PATCH] Improve error handling for users using the schema command --- docs/source/HISTORY.rst | 6 ++++++ docs/source/cli_ref/usage/WORKFLOWS.rst | 10 ++++++++++ tower_cli/resources/workflow.py | 11 +++++++---- 3 files changed, 23 insertions(+), 4 deletions(-) diff --git a/docs/source/HISTORY.rst b/docs/source/HISTORY.rst index 7da586ef..f874fd9c 100644 --- a/docs/source/HISTORY.rst +++ b/docs/source/HISTORY.rst @@ -1,6 +1,12 @@ Release History =============== +3.3.9 (2020-03-12) +------------------ + +- Improve error handling for template specification in workflow schema command. +- Pin the click library to avoid changing look and feel of output. + 3.3.8 (2020-01-14) ------------------ diff --git a/docs/source/cli_ref/usage/WORKFLOWS.rst b/docs/source/cli_ref/usage/WORKFLOWS.rst index 01e3731a..f1d9cd83 100644 --- a/docs/source/cli_ref/usage/WORKFLOWS.rst +++ b/docs/source/cli_ref/usage/WORKFLOWS.rst @@ -127,6 +127,16 @@ network with a tower-cli command after the constituent resources like the job templates and projects were created by preceding tower-cli commands. +Workflows Inside Workflows +~~~~~~~~~~~~~~~~~~~~~~~~~~ + +It is possible to have a workflow embedded inside of the schema of another +workflow. To do this, use the key "workflow". + +.. code:: yaml + + - workflow: Another workflow + Differences with Machine Formatted Schemas ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ diff --git a/tower_cli/resources/workflow.py b/tower_cli/resources/workflow.py index b469d1b8..6ec99149 100644 --- a/tower_cli/resources/workflow.py +++ b/tower_cli/resources/workflow.py @@ -45,16 +45,19 @@ def __init__(self, data, wfjt, include_id=False): else: node_attrs[fd] = data[fd] node_attrs['workflow_job_template'] = wfjt + ujt_ambiguity_msg = ( + 'You should provide exactly one of the attributes' + ' job_template, project, workflow, inventory_source, or unified_job_template.' + ) for ujt_name in ujt_attrs: if ujt_name not in node_attrs: continue if 'unified_job_template' not in node_attrs: node_attrs['unified_job_template'] = node_attrs.pop(ujt_name) else: - raise BadRequest( - 'You should not provide more than one of the attributes' - ' job_template, project and inventory_source.' - ) + raise BadRequest(ujt_ambiguity_msg) + if 'unified_job_template' not in node_attrs: + raise BadRequest(ujt_ambiguity_msg) self.unified_job_template = node_attrs.get('unified_job_template', None) self.node_attrs = node_attrs for rel in ['success_nodes', 'failure_nodes', 'always_nodes']: