Use the standard messaging in the package_update workbook

Update the package_update workbook to use the standard message sending
workflow. This workflow reduces the boilerplate that is copied between
workflows by defining the message structure, providing the retry logic
and ensuring the task on a "FAILED" message.

The workflow also offers optional persistence in Swift. If the plan name
is given to the workflow it will store the messages in a Swift container
named <plan_name>-messages.

Change-Id: Icad2846b43dec8032d9692daea390bffa7486dac
Related-Bug: #1757372
This commit is contained in:
Dougal Matthews 2018-06-18 16:36:58 +01:00
parent 5d44a0a016
commit 14c73ee0be

View File

@ -50,18 +50,13 @@ workflows:
message: <% task(update).result %> message: <% task(update).result %>
send_message: send_message:
action: zaqar.queue_post workflow: tripleo.messaging.v1.send
input: input:
queue_name: <% $.queue_name %> queue_name: <% $.queue_name %>
messages: type: <% execution().name %>
body:
type: tripleo.package_update.v1.package_update_plan
payload:
status: <% $.get('status', 'SUCCESS') %> status: <% $.get('status', 'SUCCESS') %>
message: <% $.get('message', '') %> message: <% $.get('message', '') %>
execution: <% execution() %> execution: <% execution() %>
on-success:
- fail: <% $.get('status') = "FAILED" %>
get_config: get_config:
input: input:
@ -83,18 +78,13 @@ workflows:
on-complete: send_message on-complete: send_message
send_message: send_message:
action: zaqar.queue_post workflow: tripleo.messaging.v1.send
input: input:
queue_name: <% $.queue_name %> queue_name: <% $.queue_name %>
messages: type: <% execution().name %>
body:
type: tripleo.package_update.v1.package_update_plan
payload:
status: <% $.get('status', 'SUCCESS') %> status: <% $.get('status', 'SUCCESS') %>
message: <% $.get('message', '') %> message: <% $.get('message', '') %>
execution: <% execution() %> execution: <% execution() %>
on-success:
- fail: <% $.get('status') = "FAILED" %>
update_nodes: update_nodes:
description: Take a container and perform an update nodes by nodes description: Take a container and perform an update nodes by nodes
@ -155,30 +145,25 @@ workflows:
output: <% task().result %> output: <% task().result %>
node_update_passed: node_update_passed:
on-success: notify_zaqar on-success: send_message
publish: publish:
status: SUCCESS status: SUCCESS
message: Updated nodes - <% $.nodes %> message: Updated nodes - <% $.nodes %>
node_update_failed: node_update_failed:
on-success: notify_zaqar on-success: send_message
publish: publish:
status: FAILED status: FAILED
message: Failed to update nodes - <% $.nodes %>, please see the logs. message: Failed to update nodes - <% $.nodes %>, please see the logs.
notify_zaqar: send_message:
action: zaqar.queue_post workflow: tripleo.messaging.v1.send
retry: count=5 delay=1
input: input:
queue_name: <% $.ansible_queue_name %> queue_name: <% $.ansible_queue_name %>
messages: type: <% execution().name %>
body: status: <% $.get('status', 'SUCCESS') %>
type: tripleo.package_update.v1.update_nodes message: <% $.get('message', '') %>
payload:
status: <% $.status %>
execution: <% execution() %> execution: <% execution() %>
on-success:
- fail: <% $.get('status') = "FAILED" %>
update_converge_plan: update_converge_plan:
description: Take a container and perform the converge for minor update description: Take a container and perform the converge for minor update
@ -205,18 +190,13 @@ workflows:
message: <% task(remove_noop).result %> message: <% task(remove_noop).result %>
send_message: send_message:
action: zaqar.queue_post workflow: tripleo.messaging.v1.send
input: input:
queue_name: <% $.queue_name %> queue_name: <% $.queue_name %>
messages: type: <% execution().name %>
body:
type: tripleo.package_update.v1.update_converge_plan
payload:
status: <% $.get('status', 'SUCCESS') %> status: <% $.get('status', 'SUCCESS') %>
message: <% $.get('message', '') %> message: <% $.get('message', '') %>
execution: <% execution() %> execution: <% execution() %>
on-success:
- fail: <% $.get('status') = "FAILED" %>
converge_upgrade_plan: converge_upgrade_plan:
description: Take a container and perform the converge step of a major upgrade description: Take a container and perform the converge step of a major upgrade
@ -245,18 +225,13 @@ workflows:
message: <% task(upgrade_converge).result %> message: <% task(upgrade_converge).result %>
send_message: send_message:
action: zaqar.queue_post workflow: tripleo.messaging.v1.send
input: input:
queue_name: <% $.queue_name %> queue_name: <% $.queue_name %>
messages: type: <% execution().name %>
body:
type: tripleo.major_upgrade.v1.converge_upgrade_plan
payload:
status: <% $.get('status', 'SUCCESS') %> status: <% $.get('status', 'SUCCESS') %>
message: <% $.get('message', '') %> message: <% $.get('message', '') %>
execution: <% execution() %> execution: <% execution() %>
on-success:
- fail: <% $.get('status') = "FAILED" %>
ffwd_upgrade_converge_plan: ffwd_upgrade_converge_plan:
description: ffwd-upgrade converge removes DeploymentSteps no-op from plan description: ffwd-upgrade converge removes DeploymentSteps no-op from plan
@ -283,15 +258,10 @@ workflows:
message: <% task(remove_noop).result %> message: <% task(remove_noop).result %>
send_message: send_message:
action: zaqar.queue_post workflow: tripleo.messaging.v1.send
input: input:
queue_name: <% $.queue_name %> queue_name: <% $.queue_name %>
messages: type: <% execution().name %>
body:
type: tripleo.package_update.v1.ffwd_upgrade_converge_plan
payload:
status: <% $.get('status', 'SUCCESS') %> status: <% $.get('status', 'SUCCESS') %>
message: <% $.get('message', '') %> message: <% $.get('message', '') %>
execution: <% execution() %> execution: <% execution() %>
on-success:
- fail: <% $.get('status') = "FAILED" %>