Fix update-plugin-list workflow due to new 'packaging'
The latest 'packaging' release has dropped support for `LegacyVersion`, meaning that version strings which do not conform to the standard now raise an error.
This commit is contained in:
parent
b31db4809b
commit
215ea7fd03
|
@ -81,8 +81,20 @@ def iter_plugins():
|
||||||
if re.match(r"pytest(?![-.\w])", requirement):
|
if re.match(r"pytest(?![-.\w])", requirement):
|
||||||
requires = requirement
|
requires = requirement
|
||||||
break
|
break
|
||||||
|
|
||||||
|
def version_sort_key(version_string):
|
||||||
|
"""
|
||||||
|
Return the sort key for the given version string
|
||||||
|
returned by the API.
|
||||||
|
"""
|
||||||
|
try:
|
||||||
|
return packaging.version.parse(version_string)
|
||||||
|
except packaging.version.InvalidVersion:
|
||||||
|
# Use a hard-coded pre-release version.
|
||||||
|
return packaging.version.Version("0.0.0alpha")
|
||||||
|
|
||||||
releases = response.json()["releases"]
|
releases = response.json()["releases"]
|
||||||
for release in sorted(releases, key=packaging.version.parse, reverse=True):
|
for release in sorted(releases, key=version_sort_key, reverse=True):
|
||||||
if releases[release]:
|
if releases[release]:
|
||||||
release_date = datetime.date.fromisoformat(
|
release_date = datetime.date.fromisoformat(
|
||||||
releases[release][-1]["upload_time_iso_8601"].split("T")[0]
|
releases[release][-1]["upload_time_iso_8601"].split("T")[0]
|
||||||
|
@ -124,7 +136,7 @@ def main():
|
||||||
reference_dir = pathlib.Path("doc", "en", "reference")
|
reference_dir = pathlib.Path("doc", "en", "reference")
|
||||||
|
|
||||||
plugin_list = reference_dir / "plugin_list.rst"
|
plugin_list = reference_dir / "plugin_list.rst"
|
||||||
with plugin_list.open("w") as f:
|
with plugin_list.open("w", encoding="UTF-8") as f:
|
||||||
f.write(FILE_HEAD)
|
f.write(FILE_HEAD)
|
||||||
f.write(f"This list contains {len(plugins)} plugins.\n\n")
|
f.write(f"This list contains {len(plugins)} plugins.\n\n")
|
||||||
f.write(".. only:: not latex\n\n")
|
f.write(".. only:: not latex\n\n")
|
||||||
|
|
Loading…
Reference in New Issue