Update handling of state changes

reviewable/pr18780/r1
Matt Wright 12 years ago
parent 46f962210a
commit d36d926bba

@ -27,6 +27,9 @@ def _find_supervisorctl():
if os.path.exists(e): if os.path.exists(e):
return e return e
def _is_present(name):
rc, out, err = _run('%s status' % _find_supervisorctl())
return name in out
def _is_running(name): def _is_running(name):
rc, out, err = _run('%s status %s' % (_find_supervisorctl(), name)) rc, out, err = _run('%s status %s' % (_find_supervisorctl(), name))
@ -44,7 +47,7 @@ def _run(cmd):
def main(): def main():
arg_spec = dict( arg_spec = dict(
name=dict(required=True), name=dict(required=True),
state=dict(required=True, choices=['started', 'restarted', 'stopped']) state=dict(required=True, choices=['present', 'started', 'restarted', 'stopped'])
) )
module = AnsibleModule(argument_spec=arg_spec) module = AnsibleModule(argument_spec=arg_spec)
@ -57,6 +60,20 @@ def main():
if SUPERVISORCTL is None: if SUPERVISORCTL is None:
module.fail_json(msg='supervisorctl is not installed') module.fail_json(msg='supervisorctl is not installed')
present = _is_present(name)
if state == 'present':
if not present:
_run('%s reread' % SUPERVISORCTL)
rc, out, err = _run('%s add %s' % (SUPERVISORCTL, name))
if '%s: added process group' % name in out:
module.exit_json(changed=True, name=name, state=state)
else:
module.fail_json(msg=out, name=name, state=state)
module.exit_json(changed=False, name=name, state=state)
running = _is_running(name) running = _is_running(name)
if running and state == 'started': if running and state == 'started':
@ -71,7 +88,7 @@ def main():
module.fail_json(msg=out) module.fail_json(msg=out)
elif running and state == 'restarted': elif running and state == 'restarted':
rc, out, err = _run('%s update' % SUPERVISORCTL) rc, out, err = _run('%s update %s' % (SUPERVISORCTL, name))
rc, out, err = _run('%s restart %s' % (SUPERVISORCTL, name)) rc, out, err = _run('%s restart %s' % (SUPERVISORCTL, name))
if '%s: stopped' % name in out and '%s: started' % name in out: if '%s: stopped' % name in out and '%s: started' % name in out:
@ -80,7 +97,6 @@ def main():
module.fail_json(msg=out) module.fail_json(msg=out)
elif not running and state == 'started': elif not running and state == 'started':
rc, out, err = _run('%s update' % SUPERVISORCTL)
rc, out, err = _run('%s start %s' % (SUPERVISORCTL, name)) rc, out, err = _run('%s start %s' % (SUPERVISORCTL, name))
if '%s: started' % name in out: if '%s: started' % name in out:

Loading…
Cancel
Save