Merge pull request #689 from ansible/soft-require-virtualenv
Don't fail if virtualenv is not installed and we do not need to initialize the venv
This commit is contained in:
commit
2bc27f2d3f
1 changed files with 9 additions and 7 deletions
|
@ -98,7 +98,7 @@ options:
|
||||||
required: false
|
required: false
|
||||||
default: null
|
default: null
|
||||||
notes:
|
notes:
|
||||||
- Please note that virtualenv (U(http://www.virtualenv.org/)) must be installed on the remote host if the virtualenv parameter is specified.
|
- Please note that virtualenv (U(http://www.virtualenv.org/)) must be installed on the remote host if the virtualenv parameter is specified and the virtualenv needs to be initialized.
|
||||||
requirements: [ "virtualenv", "pip" ]
|
requirements: [ "virtualenv", "pip" ]
|
||||||
author: Matt Wright
|
author: Matt Wright
|
||||||
'''
|
'''
|
||||||
|
@ -252,12 +252,14 @@ def main():
|
||||||
|
|
||||||
if env:
|
if env:
|
||||||
env = os.path.expanduser(env)
|
env = os.path.expanduser(env)
|
||||||
virtualenv = os.path.expanduser(virtualenv_command)
|
|
||||||
if os.path.basename(virtualenv) == virtualenv:
|
|
||||||
virtualenv = module.get_bin_path(virtualenv_command, True)
|
|
||||||
if not os.path.exists(os.path.join(env, 'bin', 'activate')):
|
if not os.path.exists(os.path.join(env, 'bin', 'activate')):
|
||||||
if module.check_mode:
|
if module.check_mode:
|
||||||
module.exit_json(changed=True)
|
module.exit_json(changed=True)
|
||||||
|
|
||||||
|
virtualenv = os.path.expanduser(virtualenv_command)
|
||||||
|
if os.path.basename(virtualenv) == virtualenv:
|
||||||
|
virtualenv = module.get_bin_path(virtualenv_command, True)
|
||||||
|
|
||||||
if module.params['virtualenv_site_packages']:
|
if module.params['virtualenv_site_packages']:
|
||||||
cmd = '%s --system-site-packages %s' % (virtualenv, env)
|
cmd = '%s --system-site-packages %s' % (virtualenv, env)
|
||||||
else:
|
else:
|
||||||
|
@ -278,7 +280,7 @@ def main():
|
||||||
pip = _get_pip(module, env, module.params['executable'])
|
pip = _get_pip(module, env, module.params['executable'])
|
||||||
|
|
||||||
cmd = '%s %s' % (pip, state_map[state])
|
cmd = '%s %s' % (pip, state_map[state])
|
||||||
|
|
||||||
# If there's a virtualenv we want things we install to be able to use other
|
# If there's a virtualenv we want things we install to be able to use other
|
||||||
# installations that exist as binaries within this virtualenv. Example: we
|
# installations that exist as binaries within this virtualenv. Example: we
|
||||||
# install cython and then gevent -- gevent needs to use the cython binary,
|
# install cython and then gevent -- gevent needs to use the cython binary,
|
||||||
|
@ -308,7 +310,7 @@ def main():
|
||||||
cmd += ' %s' % _get_full_name(name, version)
|
cmd += ' %s' % _get_full_name(name, version)
|
||||||
elif requirements:
|
elif requirements:
|
||||||
cmd += ' -r %s' % requirements
|
cmd += ' -r %s' % requirements
|
||||||
|
|
||||||
this_dir = tempfile.gettempdir()
|
this_dir = tempfile.gettempdir()
|
||||||
if chdir:
|
if chdir:
|
||||||
this_dir = os.path.join(this_dir, chdir)
|
this_dir = os.path.join(this_dir, chdir)
|
||||||
|
@ -319,7 +321,7 @@ def main():
|
||||||
elif name.startswith('svn+') or name.startswith('git+') or \
|
elif name.startswith('svn+') or name.startswith('git+') or \
|
||||||
name.startswith('hg+') or name.startswith('bzr+'):
|
name.startswith('hg+') or name.startswith('bzr+'):
|
||||||
module.exit_json(changed=True)
|
module.exit_json(changed=True)
|
||||||
|
|
||||||
freeze_cmd = '%s freeze' % pip
|
freeze_cmd = '%s freeze' % pip
|
||||||
rc, out_pip, err_pip = module.run_command(freeze_cmd, cwd=this_dir)
|
rc, out_pip, err_pip = module.run_command(freeze_cmd, cwd=this_dir)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue