mirror of
https://github.com/frappe/bench.git
synced 2025-01-09 16:36:25 +00:00
Merge pull request #110 from frappe/v5-upgrade
Version upgrade on switching branches
This commit is contained in:
commit
fd1848c22f
39
bench/app.py
39
bench/app.py
@ -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',
|
||||
|
15
bench/cli.py
15
bench/cli.py
@ -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'
|
||||
|
Loading…
Reference in New Issue
Block a user