fix for special case of last element of url (#43354)

* fix for special case of last element of url

* improved version

* fixed mistake

* adding appropriate test

* fix problem

* just fixed task name
This commit is contained in:
Zim Kalinowski 2018-07-31 16:31:08 +08:00 committed by GitHub
parent c344a94846
commit c8fcbdef71
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 59 additions and 16 deletions

View file

@ -210,6 +210,7 @@ class AzureRMResource(AzureRMModuleBase):
self.status_code.append(204)
if self.url is None:
orphan = None
rargs = dict()
rargs['subscription'] = self.subscription_id
rargs['resource_group'] = self.resource_group
@ -217,16 +218,27 @@ class AzureRMResource(AzureRMModuleBase):
rargs['namespace'] = "Microsoft." + self.provider
else:
rargs['namespace'] = self.provider
rargs['type'] = self.resource_type
rargs['name'] = self.resource_name
for i in range(len(self.subresource)):
rargs['child_namespace_' + str(i + 1)] = self.subresource[i].get('namespace', None)
rargs['child_type_' + str(i + 1)] = self.subresource[i].get('type', None)
rargs['child_name_' + str(i + 1)] = self.subresource[i].get('name', None)
if self.resource_type is not None and self.resource_name is not None:
rargs['type'] = self.resource_type
rargs['name'] = self.resource_name
for i in range(len(self.subresource)):
resource_ns = self.subresource[i].get('namespace', None)
resource_type = self.subresource[i].get('type', None)
resource_name = self.subresource[i].get('name', None)
if resource_type is not None and resource_name is not None:
rargs['child_namespace_' + str(i + 1)] = resource_ns
rargs['child_type_' + str(i + 1)] = resource_type
rargs['child_name_' + str(i + 1)] = resource_name
else:
orphan = resource_type
else:
orphan = self.resource_type
self.url = resource_id(**rargs)
if orphan is not None:
self.url += '/' + orphan
query_parameters = {}
query_parameters['api-version'] = self.api_version

View file

@ -152,6 +152,7 @@ class AzureRMResourceFacts(AzureRMModuleBase):
base_url=self._cloud_environment.endpoints.resource_manager)
if self.url is None:
orphan = None
rargs = dict()
rargs['subscription'] = self.subscription_id
rargs['resource_group'] = self.resource_group
@ -159,19 +160,27 @@ class AzureRMResourceFacts(AzureRMModuleBase):
rargs['namespace'] = "Microsoft." + self.provider
else:
rargs['namespace'] = self.provider
rargs['type'] = self.resource_type
rargs['name'] = self.resource_name
for i in range(len(self.subresource)):
rargs['child_namespace_' + str(i + 1)] = self.subresource[i].get('namespace', None)
rargs['child_type_' + str(i + 1)] = self.subresource[i].get('type', None)
rargs['child_name_' + str(i + 1)] = self.subresource[i].get('name', None)
if self.resource_type is not None and self.resource_name is not None:
rargs['type'] = self.resource_type
rargs['name'] = self.resource_name
for i in range(len(self.subresource)):
resource_ns = self.subresource[i].get('namespace', None)
resource_type = self.subresource[i].get('type', None)
resource_name = self.subresource[i].get('name', None)
if resource_type is not None and resource_name is not None:
rargs['child_namespace_' + str(i + 1)] = resource_ns
rargs['child_type_' + str(i + 1)] = resource_type
rargs['child_name_' + str(i + 1)] = resource_name
else:
orphan = resource_type
else:
orphan = self.resource_type
self.url = resource_id(**rargs)
# this is to fix a problem with resource_id implementation, when resource_name is not specified
if self.resource_type is not None and self.resource_name is None:
self.url += '/' + self.resource_type
if orphan is not None:
self.url += '/' + orphan
self.results['url'] = self.url

View file

@ -1,6 +1,7 @@
- name: Prepare random number
set_fact:
nsgname: "{{ resource_group | hash('md5') | truncate(7, True, '') }}{{ 1000 | random }}"
storageaccountname: "stacc{{ resource_group | hash('md5') | truncate(7, True, '') }}{{ 1000 | random }}"
run_once: yes
- name: Call REST API
@ -54,7 +55,6 @@
assert:
that: output.changed
- name: Try to get information about account
azure_rm_resource_facts:
api_version: '2018-02-01'
@ -63,3 +63,25 @@
resource_type: networksecuritygroups
resource_name: "{{ nsgname }}"
register: output
- name: Create storage account for Registry
azure_rm_storageaccount:
resource_group: "{{ resource_group }}"
name: "{{ storageaccountname }}"
type: Standard_LRS
- name: Try to storage keys -- special case when subresource part has no name
azure_rm_resource:
resource_group: "{{ resource_group }}"
provider: storage
resource_type: storageAccounts
resource_name: "{{ storageaccountname }}"
subresource:
- type: listkeys
api_version: '2018-03-01-preview'
method: POST
register: keys
- name: Assert that key was returned
assert:
that: keys['response']['keys'][0]['value'] | length > 0