aboutsummaryrefslogtreecommitdiff
path: root/releng/gitutils.xsh
diff options
context:
space:
mode:
authorJade Lovelace <lix@jade.fyi>2024-08-07 20:14:45 -0700
committerJade Lovelace <lix@jade.fyi>2024-08-07 20:14:45 -0700
commit8a86f38bca61ab67dcc137c4966f32b3dc2251d9 (patch)
tree4a173037f5bb6915968f2535ed080ba5e0cd18b2 /releng/gitutils.xsh
parent6fdb47f0b259a9ffbe4bdb349d6aaf03a0144092 (diff)
Fix is_maintenance_branch heuristic
This was broken because Nix language's version comparison does not know how to deal with versions like -rc1 and considers them newer, which is in this case not desirable. That in turn led to not tagging 2.90.0 docker images as "latest" since the heuristic was wrong. This commit also adds some more cross-checking and failsafes in case the person running releng does not have a local main branch that is up to date. Fixes: https://git.lix.systems/lix-project/lix/issues/443 Change-Id: I537103ebab58ae978c00e06972abe14432dd9c80
Diffstat (limited to 'releng/gitutils.xsh')
-rw-r--r--releng/gitutils.xsh39
1 files changed, 27 insertions, 12 deletions
diff --git a/releng/gitutils.xsh b/releng/gitutils.xsh
index e18b4da5f..d3b3774c0 100644
--- a/releng/gitutils.xsh
+++ b/releng/gitutils.xsh
@@ -1,11 +1,24 @@
import subprocess
-import json
+from packaging.version import Version
from .version import VERSION
+def remote_is_plausible(url: str) -> bool:
+ return ('git.lix.systems' in url and 'lix-project/lix' in url) or ('gerrit.lix.systems' in url and url.endswith('lix'))
+
+
def version_compare(v1: str, v2: str):
- return json.loads($(nix-instantiate --eval --json --argstr v1 @(v1) --argstr v2 @(v2) --expr '{v1, v2}: builtins.compareVersions v1 v2'))
+ v1 = Version(v1)
+ v2 = Version(v2)
+ if v1 < v2:
+ return -1
+ elif v1 > v2:
+ return 1
+ elif v1 == v2:
+ return 0
+ else:
+ raise ValueError('these versions are beyond each others celestial plane')
def latest_tag_on_branch(branch: str) -> str:
@@ -13,16 +26,18 @@ def latest_tag_on_branch(branch: str) -> str:
def is_maintenance_branch(branch: str) -> bool:
- try:
- main_tag = latest_tag_on_branch('main')
- current_tag = latest_tag_on_branch(branch)
-
- return version_compare(current_tag, main_tag) < 0
- except subprocess.CalledProcessError:
- # This is the case before Lix releases 2.90, since main *has* no
- # release tag on it.
- # FIXME: delete this case after 2.91
- return False
+ """
+ Returns whether the given branch is probably a maintenance branch.
+
+ This uses a heuristic: `main` should have a newer tag than a given
+ maintenance branch if there has been a major release since that maintenance
+ branch.
+ """
+ assert remote_is_plausible($(git remote get-url origin).strip())
+ main_tag = latest_tag_on_branch('origin/main')
+ current_tag = latest_tag_on_branch(branch)
+
+ return version_compare(current_tag, main_tag) < 0
def verify_are_on_tag():