Fix parsing of pip output
This commit is contained in:
parent
74be5a40f9
commit
e2963c0e25
1 changed files with 19 additions and 16 deletions
|
@ -19,11 +19,6 @@
|
||||||
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
|
||||||
import tempfile
|
|
||||||
import re
|
|
||||||
import os
|
|
||||||
import sys
|
|
||||||
|
|
||||||
DOCUMENTATION = '''
|
DOCUMENTATION = '''
|
||||||
---
|
---
|
||||||
module: pip
|
module: pip
|
||||||
|
@ -46,8 +41,8 @@ options:
|
||||||
default: null
|
default: null
|
||||||
requirements:
|
requirements:
|
||||||
description:
|
description:
|
||||||
- The path to a pip requirements file, which should be local to the remote system.
|
- The path to a pip requirements file, which should be local to the remote system.
|
||||||
File can be specified as a relative path if using the chdir option.
|
File can be specified as a relative path if using the chdir option.
|
||||||
required: false
|
required: false
|
||||||
default: null
|
default: null
|
||||||
virtualenv:
|
virtualenv:
|
||||||
|
@ -186,6 +181,14 @@ EXAMPLES = '''
|
||||||
become: True
|
become: True
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
import tempfile
|
||||||
|
import re
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from ansible.module_utils.basic import AnsibleModule
|
||||||
|
|
||||||
|
|
||||||
def _get_cmd_options(module, cmd):
|
def _get_cmd_options(module, cmd):
|
||||||
thiscmd = cmd + " --help"
|
thiscmd = cmd + " --help"
|
||||||
rc, stdout, stderr = module.run_command(thiscmd)
|
rc, stdout, stderr = module.run_command(thiscmd)
|
||||||
|
@ -209,7 +212,8 @@ def _get_packages(module, pip, chdir):
|
||||||
'''Return results of pip command to get packages.'''
|
'''Return results of pip command to get packages.'''
|
||||||
# Try 'pip list' command first.
|
# Try 'pip list' command first.
|
||||||
command = '%s list' % pip
|
command = '%s list' % pip
|
||||||
rc, out, err = module.run_command(command, cwd=chdir)
|
lang_env = dict(LANG='C', LC_ALL='C', LC_MESSAGES='C')
|
||||||
|
rc, out, err = module.run_command(command, cwd=chdir, environ_update=lang_env)
|
||||||
|
|
||||||
# If there was an error (pip version too old) then use 'pip freeze'.
|
# If there was an error (pip version too old) then use 'pip freeze'.
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
|
@ -334,9 +338,8 @@ def main():
|
||||||
module.fail_json(msg="umask must be an octal integer",
|
module.fail_json(msg="umask must be an octal integer",
|
||||||
details=str(sys.exc_info()[1]))
|
details=str(sys.exc_info()[1]))
|
||||||
|
|
||||||
|
|
||||||
old_umask = None
|
old_umask = None
|
||||||
if umask != None:
|
if umask is not None:
|
||||||
old_umask = os.umask(umask)
|
old_umask = os.umask(umask)
|
||||||
try:
|
try:
|
||||||
if state == 'latest' and version is not None:
|
if state == 'latest' and version is not None:
|
||||||
|
@ -435,8 +438,10 @@ def main():
|
||||||
|
|
||||||
changed = False
|
changed = False
|
||||||
if name:
|
if name:
|
||||||
|
# Pip spits an upgrade notice to stdout that we have to get rid of
|
||||||
|
pkg_list = [p for p in out.split('\n') if not p.startswith('You are using') and not p.startswith('You should consider') and p]
|
||||||
for pkg in name:
|
for pkg in name:
|
||||||
is_present = _is_present(pkg, version, out.split('\n'), pkg_cmd)
|
is_present = _is_present(pkg, version, pkg_list, pkg_cmd)
|
||||||
if (state == 'present' and not is_present) or (state == 'absent' and is_present):
|
if (state == 'present' and not is_present) or (state == 'absent' and is_present):
|
||||||
changed = True
|
changed = True
|
||||||
break
|
break
|
||||||
|
@ -472,10 +477,8 @@ def main():
|
||||||
state=state, requirements=requirements, virtualenv=env,
|
state=state, requirements=requirements, virtualenv=env,
|
||||||
stdout=out, stderr=err)
|
stdout=out, stderr=err)
|
||||||
finally:
|
finally:
|
||||||
if old_umask != None:
|
if old_umask is not None:
|
||||||
os.umask(old_umask)
|
os.umask(old_umask)
|
||||||
|
|
||||||
# import module snippets
|
if __name__ == '__main__':
|
||||||
from ansible.module_utils.basic import *
|
main()
|
||||||
|
|
||||||
main()
|
|
||||||
|
|
Loading…
Reference in a new issue