-
Notifications
You must be signed in to change notification settings - Fork 124
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
28 changed files
with
341 additions
and
756 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,118 @@ | ||
# WARNING: DO NOT EDIT! | ||
# | ||
# This file was generated by plugin_template, and is managed by it. Please use | ||
# './plugin-template --github pulp_rpm' to update this file. | ||
# | ||
# For more info visit https://github.com/pulp/plugin_template | ||
|
||
import argparse | ||
import fileinput | ||
import urllib.request | ||
import sys | ||
from packaging.requirements import Requirement | ||
from packaging.version import Version | ||
import yaml | ||
|
||
|
||
CORE_TEMPLATE_URL = "https://raw.githubusercontent.com/pulp/pulpcore/main/template_config.yml" | ||
|
||
|
||
def fetch_pulpcore_upper_bound(requirement): | ||
with urllib.request.urlopen(CORE_TEMPLATE_URL) as f: | ||
template = yaml.safe_load(f.read()) | ||
supported_versions = template["supported_release_branches"] | ||
supported_versions.append(template["latest_release_branch"]) | ||
applicable_versions = sorted( | ||
requirement.specifier.filter((Version(v) for v in supported_versions)) | ||
) | ||
if len(applicable_versions) == 0: | ||
raise Exception("No supported pulpcore version in required range.") | ||
return f"{requirement.name}~={applicable_versions[-1]}" | ||
|
||
|
||
def split_comment(line): | ||
split_line = line.split("#", maxsplit=1) | ||
try: | ||
comment = " # " + split_line[1].strip() | ||
except IndexError: | ||
comment = "" | ||
return split_line[0].strip(), comment | ||
|
||
|
||
def to_upper_bound(req): | ||
try: | ||
requirement = Requirement(req) | ||
except ValueError: | ||
return f"# UNPARSABLE: {req}" | ||
else: | ||
if requirement.name == "pulpcore": | ||
# An exception to allow for pulpcore deprecation policy. | ||
return fetch_pulpcore_upper_bound(requirement) | ||
for spec in requirement.specifier: | ||
if spec.operator == "~=": | ||
return f"# NO BETTER CONSTRAINT: {req}" | ||
if spec.operator == "<=": | ||
operator = "==" | ||
max_version = spec.version | ||
return f"{requirement.name}{operator}{max_version}" | ||
if spec.operator == "<": | ||
operator = "~=" | ||
version = Version(spec.version) | ||
if version.micro != 0: | ||
max_version = f"{version.major}.{version.minor}.{version.micro-1}" | ||
elif version.minor != 0: | ||
max_version = f"{version.major}.{version.minor-1}" | ||
elif version.major != 0: | ||
max_version = f"{version.major-1}.0" | ||
else: | ||
return f"# NO BETTER CONSTRAINT: {req}" | ||
return f"{requirement.name}{operator}{max_version}" | ||
return f"# NO UPPER BOUND: {req}" | ||
|
||
|
||
def to_lower_bound(req): | ||
try: | ||
requirement = Requirement(req) | ||
except ValueError: | ||
return f"# UNPARSABLE: {req}" | ||
else: | ||
for spec in requirement.specifier: | ||
if spec.operator == ">=": | ||
if requirement.name == "pulpcore": | ||
# Currently an exception to allow for pulpcore bugfix releases. | ||
# TODO Semver libraries should be allowed too. | ||
operator = "~=" | ||
else: | ||
operator = "==" | ||
min_version = spec.version | ||
return f"{requirement.name}{operator}{min_version}" | ||
return f"# NO LOWER BOUND: {req}" | ||
|
||
|
||
def main(): | ||
"""Calculate constraints for the lower bound of dependencies where possible.""" | ||
parser = argparse.ArgumentParser( | ||
prog=sys.argv[0], | ||
description="Calculate constraints for the lower or upper bound of dependencies where " | ||
"possible.", | ||
) | ||
parser.add_argument("-u", "--upper", action="store_true") | ||
parser.add_argument("filename", nargs="*") | ||
args = parser.parse_args() | ||
|
||
with fileinput.input(files=args.filename) as req_file: | ||
for line in req_file: | ||
if line.strip().startswith("#"): | ||
# Shortcut comment only lines | ||
print(line.strip()) | ||
else: | ||
req, comment = split_comment(line) | ||
if args.upper: | ||
new_req = to_upper_bound(req) | ||
else: | ||
new_req = to_lower_bound(req) | ||
print(new_req + comment) | ||
|
||
|
||
if __name__ == "__main__": | ||
main() |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
#!/bin/env python3 | ||
|
||
# This script is running with elevated privileges from the main branch against pull requests. | ||
|
||
import re | ||
import sys | ||
import tomllib | ||
from pathlib import Path | ||
|
||
from git import Repo | ||
|
||
|
||
def main(): | ||
assert len(sys.argv) == 3 | ||
|
||
with open("pyproject.toml", "rb") as fp: | ||
PYPROJECT_TOML = tomllib.load(fp) | ||
BLOCKING_REGEX = re.compile(r"DRAFT|WIP|NO\s*MERGE|DO\s*NOT\s*MERGE|EXPERIMENT") | ||
ISSUE_REGEX = re.compile(r"(?:fixes|closes)[\s:]+#(\d+)") | ||
CHERRY_PICK_REGEX = re.compile(r"^\s*\(cherry picked from commit [0-9a-f]*\)\s*$") | ||
CHANGELOG_EXTS = [ | ||
f".{item['directory']}" for item in PYPROJECT_TOML["tool"]["towncrier"]["type"] | ||
] | ||
|
||
repo = Repo(".") | ||
|
||
base_commit = repo.commit(sys.argv[1]) | ||
head_commit = repo.commit(sys.argv[2]) | ||
|
||
pr_commits = list(repo.iter_commits(f"{base_commit}..{head_commit}")) | ||
|
||
labels = { | ||
"multi-commit": len(pr_commits) > 1, | ||
"cherry-pick": False, | ||
"no-issue": False, | ||
"no-changelog": False, | ||
"wip": False, | ||
} | ||
for commit in pr_commits: | ||
labels["wip"] |= BLOCKING_REGEX.search(commit.summary) is not None | ||
no_issue = ISSUE_REGEX.search(commit.message, re.IGNORECASE) is None | ||
labels["no-issue"] |= no_issue | ||
cherry_pick = CHERRY_PICK_REGEX.search(commit.message) is not None | ||
labels["cherry-pick"] |= cherry_pick | ||
changelog_snippets = [ | ||
k | ||
for k in commit.stats.files | ||
if k.startswith("CHANGES/") and Path(k).suffix in CHANGELOG_EXTS | ||
] | ||
labels["no-changelog"] |= not changelog_snippets | ||
|
||
print("ADD_LABELS=" + ",".join((k for k, v in labels.items() if v))) | ||
print("REMOVE_LABELS=" + ",".join((k for k, v in labels.items() if not v))) | ||
|
||
|
||
if __name__ == "__main__": | ||
main() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
2021.08.26-349-gba81617 | ||
2021.08.26-382-gc88324b |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.