Skip to content

Commit

Permalink
Make Git Update Detection use release notes from annotated tag
Browse files Browse the repository at this point in the history
Part of #545
  • Loading branch information
rubenwardy committed Jun 30, 2024
1 parent 4ad8e36 commit e43a782
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 9 deletions.
6 changes: 4 additions & 2 deletions app/tasks/importtasks.py
Original file line number Diff line number Diff line change
Expand Up @@ -409,8 +409,9 @@ def check_update_config_impl(package):
if config.trigger == PackageUpdateTrigger.COMMIT:
tag = None
commit = get_latest_commit(package.repo, package.update_config.ref)
release_notes = None
elif config.trigger == PackageUpdateTrigger.TAG:
tag, commit = get_latest_tag(package.repo)
tag, commit, release_notes = get_latest_tag(package.repo)
else:
raise TaskError("Unknown update trigger")

Expand All @@ -437,6 +438,7 @@ def check_update_config_impl(package):
rel.package = package
rel.name = tag if tag else datetime.datetime.utcnow().strftime("%Y-%m-%d")
rel.title = rel.name
rel.release_notes = release_notes
rel.url = ""
rel.task_id = uuid()
db.session.add(rel)
Expand Down Expand Up @@ -468,7 +470,7 @@ def check_update_config_impl(package):

for user in package.maintainers:
add_system_notification(user, NotificationType.BOT,
msg, url_for("todo.view_user", username=user.username, _external=False), package)
msg, url_for("todo.view_user", username=user.username, _external=False), package)

config.last_commit = commit
config.last_tag = tag
Expand Down
16 changes: 13 additions & 3 deletions app/tests/unit/utils/test_git.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,21 @@
master_head = "23d12265ff6de84548b2e3e90dc7351a54f63f00"
test_branch_head = "51b54f00c3b3d712417a1cc4bfaa6cbdc7aac3fc"
v4_commit = "c07d27c3a466d2102d1ba5473d172c74e6b3e0d7"
latest_tag_name = "v5"
latest_tag_commit = "23d12265ff6de84548b2e3e90dc7351a54f63f00"
latest_tag_message = """
* One thing
* Second
* Third
""".strip()
random_commit = "84a2e53ff046eacbdbb80f3a00c58510885fefca"


def test_get_latest_tag():
tag, commit = get_latest_tag(test_repo)
assert tag == "v4"
assert commit == v4_commit
tag, commit, message = get_latest_tag(test_repo)
assert tag == latest_tag_name
assert commit == latest_tag_commit
assert message == latest_tag_message


def test_get_latest_commit():
Expand Down Expand Up @@ -68,6 +76,8 @@ def test_git_clone_branch():
def test_git_clone_tag():
with clone_repo(test_repo, "v4", recursive=True) as repo:
assert repo.head.commit.hexsha == v4_commit

# v4 isn't on the master branch, let's check there's no master branch files
assert os.path.isfile(os.path.join(repo.working_tree_dir, "init.lua"))
assert not os.path.isfile(os.path.join(repo.working_tree_dir, "chatcmdbuilder", "init.lua"))
assert not os.path.isfile(os.path.join(repo.working_tree_dir, "test-branch.txt"))
Expand Down
21 changes: 17 additions & 4 deletions app/utils/git.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@


import contextlib
from typing import List, Optional
from typing import List, Optional, Tuple

import git
import gitdb
Expand Down Expand Up @@ -107,7 +107,8 @@ def get_latest_commit(git_url, ref_name=None):
return remote_refs.get(ref_name)


def get_latest_tag(git_url):
# @returns (tag_name, commit_hash, tag_message)
def get_latest_tag(git_url) -> Tuple[Optional[str], Optional[str], Optional[str]]:
with get_temp_dir() as git_dir:
repo = git.Repo.init(git_dir)
origin = repo.create_remote("origin", url=git_url)
Expand All @@ -116,14 +117,26 @@ def get_latest_tag(git_url):
refs = repo.git.for_each_ref(sort="creatordate", format="%(objectname)\t%(refname)").split("\n")
refs = [ref for ref in refs if "refs/tags/" in ref]
if len(refs) == 0:
return None, None
return None, None, None

last_ref = refs[-1]
hash_ref_list = last_ref.split('\t')

tag = hash_ref_list[1].replace("refs/tags/", "")
# "^{}" means dereference the tag until an actual commit is found
commit_hash = repo.git.rev_parse(tag + "^{}")
return tag, commit_hash

# Get summary message of annotated tag from GitPython
annotated_tag = repo.tag(tag).tag
if annotated_tag:
message = annotated_tag.message
message = normalize_line_endings(message)
if message == "":
message = None
else:
message = None

return tag, commit_hash, message


def get_commit_list(git_url: str, start: str, end: str) -> List[str]:
Expand Down

0 comments on commit e43a782

Please sign in to comment.