From e2545c97afd638609d0e4c89e76fa3e6d84d85a0 Mon Sep 17 00:00:00 2001 From: Achilles Rasquinha Date: Fri, 2 Feb 2018 18:48:58 +0530 Subject: [PATCH 1/2] Migrate from one Python Version to Another --- bench/commands/__init__.py | 100 ++++++++++++++++++++++++++++++++++++- bench/commands/setup.py | 1 - 2 files changed, 99 insertions(+), 2 deletions(-) diff --git a/bench/commands/__init__.py b/bench/commands/__init__.py index 0907f12d..c9427d4a 100755 --- a/bench/commands/__init__.py +++ b/bench/commands/__init__.py @@ -70,4 +70,102 @@ bench_command.add_command(remote_reset_url) bench_command.add_command(remote_urls) from bench.commands.install import install -bench_command.add_command(install) \ No newline at end of file +bench_command.add_command(install) + +# If you're scared with this code, contact me at +import contextlib +import os, shutil, tempfile + +@contextlib.contextmanager +def tempchdir(dirpath, cleanup): + import os.path as osp + basedir = os.getcwd() + os.chdir(osp.expanduser(dirpath)) + try: + yield + finally: + os.chdir(basedir) + cleanup() + +@contextlib.contextmanager +def tempdir(): + import tempfile + dirpath = tempfile.mkdtemp() + def cleanup(): + shutil.rmtree(dirpath) + with tempchdir(dirpath, cleanup): + yield dirpath + +@click.command('migrate-env') +@click.argument('python', type = click.Choice(['python2', 'python3'])) +@click.option('--from', 'from_', help = 'Path to virtual environment to migrate to') +@click.option('--no-backup', default = False, help = 'Do not backup the existing Virtual Environment') +def migrate_env(python, from_ = None, no_backup = False): + """ + Migrate Virtual Environment to desired Python Version. + """ + import os + import os.path as osp + + from bench.utils import which + python = which(python) + + path = os.getcwd() + # This is with the assumption that a bench is set-up within path. + try: + with tempdir() as dirpath: + virtualenv = which('virtualenv') + + nvenv = 'env' + pvenv = osp.join(dirpath, nvenv) + + from bench.utils import exec_cmd + 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! :| - + if not no_backup: + # Back, the f*ck up. + parch = osp.join(path, 'archived_envs') + if not osp.exists(parch): + os.mkdir(parch) + + # Simply moving. Thanks, Ameya. + # I'm keen to zip. + source = osp.join(path, 'env') + target = parch + + print('Backing up Virtual Environment') + from datetime import datetime + stamp = datetime.now().strftime('%Y%m%d_%H%M%S') + dest = osp.join(path, str(stamp)) + + os.rename(source, dest) + shutil.move(dest, target) + + print('Setting up a New Virtual Environment') + source = pvenv + target = path + + shutil.move(source, target) + + print('Migration Successful') + except: + print('Migration Error') + raise + +bench_command.add_command(migrate_env) \ No newline at end of file diff --git a/bench/commands/setup.py b/bench/commands/setup.py index 7360a148..d2736553 100755 --- a/bench/commands/setup.py +++ b/bench/commands/setup.py @@ -45,7 +45,6 @@ def setup_fonts(): from bench.utils import setup_fonts setup_fonts() - @click.command('production') @click.argument('user') @click.option('--yes', help='Yes to regeneration config', is_flag=True, default=False) From 300c3eea08fdab663fbabf98813a48325aaa1daa Mon Sep 17 00:00:00 2001 From: Achilles Rasquinha Date: Mon, 5 Feb 2018 11:03:11 +0530 Subject: [PATCH 2/2] Moved imports --- bench/commands/__init__.py | 40 +++++++++++++++++++++----------------- 1 file changed, 22 insertions(+), 18 deletions(-) diff --git a/bench/commands/__init__.py b/bench/commands/__init__.py index c9427d4a..d73aadea 100755 --- a/bench/commands/__init__.py +++ b/bench/commands/__init__.py @@ -1,5 +1,17 @@ import click +import os, shutil, tempfile +import os.path as osp +import contextlib +import logging + +from datetime import datetime + +from bench.utils import which, exec_cmd + +log = logging.getLogger(__name__) +log.setLevel(logging.ERROR) + def print_bench_version(ctx, param, value): """Prints current bench version""" if not value or ctx.resilient_parsing: @@ -72,13 +84,8 @@ bench_command.add_command(remote_urls) from bench.commands.install import install bench_command.add_command(install) -# If you're scared with this code, contact me at -import contextlib -import os, shutil, tempfile - @contextlib.contextmanager def tempchdir(dirpath, cleanup): - import os.path as osp basedir = os.getcwd() os.chdir(osp.expanduser(dirpath)) try: @@ -89,7 +96,6 @@ def tempchdir(dirpath, cleanup): @contextlib.contextmanager def tempdir(): - import tempfile dirpath = tempfile.mkdtemp() def cleanup(): shutil.rmtree(dirpath) @@ -98,16 +104,12 @@ def tempdir(): @click.command('migrate-env') @click.argument('python', type = click.Choice(['python2', 'python3'])) -@click.option('--from', 'from_', help = 'Path to virtual environment to migrate to') @click.option('--no-backup', default = False, help = 'Do not backup the existing Virtual Environment') -def migrate_env(python, from_ = None, no_backup = False): +def migrate_env(python, no_backup = False): """ Migrate Virtual Environment to desired Python Version. """ - import os - import os.path as osp - from bench.utils import which python = which(python) path = os.getcwd() @@ -118,8 +120,7 @@ def migrate_env(python, from_ = None, no_backup = False): nvenv = 'env' pvenv = osp.join(dirpath, nvenv) - - from bench.utils import exec_cmd + exec_cmd('{virtualenv} --python {python} {pvenv}'.format( virtualenv = virtualenv, python = python, @@ -149,23 +150,26 @@ def migrate_env(python, from_ = None, no_backup = False): source = osp.join(path, 'env') target = parch - print('Backing up Virtual Environment') - from datetime import datetime + log.debug('Backing up Virtual Environment') stamp = datetime.now().strftime('%Y%m%d_%H%M%S') dest = osp.join(path, str(stamp)) os.rename(source, dest) shutil.move(dest, target) - print('Setting up a New Virtual Environment') + log.debug('Setting up a New Virtual {python} Environment'.format( + python = python + )) source = pvenv target = path shutil.move(source, target) - print('Migration Successful') + log.debug('Migration Successful to {python}'.format( + python = python + )) except: - print('Migration Error') + log.debug('Migration Error') raise bench_command.add_command(migrate_env) \ No newline at end of file