mirror of
https://github.com/frappe/bench.git
synced 2025-01-27 00:08:24 +00:00
updated migrate-env
This commit is contained in:
parent
300c3eea08
commit
0de8bf0ea7
@ -102,6 +102,17 @@ def tempdir():
|
|||||||
with tempchdir(dirpath, cleanup):
|
with tempchdir(dirpath, cleanup):
|
||||||
yield dirpath
|
yield dirpath
|
||||||
|
|
||||||
|
def copytree(source, destination, symlinks = False, ignore = None):
|
||||||
|
for f in os.listdir(source):
|
||||||
|
|
||||||
|
s = os.path.join(source, f)
|
||||||
|
d = os.path.join(destination, f)
|
||||||
|
|
||||||
|
if os.path.isdir(s):
|
||||||
|
shutil.copytree(s, d, symlinks, ignore)
|
||||||
|
else:
|
||||||
|
shutil.copy2(s, d)
|
||||||
|
|
||||||
@click.command('migrate-env')
|
@click.command('migrate-env')
|
||||||
@click.argument('python', type = click.Choice(['python2', 'python3']))
|
@click.argument('python', type = click.Choice(['python2', 'python3']))
|
||||||
@click.option('--no-backup', default = False, help = 'Do not backup the existing Virtual Environment')
|
@click.option('--no-backup', default = False, help = 'Do not backup the existing Virtual Environment')
|
||||||
@ -109,34 +120,9 @@ def migrate_env(python, no_backup = False):
|
|||||||
"""
|
"""
|
||||||
Migrate Virtual Environment to desired Python Version.
|
Migrate Virtual Environment to desired Python Version.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
python = which(python)
|
|
||||||
|
|
||||||
path = os.getcwd()
|
|
||||||
# This is with the assumption that a bench is set-up within path.
|
|
||||||
try:
|
try:
|
||||||
with tempdir() as dirpath:
|
# This is with the assumption that a bench is set-up within path.
|
||||||
virtualenv = which('virtualenv')
|
path = os.getcwd()
|
||||||
|
|
||||||
nvenv = 'env'
|
|
||||||
pvenv = osp.join(dirpath, nvenv)
|
|
||||||
|
|
||||||
exec_cmd('{virtualenv} --python {python} {pvenv}'.format(
|
|
||||||
virtualenv = virtualenv,
|
|
||||||
python = python,
|
|
||||||
pvenv = pvenv
|
|
||||||
), cwd = dirpath)
|
|
||||||
|
|
||||||
# TODO: Options
|
|
||||||
|
|
||||||
papps = osp.join(path, 'apps')
|
|
||||||
for app in os.listdir(papps):
|
|
||||||
papp = osp.join(papps, app)
|
|
||||||
if osp.isdir(papp) and osp.exists(osp.join(papp, 'setup.py')):
|
|
||||||
pip = osp.join(pvenv, 'bin', 'pip')
|
|
||||||
exec_cmd('{pip} install -e {app}'.format(
|
|
||||||
pip = pip, app = papp
|
|
||||||
))
|
|
||||||
|
|
||||||
# I know, bad name for a flag. Thanks, Ameya! :| - <achilles@frappe.io>
|
# I know, bad name for a flag. Thanks, Ameya! :| - <achilles@frappe.io>
|
||||||
if not no_backup:
|
if not no_backup:
|
||||||
@ -154,16 +140,44 @@ def migrate_env(python, no_backup = False):
|
|||||||
stamp = datetime.now().strftime('%Y%m%d_%H%M%S')
|
stamp = datetime.now().strftime('%Y%m%d_%H%M%S')
|
||||||
dest = osp.join(path, str(stamp))
|
dest = osp.join(path, str(stamp))
|
||||||
|
|
||||||
|
# WARNING: This is an archive, you might have to use virtualenv --relocate
|
||||||
|
# That's because virtualenv creates symlinks with shebangs pointing to executables.
|
||||||
|
|
||||||
|
# ...and shutil.copytree is a f*cking mess.
|
||||||
os.rename(source, dest)
|
os.rename(source, dest)
|
||||||
shutil.move(dest, target)
|
shutil.move(dest, target)
|
||||||
|
|
||||||
log.debug('Setting up a New Virtual {python} Environment'.format(
|
log.debug('Setting up a New Virtual {python} Environment'.format(
|
||||||
python = python
|
python = python
|
||||||
))
|
))
|
||||||
source = pvenv
|
|
||||||
target = path
|
|
||||||
|
|
||||||
shutil.move(source, target)
|
# Path to Python Executable (Basically $PYTHONPTH)
|
||||||
|
python = which(python)
|
||||||
|
|
||||||
|
|
||||||
|
virtualenv = which('virtualenv')
|
||||||
|
|
||||||
|
nvenv = 'env'
|
||||||
|
pvenv = osp.join(path, nvenv)
|
||||||
|
|
||||||
|
exec_cmd('{virtualenv} --python {python} {pvenv}'.format(
|
||||||
|
virtualenv = virtualenv,
|
||||||
|
python = python,
|
||||||
|
pvenv = pvenv
|
||||||
|
), cwd = path)
|
||||||
|
|
||||||
|
# TODO: Options
|
||||||
|
|
||||||
|
papps = osp.join(path, 'apps')
|
||||||
|
apps = ['frappe'] + [app for app in os.listdir(papps) if app != 'frappe']
|
||||||
|
|
||||||
|
for app in apps:
|
||||||
|
papp = osp.join(papps, app)
|
||||||
|
if osp.isdir(papp) and osp.exists(osp.join(papp, 'setup.py')):
|
||||||
|
pip = osp.join(pvenv, 'bin', 'pip')
|
||||||
|
exec_cmd('{pip} install -e {app}'.format(
|
||||||
|
pip = pip, app = papp
|
||||||
|
))
|
||||||
|
|
||||||
log.debug('Migration Successful to {python}'.format(
|
log.debug('Migration Successful to {python}'.format(
|
||||||
python = python
|
python = python
|
||||||
|
Loading…
x
Reference in New Issue
Block a user