1
0
Fork 0
mirror of https://github.com/ArtemSBulgakov/buildozer-action.git synced 2024-08-16 10:09:52 +02:00

Update move_binary script

Fixes #3
This commit is contained in:
Artem Bulgakov 2020-12-24 20:34:55 +03:00
parent abad880b7e
commit 9f94e8ca9a
2 changed files with 57 additions and 32 deletions

View file

@ -14,6 +14,7 @@ directory = sys.argv[4]
os.chdir(master_repository_directory)
filename = os.path.basename(binary_filename)
# Include commit subject and hash to the new commit
commit_hash = (
subprocess.check_output(["git", "rev-parse", "--verify", "--short", "HEAD"])
.decode("utf-8")
@ -28,42 +29,66 @@ commit_subject = (
is_tag = env["GITHUB_EVENT_NAME"] == "push" and env["GITHUB_REF"].startswith(
"refs/tags"
)
if not is_tag:
is_pr = env["GITHUB_REF"].startswith("refs/pull")
if is_pr:
# Pull Request - prN (pr1)
middle = "pr" + env["GITHUB_REF"].split("/")[2]
else:
# Latest commit - short hash (20f2448)
middle = commit_hash
filename_split = filename.split("-")
filename = "-".join([*filename_split[:2], middle, *filename_split[2:]])
is_pr = env["GITHUB_REF"].startswith("refs/pull")
# Set author info to the latest commit author
author_name = subprocess.check_output(
["git", "log", "-1", "--pretty=format:%an"]
).decode("utf-8")
author_email = subprocess.check_output(
["git", "log", "-1", "--pretty=format:%ae"]
).decode("utf-8")
filename_split = filename.split("-")
if is_tag:
new_commit_message = (
f'Add binary for {filename_split[1]} {commit_hash}: "{commit_subject}"'
)
elif is_pr:
# Pull Request - prN (pr1)
pr_number = env["GITHUB_REF"].split("/")[2]
filename = "-".join(
[*filename_split[:2], f"pr{pr_number}", *filename_split[2:]]
)
directory = os.path.join(directory, "prs")
new_commit_message = (
f'Add binary for #{pr_number} {commit_hash}: "{commit_subject}"'
)
else:
# Latest commit - short hash (20f2448)
filename = "-".join([*filename_split[:2], commit_hash, *filename_split[2:]])
new_commit_message = f'Add binary for {commit_hash}: "{commit_subject}"'
# Move file
# Prepare for pushing
os.chdir(data_repository_directory)
os.makedirs(directory, exist_ok=True)
shutil.copy(binary_filename, os.path.join(directory, filename))
# Ensure that there is no changes
subprocess.check_call(["git", "pull", "origin", data_repository, "--ff-only"])
# Push changes
subprocess.check_call(["git", "config", "user.name", author_name])
subprocess.check_call(["git", "config", "user.email", author_email])
subprocess.check_call(
["git", "pull", "--ff-only"]
) # Ensure that there is no changes
subprocess.check_call(["git", "add", os.path.join(directory, filename)])
subprocess.check_call(
["git", "commit", "-m", f'Add binary for {commit_hash}: "{commit_subject}"']
# Try to push several times
for i in range(3):
shutil.copy(binary_filename, os.path.join(directory, filename))
# Push changes
subprocess.check_call(["git", "add", os.path.join(directory, filename)])
subprocess.check_call(
["git", "commit", "--amend", "-m", new_commit_message]
)
try:
subprocess.check_call(
["git", "push", "origin", data_repository, "--force"]
)
except subprocess.CalledProcessError: # There are changes in repository
# Undo local changes
subprocess.check_call(
["git", "reset", f"origin/{data_repository}", "--hard"]
)
# Pull new changes
subprocess.check_call(
["git", "pull", "origin", data_repository, "--force", "--ff-only"]
)
else:
break # Exit loop if there is no errors
else:
raise Exception("Cannot push binary")
new_commit_hash = (
subprocess.check_output(["git", "rev-parse", "--verify", "--short", "HEAD"])
.decode("utf-8")
.strip()
)
subprocess.check_call(["git", "push"])
print(
f"Binary file: {env['GITHUB_SERVER_URL']}/{env['GITHUB_REPOSITORY']}/blob/{data_repository}/{directory}/{filename}"
f"Binary file: {env['GITHUB_SERVER_URL']}/{env['GITHUB_REPOSITORY']}/blob/"
f"{new_commit_hash}/{directory}/{filename}"
)

View file

@ -241,7 +241,7 @@ add this to your workflow:
architecture: x64
- name: Push binary to data branch
run: python master/.ci/move_binary.py "${{ steps.buildozer.outputs.filename }}" master data
run: python master/.ci/move_binary.py "${{ steps.buildozer.outputs.filename }}" master data bin
```
Also you need to create `data` branch: