mirror of
https://github.com/frappe/bench.git
synced 2025-01-24 23:48:24 +00:00
Merge pull request #889 from gavindsouza/easy-install-pip
fix(easy-install): install pip via pacman, minor fixes
This commit is contained in:
commit
5e7e2c33e3
@ -1,7 +1,6 @@
|
|||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
import os, sys, subprocess, getpass, json, multiprocessing, shutil, platform, warnings
|
import os, sys, subprocess, getpass, json, multiprocessing, shutil, platform, warnings
|
||||||
|
|
||||||
|
|
||||||
tmp_bench_repo = os.path.join('/', 'tmp', '.bench')
|
tmp_bench_repo = os.path.join('/', 'tmp', '.bench')
|
||||||
tmp_log_folder = os.path.join('/', 'tmp', 'logs')
|
tmp_log_folder = os.path.join('/', 'tmp', 'logs')
|
||||||
log_path = os.path.join(tmp_log_folder, 'install_bench.log')
|
log_path = os.path.join(tmp_log_folder, 'install_bench.log')
|
||||||
@ -105,36 +104,6 @@ def run_os_command(command_map):
|
|||||||
return success
|
return success
|
||||||
|
|
||||||
|
|
||||||
def install_pip():
|
|
||||||
if shutil.which('pip'):
|
|
||||||
run_os_command({
|
|
||||||
'pip': 'sudo -H pip install --upgrade setuptools cryptography pip'
|
|
||||||
})
|
|
||||||
|
|
||||||
else:
|
|
||||||
if not os.path.exists("get-pip.py"):
|
|
||||||
run_os_command({
|
|
||||||
'wget': 'wget -q https://bootstrap.pypa.io/get-pip.py'
|
|
||||||
})
|
|
||||||
|
|
||||||
success = run_os_command({
|
|
||||||
'python3': 'sudo python3 get-pip.py --force-reinstall'
|
|
||||||
})
|
|
||||||
|
|
||||||
if success:
|
|
||||||
dist_name, dist_version = get_distribution_info()
|
|
||||||
if dist_name == 'centos':
|
|
||||||
run_os_command({
|
|
||||||
'pip': 'sudo -H pip install --upgrade --ignore-installed requests'
|
|
||||||
})
|
|
||||||
else:
|
|
||||||
run_os_command({
|
|
||||||
'pip': 'sudo -H pip install --upgrade requests'
|
|
||||||
})
|
|
||||||
|
|
||||||
log("pip installed!", level=1)
|
|
||||||
|
|
||||||
|
|
||||||
def install_prerequisites():
|
def install_prerequisites():
|
||||||
# pre-requisites for bench repo cloning
|
# pre-requisites for bench repo cloning
|
||||||
run_os_command({
|
run_os_command({
|
||||||
@ -151,13 +120,13 @@ def install_prerequisites():
|
|||||||
install_package('curl')
|
install_package('curl')
|
||||||
install_package('wget')
|
install_package('wget')
|
||||||
install_package('git')
|
install_package('git')
|
||||||
install_pip()
|
install_package('pip3', 'python3-pip')
|
||||||
|
|
||||||
success = run_os_command({
|
success = run_os_command({
|
||||||
'pip': "sudo -H pip install --upgrade setuptools cryptography ansible==2.8.5 pip"
|
'python3': "sudo -H python3 -m pip install --upgrade setuptools cryptography ansible==2.8.5 pip"
|
||||||
})
|
})
|
||||||
|
|
||||||
if not success:
|
if not (success or shutil.which('ansible')):
|
||||||
could_not_install('Ansible')
|
could_not_install('Ansible')
|
||||||
|
|
||||||
|
|
||||||
@ -169,15 +138,16 @@ def is_sudo_user():
|
|||||||
return os.geteuid() == 0
|
return os.geteuid() == 0
|
||||||
|
|
||||||
|
|
||||||
def install_package(package):
|
def install_package(package, package_name=None):
|
||||||
if shutil.which(package):
|
if shutil.which(package):
|
||||||
log("{0} already installed!".format(package), level=1)
|
log("{0} already installed!".format(package), level=1)
|
||||||
else:
|
else:
|
||||||
log("Installing {0}...".format(package))
|
log("Installing {0}...".format(package))
|
||||||
|
package_name = package_name or package
|
||||||
success = run_os_command({
|
success = run_os_command({
|
||||||
'apt-get': ['sudo apt-get install -y {0}'.format(package)],
|
'apt-get': ['sudo apt-get install -y {0}'.format(package_name)],
|
||||||
'yum': ['sudo yum install -y {0}'.format(package)],
|
'yum': ['sudo yum install -y {0}'.format(package_name)],
|
||||||
'brew': ['brew install {0}'.format(package)]
|
'brew': ['brew install {0}'.format(package_name)]
|
||||||
})
|
})
|
||||||
if success:
|
if success:
|
||||||
log("{0} installed!".format(package), level=1)
|
log("{0} installed!".format(package), level=1)
|
||||||
@ -412,6 +382,10 @@ def parse_commandline_args():
|
|||||||
return args
|
return args
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
if sys.version[0] == '2':
|
||||||
|
if not raw_input("It is recommended to run this script with Python 3\nDo you still wish to continue? [Y/n]: ").lower() == "y":
|
||||||
|
sys.exit()
|
||||||
|
|
||||||
if not is_sudo_user():
|
if not is_sudo_user():
|
||||||
log("Please run this script as a non-root user with sudo privileges", level=3)
|
log("Please run this script as a non-root user with sudo privileges", level=3)
|
||||||
sys.exit()
|
sys.exit()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user