Add support for test mode to keystone_policy
Change-Id: Iedcad8254e5a482a31da6397fc60152ce3f4bd6b
Closes-Issue: PROD-21233
diff --git a/_states/keystone_policy.py b/_states/keystone_policy.py
index e7a4a6a..ceede27 100644
--- a/_states/keystone_policy.py
+++ b/_states/keystone_policy.py
@@ -32,7 +32,7 @@
def rule_present(name, rule, path, **kwargs):
'''
Ensures that the policy rule exists
-
+
:param name: Rule name
:param rule: Rule
:param path: Path to policy file
@@ -44,17 +44,25 @@
'comment': 'Rule "{0}" already exists and is in correct state'.format(name)}
rule_check = __salt__['keystone_policy.rule_get'](name, path, **kwargs)
if not rule_check:
- __salt__['keystone_policy.rule_set'](name, rule, path, **kwargs)
- ret['comment'] = 'Rule {0} has been created'.format(name)
- ret['changes']['Rule'] = 'Rule %s: "%s" has been created' % (name, rule)
+ if __opts__.get('test'):
+ ret['result'] = None
+ ret['comment'] = 'Rule {0} will be created'.format(name)
+ else:
+ __salt__['keystone_policy.rule_set'](name, rule, path, **kwargs)
+ ret['comment'] = 'Rule {0} has been created'.format(name)
+ ret['changes']['Rule'] = 'Rule %s: "%s" has been created' % (name, rule)
elif 'Error' in rule_check:
ret['comment'] = rule_check.get('Error')
ret['result'] = False
elif rule_check[name] != rule:
- __salt__['keystone_policy.rule_set'](name, rule, path, **kwargs)
- ret['comment'] = 'Rule %s has been changed' % (name,)
- ret['changes']['Old Rule'] = '%s: "%s"' % (name, rule_check[name])
- ret['changes']['New Rule'] = '%s: "%s"' % (name, rule)
+ if __opts__.get('test'):
+ ret['result'] = None
+ ret['comment'] = 'Rule %s will be changed' % (name,)
+ else:
+ __salt__['keystone_policy.rule_set'](name, rule, path, **kwargs)
+ ret['comment'] = 'Rule %s has been changed' % (name,)
+ ret['changes']['Old Rule'] = '%s: "%s"' % (name, rule_check[name])
+ ret['changes']['New Rule'] = '%s: "%s"' % (name, rule)
return ret
@@ -71,9 +79,13 @@
'comment': 'Rule "{0}" is already absent'.format(name)}
rule_check = __salt__['keystone_policy.rule_get'](name, path, **kwargs)
if rule_check:
- __salt__['keystone_policy.rule_delete'](name, path, **kwargs)
- ret['comment'] = 'Rule {0} has been deleted'.format(name)
- ret['changes']['Rule'] = 'Rule %s: "%s" has been deleted' % (name, rule_check[name])
+ if __opts__.get('test'):
+ ret['result'] = None
+ ret['comment'] = 'Rule {0} will be deleted'.format(name)
+ else
+ __salt__['keystone_policy.rule_delete'](name, path, **kwargs)
+ ret['comment'] = 'Rule {0} has been deleted'.format(name)
+ ret['changes']['Rule'] = 'Rule %s: "%s" has been deleted' % (name, rule_check[name])
elif 'Error' in rule_check:
ret['comment'] = rule_check.get('Error')
ret['result'] = False