2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-24 23:48:24 +00:00

Version upgrade on switching branches

This commit is contained in:
Pratik Vyas 2015-05-04 09:42:25 +05:30
parent 4999929869
commit d8f0147ef1
2 changed files with 37 additions and 17 deletions

View File

@ -90,12 +90,12 @@ def pull_all_apps(bench='.'):
logger.info('pulling {0}'.format(app))
exec_cmd("git pull {rebase} upstream {branch}".format(rebase=rebase, branch=get_current_branch(app_dir)), cwd=app_dir)
def is_version_upgrade(bench='.'):
def is_version_upgrade(bench='.', branch=None):
apps_dir = os.path.join(bench, 'apps')
frappe_dir = os.path.join(apps_dir, 'frappe')
fetch_upstream(frappe_dir)
upstream_version = get_upstream_version(frappe_dir)
upstream_version = get_upstream_version(frappe_dir, branch=branch)
if not upstream_version:
raise Exception("Current branch not in upstream")
@ -126,9 +126,11 @@ def get_current_version(repo_dir):
with open(os.path.join(repo_dir, 'setup.py')) as f:
return get_version_from_string(f.read())
def get_upstream_version(repo_dir):
def get_upstream_version(repo_dir, branch=None):
if not branch:
branch = get_current_branch(repo_dir)
try:
contents = subprocess.check_output(['git', 'show', 'upstream/{branch}:setup.py'.format(branch=get_current_branch(repo_dir))], cwd=repo_dir, stderr=subprocess.STDOUT)
contents = subprocess.check_output(['git', 'show', 'upstream/{branch}:setup.py'.format(branch=branch)], cwd=repo_dir, stderr=subprocess.STDOUT)
except subprocess.CalledProcessError, e:
if "Invalid object" in e.output:
return None
@ -136,8 +138,14 @@ def get_upstream_version(repo_dir):
raise
return get_version_from_string(contents)
def switch_branch(branch, apps=None, bench='.'):
def switch_branch(branch, apps=None, bench='.', upgrade=False):
from .utils import update_requirements, backup_all_sites, patch_sites, build_assets, pre_upgrade, post_upgrade
import utils
apps_dir = os.path.join(bench, 'apps')
version_upgrade = is_version_upgrade(bench=bench, branch=branch)
if version_upgrade and not upgrade:
raise MajorVersionUpgradeException("Switching to {0} will cause upgrade from {1} to {2}".format(branch, version_upgrade[0], version_upgrade[1]), version_upgrade[0], version_upgrade[1])
if not apps:
apps = ('frappe', 'erpnext', 'shopping_cart')
for app in apps:
@ -146,14 +154,23 @@ def switch_branch(branch, apps=None, bench='.'):
exec_cmd("git fetch upstream", cwd=app_dir)
exec_cmd("git checkout {branch}".format(branch=branch), cwd=app_dir)
def switch_to_master(apps=None, bench='.'):
switch_branch('master', apps=apps, bench=bench)
if version_upgrade and upgrade:
pre_upgrade(version_upgrade[0], version_upgrade[1])
update_requirements()
reload(utils)
backup_all_sites()
patch_sites()
build_assets()
post_upgrade(version_upgrade[0], version_upgrade[1])
def switch_to_develop(apps=None, bench='.'):
switch_branch('develop', apps=apps, bench=bench)
def switch_to_master(apps=None, bench='.', upgrade=False):
switch_branch('master', apps=apps, bench=bench, upgrade=upgrade)
def switch_to_v4(apps=None, bench='.'):
switch_branch('v4.x.x', apps=apps, bench=bench)
def switch_to_develop(apps=None, bench='.', upgrade=False):
switch_branch('develop', apps=apps, bench=bench, upgrade=upgrade)
def switch_to_v4(apps=None, bench='.', upgrade=False):
switch_branch('v4.x.x', apps=apps, bench=bench, upgrade=upgrade)
def get_version_from_string(contents):
match = re.search(r"^(\s*%s\s*=\s*['\\\"])(.+?)(['\"])(?sm)" % 'version',

View File

@ -288,25 +288,28 @@ def migrate_3to4(path):
site=path))
@click.command('switch-to-master')
def _switch_to_master():
@click.option('--upgrade',flag_value=True, type=bool)
def _switch_to_master(upgrade=False):
"Switch frappe and erpnext to master branch"
switch_to_master()
switch_to_master(upgrade=upgrade)
print
print 'Switched to master'
print 'Please run `bench update --patch` to be safe from any differences in database schema'
@click.command('switch-to-develop')
def _switch_to_develop():
@click.option('--upgrade',flag_value=True, type=bool)
def _switch_to_develop(upgrade=False):
"Switch frappe and erpnext to develop branch"
switch_to_develop()
switch_to_develop(upgrade=upgrade)
print
print 'Switched to develop'
print 'Please run `bench update --patch` to be safe from any differences in database schema'
@click.command('switch-to-v4')
def _switch_to_v4():
@click.option('--upgrade',flag_value=True, type=bool)
def _switch_to_v4(upgrade=False):
"Switch frappe and erpnext to v4 branch"
switch_to_v4()
switch_to_v4(upgrade=upgrade)
print
print 'Switched to v4'
print 'Please run `bench update --patch` to be safe from any differences in database schema'