[release_table] Improve script for Debian (#315)

- add an 'ignore_empty_releases' to exclude empty releases (which are future releases for Debian),
- improve logging,
- add the 'YYYY-mm' month_year date format.
This commit is contained in:
Marc Wrobel
2024-02-19 22:12:25 +01:00
parent 56ca896a38
commit c968456d3d
3 changed files with 25 additions and 9 deletions

View File

@@ -20,6 +20,7 @@ def parse_date(text: str, formats: list[str] = frozenset([
def parse_month_year_date(text: str, formats: list[str] = frozenset([
"%B %Y", # January 2020
"%b %Y", # Jan 2020
"%Y-%m", # 2020-01
])) -> datetime:
"""Parse a given text representing a partial date using a list of formats,
adjusting it to the last day of the month.

View File

@@ -50,6 +50,9 @@ class ProductRelease:
else:
logging.info(f"set '{field}' in {self} to {new_value}")
def is_empty(self) -> bool:
return len(self.data) == 1 # only the name is set
def __repr__(self) -> str:
return f"{self.product}#{self.name()}"
@@ -132,6 +135,13 @@ class ProductData:
self.updated = True
return self.releases[release]
def remove_release(self, release: str) -> None:
if release not in self.releases:
logging.warning(f"release {release} cannot be removed as it does not exist for {self}")
return
logging.info(f"removing release {release} ({self.releases.pop(release)}) from {self}")
def get_version(self, version: str) -> ProductVersion:
return self.versions[version] if version in self.versions else None
@@ -149,7 +159,7 @@ class ProductData:
self.declare_version(version, date)
def remove_version(self, version: str) -> None:
if not self.get_version(version):
if version not in self.versions:
logging.warning(f"version {version} cannot be removed as it does not exist for {self}")
return

View File

@@ -90,7 +90,7 @@ class Field:
if self.name == "releaseCycle":
return None # skipping entire rows is allowed
msg = f"field {self}'s value {raw_value} does not matching any regex in {self.include_version_patterns}"
msg = f"field {self}'s value '{raw_value}' does not match any regex in {self.include_version_patterns}"
raise ValueError(msg)
def __repr__(self) -> str:
@@ -121,20 +121,25 @@ for config in endoflife.list_configs(p_filter, METHOD, m_filter):
logging.info(f"skipping row {cells}: not enough columns")
continue
raw_release_cycle = cells[fields_index[release_cycle_field.name]]
release_cycle = release_cycle_field.extract_from(raw_release_cycle)
if not release_cycle:
logging.info(f"skipping row {cells}: invalid release cycle '{raw_release_cycle}', "
f"should match any of {release_cycle_field.include_version_patterns} "
f"and not match any of {release_cycle_field.exclude_version_patterns}")
raw_release_name = cells[fields_index[release_cycle_field.name]]
release_name = release_cycle_field.extract_from(raw_release_name)
if not release_name:
logging.info(f"skipping row {cells}: invalid release cycle '{raw_release_name}', "
f"should match one of {release_cycle_field.include_version_patterns} "
f"and not match all of {release_cycle_field.exclude_version_patterns}")
continue
release = product_data.get_release(release_cycle)
release = product_data.get_release(release_name)
for field in fields:
raw_field = cells[fields_index[field.name]]
try:
release.set_field(field.name, field.extract_from(raw_field))
except ValueError as e:
logging.info(f"skipping cell {raw_field} for {release}: {e}")
if config.data.get("ignore_empty_releases", False) and release.is_empty():
logging.info(f"removing empty release '{release}'")
product_data.remove_release(release_name)
except ValueError as e:
logging.info(f"skipping table with headers {headers}: {e}")