summaryrefslogtreecommitdiff
path: root/cloud/azure
diff options
context:
space:
mode:
authorchouseknecht <chouseknecht@ansible.com>2016-04-27 10:48:20 -0400
committerchouseknecht <chouseknecht@ansible.com>2016-04-27 10:48:20 -0400
commita1cc951d6f56dc76086c7ad21456342f2642ebf6 (patch)
tree8c138591308dbeaff1ca05b5e6b3c8afa1c912a8 /cloud/azure
parent99f5e394add7f7525fd3cae8cff53ca86ebaaa2e (diff)
downloadansible-modules-extras-a1cc951d6f56dc76086c7ad21456342f2642ebf6.tar.gz
Updated per PR comments
Diffstat (limited to 'cloud/azure')
-rw-r--r--cloud/azure/azure_rm_deployment.py82
1 files changed, 38 insertions, 44 deletions
diff --git a/cloud/azure/azure_rm_deployment.py b/cloud/azure/azure_rm_deployment.py
index 022c240a..aeb2454e 100644
--- a/cloud/azure/azure_rm_deployment.py
+++ b/cloud/azure/azure_rm_deployment.py
@@ -32,6 +32,7 @@ options:
description:
- The resource group name to use or create to host the deployed template
required: true
+ default: null
location:
description:
- The geo-locations in which the resource group will be located.
@@ -42,6 +43,7 @@ options:
- If state is "present", template will be created. If state is "present" and if deployment exists, it will be
updated. If state is "absent", stack will be removed.
default: present
+ required: true
choices:
- present
- absent
@@ -50,25 +52,25 @@ options:
- A hash containing the templates inline. This parameter is mutually exclusive with 'template_link'.
Either one of them is required if "state" parameter is "present".
required: false
- default: None
+ default: null
template_link:
description:
- Uri of file containing the template body. This parameter is mutually exclusive with 'template'. Either one
of them is required if "state" parameter is "present".
required: false
- default: None
+ default: null
parameters:
description:
- A hash of all the required template variables for the deployment template. This parameter is mutually exclusive
with 'parameters_link'. Either one of them is required if "state" parameter is "present".
required: false
- default: None
+ default: null
parameters_link:
description:
- Uri of file containing the parameters body. This parameter is mutually exclusive with 'parameters'. Either
one of them is required if "state" parameter is "present".
required: false
- default: None
+ default: null
extends_documentation_fragment:
- azure
@@ -314,51 +316,40 @@ EXAMPLES = '''
'''
RETURN = '''
-msg:
- description: String indicating if the deployment was created or deleted
- returned: always
- type: string
- sample: "deployment created"
deployment:
description: Deployment details
type: dict
returned: always
- sample:{
- "group_name": "Test_Deployment",
- "id": "/subscriptions/3f7e29ba-24e0-42f6-8d9c-5149a14bda37/resourceGroups/Test_Deployment/providers/Microsoft.Resources/deployments/ansible-arm",
- "instances": [
- {
- "ips": [
- {
- "dns_settings": {
- "domain_name_label": "testvm9910001",
- "fqdn": "testvm9910001.westus.cloudapp.azure.com"
- },
- "id": "/subscriptions/3f7e29ba-24e0-42f6-8d9c-5149a14bda37/resourceGroups/Test_Deployment/providers/Microsoft.Network/publicIPAddresses/myPublicIP",
- "name": "myPublicIP",
- "public_ip": "13.91.99.232",
- "public_ip_allocation_method": "IPAllocationMethod.dynamic"
- }
- ],
- "vm_name": "MyUbuntuVM"
- }
- ],
- "name": "ansible-arm",
- "outputs": {
- "hostname": {
- "type": "String",
- "value": "testvm9910001.westus.cloudapp.azure.com"
- },
- "sshCommand": {
- "type": "String",
- "value": "ssh chouseknecht@testvm9910001.westus.cloudapp.azure.com"
- }
- }
- }
+ sample:
+ group_name:
+ description: Name of the resource group
+ type: string
+ returned: always
+ id:
+ description: The Azure ID of the deployment
+ type: string
+ returned: always
+ instances:
+ description: Provides the public IP addresses for each VM instance.
+ type: list
+ returned: always
+ name:
+ description: Name of the deployment
+ type: string
+ returned: always
+ outputs:
+ description: Dictionary of outputs received from the deployment
+ type: dict
+ returned: always
'''
-import time
-import yaml
+PREREQ_IMPORT_ERROR = None
+
+try:
+ import time
+ import yaml
+except ImportError as exc:
+ IMPORT_ERROR = "Error importing module prerequisites: %s" % exc
from ansible.module_utils.basic import *
from ansible.module_utils.azure_rm_common import *
@@ -427,6 +418,9 @@ class AzureRMDeploymentManager(AzureRMModuleBase):
def exec_module(self, **kwargs):
+ if PREREQ_IMPORT_ERROR:
+ self.fail(PREREQ_IMPORT_ERROR)
+
for key in self.module_arg_spec.keys() + ['tags']:
setattr(self, key, kwargs[key])
@@ -440,7 +434,7 @@ class AzureRMDeploymentManager(AzureRMModuleBase):
instances=self._get_instances(deployment)
)
self.results['changed'] = True
- self.results['msg'] = 'deployment created'
+ self.results['msg'] = 'deployment succeeded'
else:
if self.resource_group_exists(self.resource_group_name):
self.destroy_resource_group()