os_volume: Modify existing volume (#54905)

* add support for: volume resize, check_mode and diff

* add changelog fragment
This commit is contained in:
Andreas Calminder 2019-04-10 11:41:41 +02:00 committed by John R Barker
parent 44c2061c70
commit 7adfb1f714
2 changed files with 74 additions and 6 deletions

View file

@ -0,0 +1,2 @@
minor_changes:
- "add support for extending volumes in os_volume, also add module support for check_mode and diff"

View file

@ -103,10 +103,62 @@ from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.openstack import openstack_full_argument_spec, openstack_module_kwargs, openstack_cloud_from_module from ansible.module_utils.openstack import openstack_full_argument_spec, openstack_module_kwargs, openstack_cloud_from_module
def _needs_update(module, volume):
'''
check for differences in updatable values, at the moment
openstacksdk only supports extending the volume size, this
may change in the future.
:returns: bool
'''
compare_simple = ['size']
for k in compare_simple:
if module.params[k] is not None and module.params[k] != volume.get(k):
return True
return False
def _modify_volume(module, cloud):
'''
modify volume, the only modification to an existing volume
available at the moment is extending the size, this is
limited by the openstacksdk and may change whenever the
functionality is extended.
'''
volume = cloud.get_volume(module.params['display_name'])
diff = {'before': volume, 'after': ''}
size = module.params['size']
if size < volume.get('size'):
module.fail_json(
msg='Cannot shrink volumes, size: {0} < {1}'.format(size, volume.get('size'))
)
if not _needs_update(module, volume):
diff['after'] = volume
module.exit_json(changed=False, id=volume['id'], volume=volume, diff=diff)
if module.check_mode:
diff['after'] = volume
module.exit_json(changed=True, id=volume['id'], volume=volume, diff=diff)
cloud.volume.extend_volume(
volume.id,
size
)
diff['after'] = cloud.get_volume(module.params['display_name'])
module.exit_json(changed=True, id=volume['id'], volume=volume, diff=diff)
def _present_volume(module, cloud): def _present_volume(module, cloud):
if cloud.volume_exists(module.params['display_name']): if cloud.volume_exists(module.params['display_name']):
v = cloud.get_volume(module.params['display_name']) v = cloud.get_volume(module.params['display_name'])
if not _needs_update(module, v):
module.exit_json(changed=False, id=v['id'], volume=v) module.exit_json(changed=False, id=v['id'], volume=v)
_modify_volume(module, cloud)
diff = {'before': '', 'after': ''}
volume_args = dict( volume_args = dict(
size=module.params['size'], size=module.params['size'],
@ -132,28 +184,42 @@ def _present_volume(module, cloud):
if module.params['metadata']: if module.params['metadata']:
volume_args['metadata'] = module.params['metadata'] volume_args['metadata'] = module.params['metadata']
if module.check_mode:
diff['after'] = volume_args
module.exit_json(changed=True, id=None, volume=volume_args, diff=diff)
volume = cloud.create_volume( volume = cloud.create_volume(
wait=module.params['wait'], timeout=module.params['timeout'], wait=module.params['wait'], timeout=module.params['timeout'],
**volume_args) **volume_args)
module.exit_json(changed=True, id=volume['id'], volume=volume) diff['after'] = volume
module.exit_json(changed=True, id=volume['id'], volume=volume, diff=diff)
def _absent_volume(module, cloud, sdk): def _absent_volume(module, cloud, sdk):
changed = False changed = False
diff = {'before': '', 'after': ''}
if cloud.volume_exists(module.params['display_name']): if cloud.volume_exists(module.params['display_name']):
volume = cloud.get_volume(module.params['display_name'])
diff['before'] = volume
if module.check_mode:
module.exit_json(changed=True, diff=diff)
try: try:
changed = cloud.delete_volume(name_or_id=module.params['display_name'], changed = cloud.delete_volume(name_or_id=module.params['display_name'],
wait=module.params['wait'], wait=module.params['wait'],
timeout=module.params['timeout']) timeout=module.params['timeout'])
except sdk.exceptions.ResourceTimeout: except sdk.exceptions.ResourceTimeout:
module.exit_json(changed=changed) diff['after'] = volume
module.exit_json(changed=changed, diff=diff)
module.exit_json(changed=changed) module.exit_json(changed=changed, diff=diff)
def main(): def main():
argument_spec = openstack_full_argument_spec( argument_spec = openstack_full_argument_spec(
size=dict(default=None), size=dict(default=None, type='int'),
volume_type=dict(default=None), volume_type=dict(default=None),
display_name=dict(required=True, aliases=['name']), display_name=dict(required=True, aliases=['name']),
display_description=dict(default=None, aliases=['description']), display_description=dict(default=None, aliases=['description']),
@ -169,7 +235,7 @@ def main():
['image', 'snapshot_id', 'volume'], ['image', 'snapshot_id', 'volume'],
], ],
) )
module = AnsibleModule(argument_spec=argument_spec, **module_kwargs) module = AnsibleModule(argument_spec=argument_spec, supports_check_mode=True, **module_kwargs)
state = module.params['state'] state = module.params['state']