Skip to main content

Shared CI / build tooling for the Juniper ML platform (dependency-documentation generator + workflow-script-path lint + AGENTS.md version-drift lint + AGENTS.md header-schema lint)

Project description

juniper-ci-tools

Shared CI / build tooling for the Juniper ML platform.

This package is the single source of truth for the dependency-documentation generator that historically lived as scripts/generate_dep_docs.sh (or util/generate_dep_docs.sh) in every Juniper repo. Three variants of that script drifted on origin/main; the 2026-05-20 bug fix in juniper-cascor#276 (switching the conda-dependency extraction from sed to awk to avoid emitting an invalid trailing prefix: / variables: key) shipped in 1 of 8 repos. This package distributes that fix as pip install-able tooling so it cannot drift again.

This work mirrors the juniper-doc-tools PyPI migration plan that addressed the analogous 2026-05-18 doc-link validator incident.

Installation

pip install juniper-ci-tools

This installs two console scripts:

  • juniper-generate-dep-docs — dependency-documentation generator (the consolidated scripts/generate_dep_docs.sh port; see "Usage" below).
  • juniper-lint-workflow-paths — lints that every python|bash <path> invocation in .github/workflows/*.yml references a file that exists on disk. Added in 0.2.0; consolidates the 6 byte-identical copies of util/test_workflow_script_paths.py that existed across consumer repos.

The package requires Python 3.11 or newer and depends on PyYAML.

Usage

Run from the root of any Juniper repo that has a pyproject.toml:

juniper-generate-dep-docs

Equivalent module form:

python -m juniper_ci_tools

This will:

  1. Create conf/ if needed.
  2. Back up any existing conf/requirements_ci.txt with a timestamp infix.
  3. Render notes/PIP_DEPENDENCY_FILE_HEADER.md (substituting placeholders like <X.Y.Z ...>, <YYYY-MM-dd ...>, <Python Version>, <Pip Version>) and append pip list --format=freeze output.
  4. If conda is on PATH: back up any existing conf/conda_environment_ci.yaml, render notes/CONDA_DEPENDENCY_FILE_HEADER.md, append the dependency block extracted from conda env export --no-builds (using the awk-equivalent logic that produces valid YAML), and validate the result with yaml.safe_load.

If conda is not available the conda step is skipped with a warning (matches the legacy bash script). If the generated YAML fails to parse, the command exits non-zero.

CLI options

Flag Default Purpose
--repo-root cwd Repo root containing pyproject.toml
--conf-dir conf Output directory
--notes-dir notes Directory containing header templates
--pip-header PIP_DEPENDENCY_FILE_HEADER.md Pip header template filename
--conda-header CONDA_DEPENDENCY_FILE_HEADER.md Conda header template filename
--pip-filename requirements_ci.txt Pip output filename
--conda-filename conda_environment_ci.yaml Conda output filename
--no-conda off Skip conda generation even if conda is installed
--no-yaml-validation off Skip yaml.safe_load on generated conda file

Library API

from juniper_ci_tools import generate_dep_docs

result = generate_dep_docs(repo_root="/path/to/repo")
print(result.pip_file, result.conda_file, result.yaml_validated)

See the package's juniper_ci_tools/generate_dep_docs.py docstring for the full surface.

Development

cd juniper-ci-tools
pip install -e ".[test]"
pytest

License

MIT. Copyright (c) 2024-2026 Paul Calnon.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

juniper_ci_tools-0.4.0.tar.gz (31.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

juniper_ci_tools-0.4.0-py3-none-any.whl (28.9 kB view details)

Uploaded Python 3

File details

Details for the file juniper_ci_tools-0.4.0.tar.gz.

File metadata

  • Download URL: juniper_ci_tools-0.4.0.tar.gz
  • Upload date:
  • Size: 31.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for juniper_ci_tools-0.4.0.tar.gz
Algorithm Hash digest
SHA256 520b4da6be0bbc2dc016f82a74db318f612fb30e1bce2de32622c521d62abc06
MD5 b397ccbe95e83687f537c019c28f346b
BLAKE2b-256 566e8bba73631bc01c9a4c8fee4a310fb22964d7b4a27d164307fea41962bdde

See more details on using hashes here.

Provenance

The following attestation bundles were made for juniper_ci_tools-0.4.0.tar.gz:

Publisher: publish-ci-tools.yml on pcalnon/juniper-ml

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file juniper_ci_tools-0.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for juniper_ci_tools-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8f2bd7ef1378d55469b130a991433df0977908d4c3bb50fac047114b63439b5a
MD5 759604d2bb36a09b185b06f5d78c636a
BLAKE2b-256 63d4e2e10036920911ad73bfb6084512f42c08f2fb8ae2901da5ff721efb4979

See more details on using hashes here.

Provenance

The following attestation bundles were made for juniper_ci_tools-0.4.0-py3-none-any.whl:

Publisher: publish-ci-tools.yml on pcalnon/juniper-ml

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page