Use HOT instead of CFN heat template format

New Heaet features will get added to HOT but possibly not the
older CFN format, and it's easier to make the change now than
later.

The only code change is in heat_stack to look for 'resources'
instead of 'Resources'; all other changes are to the Heat template
sections within PL class definitions. Keys are lower-cased and
in some cases changed to match HOT (e.g. key_name instead of KeyName),
and sections specifying Heat resources add heat_template_version to
the template.

Implements blueprint replace-cfn-templates-with-hot

Change-Id: If4d34cd25a4e964d7555fedf218512d5c0f5615c
This commit is contained in:
Steve McLellan 2014-05-07 12:34:43 -05:00
parent b91a329625
commit b7626aa140
4 changed files with 61 additions and 52 deletions

View File

@ -61,18 +61,19 @@ Workflow:
- $.ensureNetworkConfigured() - $.ensureNetworkConfigured()
- $portname: $instance.name + '-port-to-' + $.id() - $portname: $instance.name + '-port-to-' + $.id()
- $template: - $template:
Resources: heat_template_version: '2013-05-23'
resources:
$portname: $portname:
Type: 'OS::Neutron::Port' type: 'OS::Neutron::Port'
Properties: properties:
network_id: {Ref: $.net_res_name} network_id: { get_resource: $.net_res_name }
fixed_ips: [{subnet_id: {Ref: $.subnet_res_name}}] fixed_ips: [{ subnet_id: { get_resource: $.subnet_res_name } }]
security_groups: security_groups:
- Ref: $securityGroupName - get_resource: $securityGroupName
$instance.name: $instance.name:
Properties: properties:
NetworkInterfaces: networks:
- Ref: $portname - port: { get_resource: $portname }
- $.environment.stack.updateTemplate($template) - $.environment.stack.updateTemplate($template)
- If: $assignFloatingIp - If: $assignFloatingIp
@ -82,25 +83,23 @@ Workflow:
Then: Then:
- $fip_name: $instance.name + '-FloatingIP-' + $.id() - $fip_name: $instance.name + '-FloatingIP-' + $.id()
- $template: - $template:
Resources: resources:
$fip_name: $fip_name:
Type: 'OS::Neutron::FloatingIP' type: 'OS::Neutron::FloatingIP'
Properties: properties:
floating_network_id: $extNetId floating_network_id: $extNetId
$instance.name + '-FloatingIpAssoc-' + $.id(): $instance.name + '-FloatingIpAssoc-' + $.id():
Type: 'OS::Neutron::FloatingIPAssociation' type: 'OS::Neutron::FloatingIPAssociation'
Properties: properties:
floatingip_id: floatingip_id:
Ref: $fip_name get_resource: $fip_name
port_id: port_id:
Ref: $portname get_resource: $portname
Outputs: outputs:
$instance.name + '-FloatingIPaddress': $instance.name + '-FloatingIPaddress':
Value: value:
Fn::GetAtt: get_attr: [$fip_name, floating_ip_address]
- $fip_name description: Floating IP assigned
- floating_ip_address
Description: Floating IP assigned
- $.environment.stack.updateTemplate($template) - $.environment.stack.updateTemplate($template)
ensureNetworkConfigured: ensureNetworkConfigured:
@ -132,33 +131,36 @@ Workflow:
createNetwork: createNetwork:
Body: Body:
- $template: - $template:
Resources: heat_template_version: '2013-05-23'
resources:
$.net_res_name: $.net_res_name:
Type: 'OS::Neutron::Net' type: 'OS::Neutron::Net'
Properties: properties:
name: $.name name: $.name
- $.environment.stack.updateTemplate($template) - $.environment.stack.updateTemplate($template)
createSubnet: createSubnet:
Body: Body:
- $template: - $template:
Resources: heat_template_version: '2013-05-23'
resources:
$.subnet_res_name: $.subnet_res_name:
Type: 'OS::Neutron::Subnet' type: 'OS::Neutron::Subnet'
Properties: properties:
network_id: {Ref: $.net_res_name} network_id: { get_resource: $.net_res_name }
ip_version: 4 ip_version: 4
dns_nameservers: [$.dnsNameserver] dns_nameservers: [ $.dnsNameserver ]
cidr: $.subnetCidr cidr: $.subnetCidr
- $.environment.stack.updateTemplate($template) - $.environment.stack.updateTemplate($template)
createRouterInterface: createRouterInterface:
Body: Body:
- $template: - $template:
Resources: heat_template_version: '2013-05-23'
resources:
$.name + '-ri-' + $.id(): $.name + '-ri-' + $.id():
Type: 'OS::Neutron::RouterInterface' type: 'OS::Neutron::RouterInterface'
Properties: properties:
router_id: $.externalRouterId router_id: $.externalRouterId
subnet_id: {Ref: $.subnet_res_name} subnet_id: { get_resource: $.subnet_res_name }
- $.environment.stack.updateTemplate($template) - $.environment.stack.updateTemplate($template)

View File

@ -36,10 +36,11 @@ Workflow:
- $stack: $.environment.stack - $stack: $.environment.stack
- $template: - $template:
Resources: heat_template_version: '2013-05-23'
resources:
$groupName: $groupName:
Type: 'OS::Neutron::SecurityGroup' type: 'OS::Neutron::SecurityGroup'
Properties: properties:
description: format('Composite security group of Murano environment {0}', $.environment.name) description: format('Composite security group of Murano environment {0}', $.environment.name)
rules: rules:
- port_range_min: null - port_range_min: null
@ -56,10 +57,10 @@ Workflow:
)) ))
- $template: - $template:
Resources: resources:
$groupName: $groupName:
Type: 'OS::Neutron::SecurityGroup' type: 'OS::Neutron::SecurityGroup'
Properties: properties:
rules: $ingress rules: $ingress
- $.environment.stack.updateTemplate($template) - $.environment.stack.updateTemplate($template)

View File

@ -69,20 +69,22 @@ Workflow:
- $userData: $.prepareUserData() - $userData: $.prepareUserData()
- $template: - $template:
Resources: heat_template_version: '2013-05-23'
resources:
$.name: $.name:
Type: 'AWS::EC2::Instance' type: 'OS::Nova::Server'
Properties: properties:
InstanceType: $.flavor flavor: $.flavor
ImageId: $.image image: $.image
UserData: $userData user_data: $userData
KeyName: $.keyname key_name: $.keyname
Outputs: outputs:
format('{0}-PublicIp', $.name): format('{0}-PublicIp', $.name):
Value: description: format('Public IP assigned to {0} instance', $.name)
- Fn::GetAtt: [$.name, PublicIp] value:
get_attr: [$.name, PublicIp]
- $.environment.stack.updateTemplate($template) - $.environment.stack.updateTemplate($template)
- $.environment.stack.push() - $.environment.stack.push()
- $outputs: $.environment.stack.output() - $outputs: $.environment.stack.output()

View File

@ -165,7 +165,9 @@ class HeatStack(murano_object.MuranoObject):
current_status = self._get_status() current_status = self._get_status()
if current_status == 'NOT_FOUND': if current_status == 'NOT_FOUND':
if self._template.get('Resources'): # For now, allow older CFN style templates as well, but this
# should be removed to avoid mixing them
if 'resources' in self._template or 'Resources' in self._template:
self._heat_client.stacks.create( self._heat_client.stacks.create(
stack_name=self._name, stack_name=self._name,
parameters=self._parameters, parameters=self._parameters,
@ -175,7 +177,9 @@ class HeatStack(murano_object.MuranoObject):
self._wait_state( self._wait_state(
lambda status: status == 'CREATE_COMPLETE') lambda status: status == 'CREATE_COMPLETE')
else: else:
if self._template.get('Resources'): # For now, allow older CFN style templates as well, but this
# should be removed to avoid mixing them
if 'resources' in self._template or 'Resources' in self._template:
self._heat_client.stacks.update( self._heat_client.stacks.update(
stack_id=self._name, stack_id=self._name,
parameters=self._parameters, parameters=self._parameters,