utils: report additional git repo data

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Eric Callahan 2023-05-25 16:17:45 -04:00
parent c609060352
commit cd4fdfb7b6
No known key found for this signature in database
GPG Key ID: 5A1EB336DFB4C71B
2 changed files with 69 additions and 20 deletions

View File

@ -21,7 +21,7 @@ from . import confighelper
from .eventloop import EventLoop from .eventloop import EventLoop
from .app import MoonrakerApp from .app import MoonrakerApp
from .klippy_connection import KlippyConnection from .klippy_connection import KlippyConnection
from .utils import ServerError, Sentinel, get_software_version from .utils import ServerError, Sentinel, get_software_info
from .loghelper import LogManager from .loghelper import LogManager
# Annotation imports # Annotation imports
@ -526,7 +526,7 @@ def main(from_package: bool = True) -> None:
} }
# Setup Logging # Setup Logging
version = get_software_version() app_args.update(get_software_info())
if cmd_line_args.nologfile: if cmd_line_args.nologfile:
app_args["log_file"] = "" app_args["log_file"] = ""
elif cmd_line_args.logfile: elif cmd_line_args.logfile:
@ -534,7 +534,6 @@ def main(from_package: bool = True) -> None:
os.path.expanduser(cmd_line_args.logfile)) os.path.expanduser(cmd_line_args.logfile))
else: else:
app_args["log_file"] = str(data_path.joinpath("logs/moonraker.log")) app_args["log_file"] = str(data_path.joinpath("logs/moonraker.log"))
app_args["software_version"] = version
app_args["python_version"] = sys.version.replace("\n", " ") app_args["python_version"] = sys.version.replace("\n", " ")
log_manager = LogManager(app_args, startup_warnings) log_manager = LogManager(app_args, startup_warnings)

View File

@ -27,7 +27,7 @@ from typing import (
TYPE_CHECKING, TYPE_CHECKING,
List, List,
Optional, Optional,
ClassVar, Any,
Tuple, Tuple,
Dict, Dict,
Union Union
@ -57,7 +57,9 @@ def _run_git_command(cmd: str) -> str:
retcode = process.wait() retcode = process.wait()
if retcode == 0: if retcode == 0:
return ret.strip().decode() return ret.strip().decode()
raise Exception(f"Failed to run git command: {cmd}") raise Exception(
f"Failed to run git command '{cmd}': {err.decode(errors='ignore')}"
)
def _retrieve_git_tag(source_path: str) -> str: def _retrieve_git_tag(source_path: str) -> str:
cmd = f"git -C {source_path} rev-list --tags --max-count=1" cmd = f"git -C {source_path} rev-list --tags --max-count=1"
@ -82,15 +84,64 @@ def retrieve_git_version(source_path: str) -> str:
tag = _retrieve_git_tag(source_path) tag = _retrieve_git_tag(source_path)
return f"t{tag}-g{ver}-shallow" return f"t{tag}-g{ver}-shallow"
def get_software_version() -> str: def get_repo_info(source_path: str) -> Dict[str, Any]:
repo_info: Dict[str, Any] = {
"software_version": "?",
"git_branch": "?",
"git_remote": "?",
"git_repo_url": "?",
"modified_files": [],
"unofficial_components": []
}
try:
repo_info["software_version"] = retrieve_git_version(source_path)
cmd = f"git -C {source_path} branch --no-color"
branch_list = _run_git_command(cmd)
for line in branch_list.split("\n"):
if line[0] == "*":
repo_info["git_branch"] = line[1:].strip()
break
else:
return repo_info
if repo_info["git_branch"].startswith("(HEAD detached"):
parts = repo_info["git_branch"] .strip("()").split()[-1]
remote, _, _ = parts.partition("/")
if not remote:
return repo_info
repo_info["git_remote"] = remote
else:
branch = repo_info["git_branch"]
cmd = f"git -C {source_path} config --get branch.{branch}.remote"
repo_info["git_remote"] = _run_git_command(cmd)
cmd = f"git -C {source_path} remote get-url {repo_info['git_remote']}"
repo_info["git_repo_url"] = _run_git_command(cmd)
cmd = f"git -C {source_path} status --porcelain --ignored"
status = _run_git_command(cmd)
for line in status.split("\n"):
parts = line.strip().split(maxsplit=1)
if len(parts) != 2:
continue
if parts[0] == "M":
repo_info["modified_files"].append(parts[1])
elif (
parts[0] in ("??", "!!")
and parts[1].endswith(".py")
and parts[1].startswith("components")
):
comp = parts[1].split("/", maxsplit=1)[-1]
repo_info["unofficial_components"].append(comp)
except Exception:
logging.exception("Error Retreiving Git Repo Info")
return repo_info
def get_software_info() -> Dict[str, Any]:
src_path = source_info.source_path()
if source_info.is_git_repo():
return get_repo_info(str(src_path))
pkg_ver = source_info.package_version() pkg_ver = source_info.package_version()
if pkg_ver is not None: if pkg_ver is not None:
return pkg_ver return {"software_version": pkg_ver}
version: str = "?" version: str = "?"
src_path = source_info.source_path()
try:
version = retrieve_git_version(str(src_path))
except Exception:
vfile = src_path.joinpath("moonraker/.version") vfile = src_path.joinpath("moonraker/.version")
if vfile.exists(): if vfile.exists():
try: try:
@ -98,8 +149,7 @@ def get_software_version() -> str:
except Exception: except Exception:
logging.exception("Unable to extract version from file") logging.exception("Unable to extract version from file")
version = "?" version = "?"
return version return {"software_version": version}
def hash_directory( def hash_directory(
dir_path: Union[str, pathlib.Path], dir_path: Union[str, pathlib.Path],