Skip to main content

Modern Python Package Deployment Tool

Project description

pkg-deploy

Modern Python Package Deployment Tool

What is it

pkg-deploy is a comprehensive Python package deployment tool that streamlines the process of building, versioning, and publishing Python packages to PyPI and private repositories. It supports both standard and Cython builds, automatic version management, and seamless Git integration.

Features

  • Automatic Version Management: Support for semantic versioning with patch, minor, major, alpha, beta, and release candidate bumps
  • Flexible Build System: Standard Python builds and optimized Cython compilation
  • Multiple Repository Support: Deploy to PyPI, private Nexus repositories, and custom package indexes
  • Git Integration: Automatic tagging and commit management
  • Environment Detection: Native support for both pip and uv virtual environments
  • Dry Run Mode: Test deployments without making actual changes
  • Interactive Authentication: Secure credential input with API token support
  • Automatic Cleanup: Clean removal of build artifacts after deployment

Installation

From PyPI

pip install pkg-deploy

Quick Start

Basic Usage

Create a deploy.py file in your project root directory (the same folder containing your pyproject.toml):

my-package/
├── src/
│   └── my_package/
│       ├── __init__.py
│       └── main.py
├── pyproject.toml
├── README.md
└── deploy.py  ← Create this file

With the following contents:

from pkg_deploy import PackageDeploy
PackageDeploy().deploy()

Running the Deployment

You can run the deployment in two ways:

Option 1: Command Line

Run the script directly with command-line arguments:

# Deploy with patch version bump to PyPI
python deploy.py --repository-name pypi --version-type patch

# Deploy to private repository with minor version bump
python deploy.py --repository-url https://nexus.example.com/repository/pypi-internal/ \
                 --username admin --password secret --version-type minor

# Dry run to test configuration
python deploy.py --repository-name pypi --version-type patch --dry-run

Option 2: IDE with Arguments

If running from an IDE, modified the deploy.py file to run it programmatically:

import sys
from pkg_deploy import PackageDeploy

# Set arguments for IDE execution
sys.argv = [
    'deploy.py',
    '--repository-name', 'pypi',
    '--version-type', 'patch',
    '--dry-run'
]

PackageDeploy().deploy()

Configuration

pyproject.toml

Ensure your pyproject.toml includes the required project metadata:

[build-system]
requires = ["setuptools>=70"]
build-backend = "setuptools.build_meta"

[project]
name = "your-package-name"
version = "1.0.0"
description = "Your package description"
requires-python = ">=3.10"
authors = [
    { name = "Your Name", email = "your.email@example.com" },
]
readme = "README.md"
dependencies = [
    "dependency1",
    "dependency2",
]

[tool.setuptools]
package-dir = {"" = "src"}
zip-safe = false

[tool.setuptools.packages.find]
where = ["src"]

# Optional: Version bump configuration, other wise will only bump version in pyproject.toml
[[tool.bumpversion.file]]
filename = "src/your_package/__init__.py"
search = '__version__ = "{current_version}"'
replace = '__version__ = "{new_version}"'

.pypirc Configuration

For repository authentication, create a .pypirc file in your user home directory:

  • Unix/macOS: ~/.pypirc
  • Windows: C:\Users\username\.pypirc
[distutils]
index-servers =
    pypi
    private-repo

[pypi]
repository = https://upload.pypi.org/legacy/
username = __token__
password = pypi-your-api-token-here

[private-repo]
repository = https://nexus.example.com/repository/pypi-internal/
username = your-username
password = your-password

Usage Examples

Version Management

# Patch version bump (1.0.0 -> 1.0.1)
python deploy.py --repository-name pypi --version-type patch

# Minor version bump (1.0.1 -> 1.1.0)
python deploy.py --repository-name pypi --version-type minor

# Major version bump (1.1.0 -> 2.0.0)
python deploy.py --repository-name pypi --version-type major

# Use specific version
python deploy.py --repository-name pypi --new-version 2.1.0

# Pre-release versions
python deploy.py --repository-name pypi --version-type alpha  # 1.0.0a1
python deploy.py --repository-name pypi --version-type beta   # 1.0.0b1
python deploy.py --repository-name pypi --version-type rc     # 1.0.0rc1

Cython Builds

# Build with Cython optimization
python deploy.py --repository-name pypi --version-type patch --cython

# Cython build for private repository
python deploy.py --repository-url https://nexus.example.com/repository/pypi-internal/ \
                 --username admin --password secret --cython

Advanced Options

# Custom project directory
python deploy.py --project-dir /path/to/project --repository-name pypi

# Skip Git operations
python deploy.py --repository-name pypi --skip-git-push

# Verbose logging
python deploy.py --repository-name pypi --verbose

# Dry run with verbose output
python deploy.py --repository-name pypi --dry-run --verbose

Command Line Interface

Arguments

  • --project-dir: Project directory (default: current directory)
  • --version-type, -vt: Version bump type: patch, minor, major, alpha, beta, or rc
  • --new-version, -v: Specify exact version number (overrides version-type)
  • --cython, -c: Enable Cython compilation for performance
  • --repository-name, -rn: Repository name from .pypirc configuration (e.g., 'pypi', 'testpypi')
  • --repository-url, -rl: Repository upload URL (prompts for username/password if not in .pypirc)
  • --username, -u: Authentication username (optional if configured in .pypirc)
  • --password, -p: Authentication password/token (optional if configured in .pypirc)
  • --skip-git-push: Skip pushing version changes and tags to Git repository
  • --skip-git-status-check: Skip Git status validation before deployment
  • --dry-run: Simulate deployment without making actual changes
  • --verbose, -V: Enable detailed logging output

Environment Support

UV Virtual Environments

pkg-deploy automatically detects and supports UV-managed virtual environments:

Security Considerations

API Tokens (Recommended)

For PyPI, use API tokens instead of passwords:

  1. Generate token at https://pypi.org/manage/account/token/
  2. Use __token__ as username
  3. Use the generated token as password

Credential Storage

  • Store credentials in .pypirc for reusability
  • Enable interactive mode for secure input

Troubleshooting

Common Issues

Git Repository Not Clean

Error: Git repo is NOT clean

Solution: Commit or stash your changes before deployment or use --skip-git-push.

Missing Dependencies

Error: Missing required packages: build, twine

Solution: Install missing packages with pip install build twine.

Cython Build Conflicts

Error: Cannot build Cython code: setup.py already exists

Solution: Backup existing setup.py or migrate configuration to pyproject.toml.

Authentication Failures

Error: 403 Forbidden

Solution: Verify credentials, use API tokens for PyPI, or enable interactive mode.

Debug Mode

Enable verbose logging for detailed troubleshooting:

python deploy.py --repository-name pypi --verbose --dry-run

pkg-deploy - Streamlining Python package deployment since 2025.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

pkg_deploy-1.0.2-py3-none-any.whl (19.9 kB view details)

Uploaded Python 3

File details

Details for the file pkg_deploy-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: pkg_deploy-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 19.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for pkg_deploy-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d5030132bb2c2d3b5324f95ceac8ccfaa2499dffd7b38e8e9890e8d89cadd13e
MD5 37ac798d71a1dab7eaba20426caa9009
BLAKE2b-256 47fbbc4cdc182efa270007f618809594c6edfef15f7fd6d8ceb8e119f864de52

See more details on using hashes here.

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