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

added app argument to compare repo and app

This commit is contained in:
Revant Nandgaonkar 2016-05-17 18:40:21 +05:30 committed by Anand Doshi
parent 08e65f7881
commit 40247bae0f
2 changed files with 58 additions and 22 deletions

View File

@ -126,4 +126,4 @@ def release(app, bump_type, develop, master, owner, repo_name):
"Release app (internal to the Frappe team)" "Release app (internal to the Frappe team)"
from bench.release import release from bench.release import release
repo = os.path.join('apps', repo_name) if repo_name else os.path.join('apps', app) repo = os.path.join('apps', repo_name) if repo_name else os.path.join('apps', app)
release(repo, bump_type, develop, master, owner) release(repo, bump_type, develop, master, owner, app)

View File

@ -19,7 +19,7 @@ import click
github_username = None github_username = None
github_password = None github_password = None
def release(repo, bump_type, develop, master, owner): def release(repo, bump_type, develop, master, owner, app):
if not get_config(".").get('release_bench'): if not get_config(".").get('release_bench'):
print 'bench not configured to release' print 'bench not configured to release'
sys.exit(1) sys.exit(1)
@ -28,12 +28,14 @@ def release(repo, bump_type, develop, master, owner):
github_password = getpass.getpass() github_password = getpass.getpass()
r = requests.get('https://api.github.com/user', auth=HTTPBasicAuth(github_username, github_password)) r = requests.get('https://api.github.com/user', auth=HTTPBasicAuth(github_username, github_password))
r.raise_for_status() r.raise_for_status()
bump(repo, bump_type, develop=develop, master=master, owner=owner)
def bump(repo, bump_type, develop='develop', master='master', remote='upstream', owner='frappe'): bump(repo, bump_type, develop=develop, master=master, owner=owner, app=app)
def bump(repo, bump_type, develop='develop', master='master', remote='upstream', owner='frappe', app=None):
assert bump_type in ['minor', 'major', 'patch'] assert bump_type in ['minor', 'major', 'patch']
update_branches_and_check_for_changelog(repo, bump_type, develop=develop, master=master, remote=remote) update_branches_and_check_for_changelog(repo, bump_type, develop=develop, master=master, remote=remote, app=app)
message = get_release_message(repo, develop_branch=develop, master_branch=master) message = get_release_message(repo, develop_branch=develop, master_branch=master, app=app)
if not message: if not message:
print 'No commits to release' print 'No commits to release'
return return
@ -44,25 +46,34 @@ def bump(repo, bump_type, develop='develop', master='master', remote='upstream',
click.confirm('Do you want to continue?', abort=True) click.confirm('Do you want to continue?', abort=True)
new_version = bump_repo(repo, bump_type, develop=develop, master=master, remote=remote) new_version = bump_repo(repo, bump_type, develop=develop, master=master, remote=remote, app=app)
commit_changes(repo, new_version) commit_changes(repo, new_version, app=app)
tag_name = create_release(repo, new_version, develop_branch=develop, master_branch=master) tag_name = create_release(repo, new_version, develop_branch=develop, master_branch=master, app=app)
push_release(repo, develop_branch=develop, master_branch=master) push_release(repo, develop_branch=develop, master_branch=master, app=app)
create_github_release(owner, repo, tag_name, message) create_github_release(owner, repo, tag_name, message, app)
print 'Released {tag} for {repo}'.format(tag=tag_name, repo=repo) print 'Released {tag} for {repo}'.format(tag=tag_name, repo=repo)
def update_branches_and_check_for_changelog(repo, bump_type, develop='develop', master='master', remote='upstream'): def update_branches_and_check_for_changelog(repo, bump_type, develop='develop', master='master', remote='upstream', app=None):
update_branch(repo, master, remote=remote)
update_branch(repo, develop, remote=remote) update_branch(repo, master, remote=remote, app=app)
update_branch(repo, develop, remote=remote, app=app)
if develop != 'develop': if develop != 'develop':
update_branch(repo, 'develop', remote=remote) update_branch(repo, 'develop', remote=remote, app=app)
if os.path.basename(repo) != app:
repo = app
repo = os.path.join('apps', repo)
git.Repo(repo).git.checkout(develop) git.Repo(repo).git.checkout(develop)
check_for_unmerged_changelog(repo) check_for_unmerged_changelog(repo)
def update_branch(repo_path, branch, remote='origin'): def update_branch(repo_path, branch, remote='origin', app=None):
print "updating local branch of", repo_path, 'using', remote + '/' + branch print "updating local branch of", repo_path, 'using', remote + '/' + branch
if os.path.basename(repo_path) != app:
repo_path = app
repo_path = os.path.join('apps', repo_path)
repo = git.Repo(repo_path) repo = git.Repo(repo_path)
g = repo.git g = repo.git
g.fetch(remote) g.fetch(remote)
@ -74,7 +85,13 @@ def check_for_unmerged_changelog(repo):
if os.path.exists(current) and [f for f in os.listdir(current) if f != "readme.md"]: if os.path.exists(current) and [f for f in os.listdir(current) if f != "readme.md"]:
raise Exception("Unmerged change log! in " + repo) raise Exception("Unmerged change log! in " + repo)
def get_release_message(repo_path, develop_branch='develop', master_branch='master'): def get_release_message(repo_path, develop_branch='develop', master_branch='master', app=None):
if os.path.basename(repo_path) != app:
repo_path = app
repo_path = os.path.join('apps', repo_path)
print 'getting release message for', repo_path, 'comparing', master_branch, '...', develop_branch print 'getting release message for', repo_path, 'comparing', master_branch, '...', develop_branch
repo = git.Repo(repo_path) repo = git.Repo(repo_path)
g = repo.git g = repo.git
@ -83,7 +100,11 @@ def get_release_message(repo_path, develop_branch='develop', master_branch='mast
return "* " + log.replace('\n', '\n* ') return "* " + log.replace('\n', '\n* ')
def bump_repo(repo, bump_type, develop='develop', master='master', remote='upstream'): def bump_repo(repo, bump_type, develop='develop', master='master', remote='upstream', app=None):
if os.path.basename(repo) != app:
repo = app
repo = os.path.join('apps', repo)
current_version = get_current_version(repo) current_version = get_current_version(repo)
new_version = get_bumped_version(current_version, bump_type) new_version = get_bumped_version(current_version, bump_type)
@ -145,7 +166,11 @@ def set_filename_version(filename, version_number, pattern):
with open(filename, 'w') as f: with open(filename, 'w') as f:
f.write(contents) f.write(contents)
def commit_changes(repo_path, version): def commit_changes(repo_path, version, app=None):
if os.path.basename(repo_path) != app:
repo_path = app
repo_path = os.path.join('apps', repo_path)
print 'committing version change to', repo_path print 'committing version change to', repo_path
repo = git.Repo(repo_path) repo = git.Repo(repo_path)
@ -155,7 +180,12 @@ def commit_changes(repo_path, version):
repo.index.add([os.path.join(repo_name, 'hooks.py')]) repo.index.add([os.path.join(repo_name, 'hooks.py')])
repo.index.commit('bumped to version {}'.format(version)) repo.index.commit('bumped to version {}'.format(version))
def create_release(repo_path, version, remote='origin', develop_branch='develop', master_branch='master'): def create_release(repo_path, version, remote='origin', develop_branch='develop', master_branch='master', app=None):
if os.path.basename(repo_path) != app:
repo_path = app
repo_path = os.path.join('apps', repo_path)
print 'creating release for version', version print 'creating release for version', version
repo = git.Repo(repo_path) repo = git.Repo(repo_path)
g = repo.git g = repo.git
@ -173,7 +203,12 @@ def create_release(repo_path, version, remote='origin', develop_branch='develop'
return tag_name return tag_name
def push_release(repo_path, develop_branch='develop', master_branch='master'): def push_release(repo_path, develop_branch='develop', master_branch='master', app=None):
if os.path.basename(repo_path) != app:
repo_path = app
repo_path = os.path.join('apps', repo_path)
print 'pushing branches', master_branch, develop_branch, 'of', repo_path print 'pushing branches', master_branch, develop_branch, 'of', repo_path
repo = git.Repo(repo_path) repo = git.Repo(repo_path)
g = repo.git g = repo.git
@ -191,6 +226,7 @@ def push_release(repo_path, develop_branch='develop', master_branch='master'):
print g.push('upstream', *args) print g.push('upstream', *args)
def create_github_release(owner, repo, tag_name, log, gh_username=None, gh_password=None): def create_github_release(owner, repo, tag_name, log, gh_username=None, gh_password=None):
print 'creating release on github' print 'creating release on github'
global github_username, github_password global github_username, github_password