Select bootstrap node by list index not name

Modify the syntax used to access the ResourceGroup attributes so we
always select the first node from the group, e.g even if the node
named "0" in the ResourceGroup nested stack has been removed due to
the removal policy.

Change-Id: I8b1c9538976a1518b220187a0034ad41a738d5a6
Closes-Bug: #1640449
This commit is contained in:
Steven Hardy 2016-11-09 11:35:03 +00:00
parent 465324cb6a
commit 390292e59e

View File

@ -231,8 +231,19 @@ resources:
config: {get_attr: [allNodesConfig, config_id]} config: {get_attr: [allNodesConfig, config_id]}
servers: {get_attr: [{{role.name}}, attributes, nova_server_resource]} servers: {get_attr: [{{role.name}}, attributes, nova_server_resource]}
input_values: input_values:
bootstrap_nodeid: {get_attr: [{{role.name}}, resource.0.hostname]} # Note we have to use yaql to look up the first hostname/ip in the
bootstrap_nodeid_ip: {get_attr: [{{role.name}}, resource.0.ip_address]} # list because heat path based attributes operate on the attribute
# inside the ResourceGroup, not the exposed list ref discussion in
# https://bugs.launchpad.net/heat/+bug/1640488
# The coalesce is needed because $.data is None during heat validation
bootstrap_nodeid:
yaql:
expression: coalesce($.data, []).first(null)
data: {get_attr: [{{role.name}}, hostname]}
bootstrap_nodeid_ip:
yaql:
expression: coalesce($.data, []).first(null)
data: {get_attr: [{{role.name}}, ip_address]}
{{role.name}}AllNodesValidationDeployment: {{role.name}}AllNodesValidationDeployment:
type: OS::Heat::StructuredDeployments type: OS::Heat::StructuredDeployments