Skip to content

tivaliy/python-gerritclient

Repository files navigation

PyPI Build Status Documentation Status Python Version

python-gerritclient

CLI tool and Python API wrapper for Gerrit Code Review

Requirements

Python 3.11+ is required. This project uses modern Python features and tooling.

Quick Start

Command Line Tool (Recommended: Using UV)

UV is a fast, modern Python package manager. Recommended for the best experience.

  1. Install UV (if not already installed):

    curl -LsSf https://astral.sh/uv/install.sh | sh
  2. Clone the repository:

    git clone https://github.com/tivaliy/python-gerritclient.git
    cd python-gerritclient
  3. Configure settings.yaml file (in gerritclient/settings.yaml):

    url: http://review.example.com
    auth_type: basic
    username: admin
    password: "1234567890aaWmmflSl+ZlOPs23Dffn"
    • url - Gerrit server URL in format <scheme>://<host>:<port> (e.g., https://review.openstack.org)
    • auth_type - HTTP authentication scheme (basic or digest), omit for anonymous access
    • username and password - user credentials from Gerrit (Settings → HTTP Password)
  4. Install dependencies and run:

    uv sync
    uv run gerrit --help
  5. Run commands:

    uv run gerrit plugin list
    uv run gerrit account list "john"

Command Line Tool (Alternative: Using pip)

  1. Clone the repository:

    git clone https://github.com/tivaliy/python-gerritclient.git
    cd python-gerritclient
  2. Configure settings.yaml (same as above)

  3. Install with pip:

    python3 -m venv venv
    source venv/bin/activate  # On Windows: venv\Scripts\activate
    pip install -e .
  4. Run commands:

    gerrit --help
    gerrit plugin list

Library Usage

Install the package:

# With UV
uv add python-gerritclient

# With pip
pip install python-gerritclient
from gerritclient import client

connection = client.connect("review.openstack.org", auth_type="digest" username="user-name", password="password")
group_client = client.get_client('group', connection=connection)
members = group_client.get_group_members('swift-core')  # or get_group_members(24)
print(', '.join(member['name'] for member in members))

Output result: Alistair Coles, Christian Schwede, Clay Gerrard, Darrell Bishop, David Goetz, Greg Lange, Janie Richling, John Dickinson, Kota Tsuyuzaki, Mahati Chamarthy, Matthew Oliver, Michael Barton, Pete Zaitcev, Samuel Merritt, Thiago da Silva, Tim Burke

What's New in v1.0

Major modernization release! This version brings python-gerritclient into the modern Python ecosystem:

🚀 Performance & Tooling

  • UV Package Manager: 10-100x faster dependency resolution and installation
  • Ruff Linting: 100x faster than flake8, instant code quality checks
  • Modern Python: Requires Python 3.11+ (dropped Python 2.7/3.5/3.6 support)

🏗️ Infrastructure

  • GitHub Actions CI/CD: Replaced Travis CI with modern GitHub Actions
  • Modern pyproject.toml: Migrated from legacy setup.py/setup.cfg
  • Setuptools Build Backend: Replaced pbr with modern setuptools

✨ Code Quality

  • Removed all Python 2 compatibility code (six library)
  • Applied 100+ code modernizations (modern super(), f-strings, etc.)
  • 96.7% test coverage (178/184 tests passing)

✅ Validated

Tested and working against Gerrit 3.13.1 (latest) on production instances (Android Code Review).

Compatibility

Gerrit Versions

  • Recommended: Gerrit 3.11+ (latest tested: 3.13.1)
  • Supported: Gerrit 2.14+ (backwards compatible)
  • API Coverage: ~45% of Gerrit REST API

Python Versions

  • Required: Python 3.11+
  • Tested: Python 3.11, 3.12, 3.13
  • Dropped: Python 2.7, 3.5, 3.6, 3.7, 3.8, 3.9, 3.10

Development

Setting Up Development Environment

  1. Install UV (recommended):

    curl -LsSf https://astral.sh/uv/install.sh | sh
  2. Clone and setup:

    git clone https://github.com/tivaliy/python-gerritclient.git
    cd python-gerritclient
    uv sync --all-extras
  3. Install in editable mode:

    uv pip install -e .

Running Tests

# Run unit tests with stestr
uv pip install stestr
uv run stestr run

# Run linting
uv run ruff check .

# Run formatting
uv run ruff format .

# Format check (CI)
uv run ruff format --check .

Code Quality Tools

  • Linter: Ruff - Fast Python linter
  • Formatter: Ruff format - Fast Python formatter
  • Test Runner: stestr - Parallel test runner
  • CI/CD: GitHub Actions

Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes
  4. Run tests and linting: uv run stestr run && uv run ruff check .
  5. Format code: uv run ruff format .
  6. Commit your changes (git commit -m 'Add amazing feature')
  7. Push to the branch (git push origin feature/amazing-feature)
  8. Open a Pull Request

License

Apache License 2.0

Credits

Originally created by Vitalii Kulanov