A raiz do problema geralmente são scripts desatualizados no subdiretório bin
(Linux) ou Scripts
(Windows). Vou explicar isso usando o problema que me encontrei como exemplo.
Eu tinha o virtualenv versão 1.10 instalado nos pacotes de sites do usuário (o fato de ele estar nos pacotes de sites do usuário e não no sytem site-packages é irrelevante aqui)
pdobrogost@host:~$ which virtualenv
/home/users/pdobrogost/.local/bin/virtualenv
pdobrogost@host:~$ virtualenv --version
1.10
Depois de atualizá-lo para a versão 1.11, recebi o seguinte erro:
pdobrogost@host:~$ virtualenv --version
Traceback (most recent call last):
File "/home/users/pdobrogost/.local/bin/virtualenv", line 5, in <module>
from pkg_resources import load_entry_point
File "build/bdist.linux-x86_64/egg/pkg_resources.py", line 2701, in <module>
return self.__dep_map
File "build/bdist.linux-x86_64/egg/pkg_resources.py", line 572, in resolve
if insert:
pkg_resources.DistributionNotFound: virtualenv==1.10
O arquivo /home/users/pdobrogost/.local/bin/virtualenv
mencionado na mensagem de erro ficou assim:
#!/opt/python/2.7.5/bin/python2.7
# EASY-INSTALL-ENTRY-SCRIPT: 'virtualenv==1.10','console_scripts','virtualenv'
__requires__ = 'virtualenv==1.10'
import sys
from pkg_resources import load_entry_point
if __name__ == '__main__':
sys.exit(
load_entry_point('virtualenv==1.10', 'console_scripts', 'virtualenv')()
)
Lá, vemos que o virtualenv
script não foi atualizado e ainda requer a versão 1.10 do virtualenv instalada anteriormente.
Agora, reinstalando o virtualenv como este
pdobrogost@host:~$ pip install --user --upgrade virtualenv
Downloading/unpacking virtualenv from https://pypi.python.org/packages/py27/v/virtualenv/virtualenv-1.11.1-py27-none-any.whl#md5=265770b61de41d34d2e9fdfddcdf034c
Using download cache from /home/users/pdobrogost/.pip_download_cache/https%3A%2F%2Fpypi.python.org%2Fpackages%2Fpy27%2Fv%2Fvirtualenv%2Fvirtualenv-1.11.1-py27-none-any.whl
Installing collected packages: virtualenv
Successfully installed virtualenv
Cleaning up...
não ajuda (nem pip install --user --upgrade --force-reinstall virtualenv
) porque o script /home/users/pdobrogost/.local/bin/virtualenv
permanece inalterado.
A única maneira de corrigir isso foi removendo manualmente os scripts virtualenv * da /home/users/pdobrogost/.local/bin/
pasta e instalando o virtualenv novamente. Depois disso, os scripts recém-gerados se referem à versão apropriada do pacote:
pdobrogost@host:~$ virtualenv --version
1.11