Skip to main content

A template library for Python library projects using Poetry and Semantic Release.

Project description

Python Library Template

Python library template with security scanning, automated publishing, and optional AWS integration.

CI Pipeline PyPI Python

Poetry Code style: black Linting: Ruff pre-commit Dependabot

pytest GitHub Actions Semantic Release AWS SAM License: AGPL v3

📊 Live Dashboards

📖 Documentation 🧪 Test Results 📊 Coverage 🔒 Security ⚖️ Compliance

⚡ What You Get

Zero-Config CI/CD Pipeline

  • Matrix testing with HTML reports
  • Automated security scanning (Bandit, Safety, pip-audit, Semgrep)
  • License compatibility checking and compliance reports
  • Semantic versioning with automated changelog generation

Enterprise-Grade Quality

  • Pre-commit hooks (Ruff, Black, conventional commits)
  • Test-driven development setup with Click CLI testing
  • Code coverage reporting with beautiful HTML dashboards
  • API documentation auto-generated and deployed to GitHub Pages

Modern Python Stack

  • Poetry dependency management with security/compliance groups
  • Trusted publishing to PyPI/TestPyPI (no API keys needed)
  • Optional AWS SAM integration with ephemeral test environments
  • Windows/Git Bash compatibility with comprehensive guidance

🚀 Quick Start

1. Get the Template

# Use as GitHub template or clone
gh repo create my-awesome-lib --template svange/augint-library --public
cd my-awesome-lib

2. Quick Setup

# Run the two-stage bootstrap
python bootstrap-stage1.py     # Template customization
python bootstrap-stage2.py     # AWS integration (after manual SAM setup)

What this does:

  • Customizes template with your project name
  • Sets up AWS pipeline infrastructure
  • Configures GitHub Actions OIDC authentication
  • Creates comprehensive development environment

📋 For detailed setup instructions, see BOOTSTRAP.md

3. Secure Your Secrets

# Add GitHub token to .env, then
chezmoi add .env
chezmoi git add . && chezmoi git commit -m "Add project secrets"

4. Go Live

poetry install && pre-commit install
git add . && git commit -m "feat: initial project setup"
git push

That's it! Your CI/CD pipeline is now running with full security scanning and automated publishing.

📋 Prerequisites

Required Tools:

PyPI Setup (Important - Do This First!):

  1. Reserve your package name on PyPI and TestPyPI
  2. Set up Trusted Publishing:
    • Publisher: GitHub Actions
    • Repository: your-account/your-repo
    • Workflow: pipeline.yaml
    • Environment: pypi

Windows Users:

# Install tools
winget install Python.Python.3.11
winget install twpayne.chezmoi
winget install --id FiloSottile.age

# Set environment for Claude Code
$env:CLAUDE_CODE_GIT_BASH_PATH="C:\Program Files\Git\bin\bash.exe"

AWS Setup (Optional - One Time Per Account):

# Enable GitHub Actions OIDC
aws iam create-open-id-connect-provider \
  --url https://token.actions.githubusercontent.com \
  --client-id-list sts.amazonaws.com

🏗️ Project Setup

This template uses a two-stage bootstrap process that eliminates common setup friction:

Stage Purpose When to Run
Stage 1 Template customization Immediately after cloning
Stage 2 AWS integration After sam pipeline bootstrap

Why two stages? This approach prevents dependency conflicts and handles the interactive SAM setup gracefully.

See BOOTSTRAP.md for complete setup instructions (delete after setup).

📚 Documentation Best Practices

API Documentation (Google-style docstrings):

def process_data(data: list[str], format: str = "json") -> dict:
    """Process input data and return formatted results.

    Args:
        data: List of strings to process.
        format: Output format ("json" or "xml").

    Returns:
        Processed data in specified format.

    Example:
        >>> process_data(["item1", "item2"])
        {"processed": ["item1", "item2"]}
    """

Library vs CLI Design:

  • Use __all__ to control public API surface
  • Keep CLI commands in separate modules
  • Document both library and CLI usage in module docstrings

🛠️ Development Workflow

# Daily development
poetry run pytest              # Run fast tests
poetry run pytest -m slow      # Run AWS integration tests  
poetry run ruff check --fix     # Lint and fix
poetry run black .              # Format code

# Security and compliance (CI runs these automatically)
poetry install --with security,compliance
poetry run bandit -r src/
poetry run safety check
poetry run pip-licenses

# Documentation
poetry run pdoc src/your_module  # Generate docs locally

💡 Pro Tips

  • Branch Protection: See .github/BRANCH_PROTECTION.md for recommended settings
  • Dependabot: Auto-merge is configured for safe updates (patch/minor)
  • Security Scans: Only run on main/dev branches to keep feature branches fast
  • Windows Users: All commands work in Git Bash, PowerShell, and CMD
  • Claude Code: Generate CLAUDE.md during bootstrap for AI-assisted development

🖥️ MCP Server Setup

  • Add MCP Servers: Use claude mcp add <server-name> to add servers for GitHub, AWS, and more.
    • GitHub MCP Server Setup:
      1. Ensure CLAUDE_GITHUB_PAT is set as an env var
      2. Run this command:
      claude mcp add-json github "{
        `"command`": `"docker`",
        `"args`": [
          `"run`",
          `"-i`",
          `"--rm`",
          `"-e`",
          `"GITHUB_PERSONAL_ACCESS_TOKEN`",
          `"ghcr.io/github/github-mcp-server`"
        ],
        `"env`": {
          `"GITHUB_PERSONAL_ACCESS_TOKEN`": `"$($env:CLAUDE_GITHUB_PAT)`"
        }
      }"
      
    • Context7: claude mcp add --transport sse context7 https://mcp.context7.com/sse
    claude mcp add --transport sse context7 https://mcp.context7.com/sse
    

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

augint_library-1.24.0.tar.gz (33.3 kB view details)

Uploaded Source

Built Distribution

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

augint_library-1.24.0-py3-none-any.whl (30.4 kB view details)

Uploaded Python 3

File details

Details for the file augint_library-1.24.0.tar.gz.

File metadata

  • Download URL: augint_library-1.24.0.tar.gz
  • Upload date:
  • Size: 33.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for augint_library-1.24.0.tar.gz
Algorithm Hash digest
SHA256 90674700a880ddcbf6eccbf8dfaeaf5777a72f50c1a833409edf09b549b0f3a9
MD5 b948a6c966eb1ad373b8214fa81681e5
BLAKE2b-256 9d17681279a53263b3841a98864f167740f34c32534da86299c052f0abadcc8e

See more details on using hashes here.

Provenance

The following attestation bundles were made for augint_library-1.24.0.tar.gz:

Publisher: pipeline.yaml on svange/augint-library

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

File details

Details for the file augint_library-1.24.0-py3-none-any.whl.

File metadata

File hashes

Hashes for augint_library-1.24.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a7a62ecd5a42664a6183a814cad3dd56af9e7308a0ede7d57d70d24ff4b29839
MD5 eed887cc88dd6b49ce685bea9674a849
BLAKE2b-256 6e25debc64f2f7e43655ba82c32d63c49d4478d180091e7555c3c4ff41648bbb

See more details on using hashes here.

Provenance

The following attestation bundles were made for augint_library-1.24.0-py3-none-any.whl:

Publisher: pipeline.yaml on svange/augint-library

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