pmb.ci package¶
Module contents¶
- class pmb.ci.CiScriptDescriptor¶
Bases:
TypedDict
- artifacts: str | None¶
- description: str¶
- options: list[str]¶
- pmb.ci.ask_which_scripts_to_run(scripts_available: dict[str, CiScriptDescriptor]) dict[str, CiScriptDescriptor] ¶
Display an interactive prompt about which of the scripts the user wishes to run, or all of them.
- Parameters:
scripts_available – same format as get_ci_scripts()
- Returns:
either full scripts_available (all selected), or a subset
- pmb.ci.copy_git_repo_to_chroot(topdir: Path) None ¶
Create a tarball of the git repo (including unstaged changes and new files) and extract it in chroot_native.
- Parameters:
topdir – top directory of the git repository, get it with: pmb.helpers.git.get_topdir()
- pmb.ci.get_ci_scripts(topdir: Path) dict[str, CiScriptDescriptor] ¶
Find ‘pmbootstrap ci’-compatible scripts inside a git repository, and parse their metadata (description, options). The reference is at: https://postmarketos.org/pmb-ci
- Parameters:
topdir – top directory of the git repository, get it with: pmb.helpers.git.get_topdir()
- Returns:
a dict of CI scripts found in the git repository, e.g. {“ruff”: {“description”: “lint all python scripts”, “options”: []}, …}
- pmb.ci.run_scripts(topdir: Path, scripts: dict[str, CiScriptDescriptor]) None ¶
Run one of the given scripts after another, either natively or in a chroot. Display a progress message and stop on error (without printing a python stack trace).
- Parameters:
topdir – top directory of the git repository, get it with: pmb.helpers.git.get_topdir()
scripts – return of get_ci_scripts()
- pmb.ci.sort_scripts_by_speed(scripts: dict[str, CiScriptDescriptor]) dict[str, CiScriptDescriptor] ¶
Order the scripts, so fast scripts run before slow scripts. Whether a script is fast or not is determined by the ‘# Options: slow’ comment in the file.
- Parameters:
scripts – return of get_ci_scripts()
- Returns:
same format as get_ci_scripts(), but as ordered dict with fast scripts before slow scripts