Move remaining metadata to pyproject (#72469)

This commit is contained in:
Marc Mueller 2022-05-26 02:54:49 +02:00 committed by GitHub
parent 30edc039ae
commit 1ac71455cb
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
10 changed files with 62 additions and 52 deletions

View file

@ -1,31 +1,36 @@
"""Package metadata validation."""
import configparser
import sys
from homeassistant.const import REQUIRED_PYTHON_VER, __version__
from .model import Config, Integration
if sys.version_info >= (3, 11):
import tomllib
else:
import tomli as tomllib
def validate(integrations: dict[str, Integration], config: Config) -> None:
"""Validate project metadata keys."""
metadata_path = config.root / "setup.cfg"
parser = configparser.ConfigParser()
parser.read(metadata_path)
metadata_path = config.root / "pyproject.toml"
with open(metadata_path, "rb") as fp:
data = tomllib.load(fp)
try:
if parser["metadata"]["version"] != __version__:
if data["project"]["version"] != __version__:
config.add_error(
"metadata", f"'metadata.version' value does not match '{__version__}'"
"metadata", f"'project.version' value does not match '{__version__}'"
)
except KeyError:
config.add_error("metadata", "No 'metadata.version' key found!")
required_py_version = f">={'.'.join(map(str, REQUIRED_PYTHON_VER))}"
try:
if parser["options"]["python_requires"] != required_py_version:
if data["project"]["requires-python"] != required_py_version:
config.add_error(
"metadata",
f"'options.python_requires' value doesn't match '{required_py_version}",
f"'project.requires-python' value doesn't match '{required_py_version}",
)
except KeyError:
config.add_error("metadata", "No 'options.python_requires' key found!")