Skip to main content

Standardized Django deployment pipeline with Docker, testing, and SonarQube integration

Project description

ITW Python Builder

Standardized Django deployment pipeline with Docker, testing, SonarQube integration, automatic changelog generation, and code quality enforcement.

Features

  • Automated deployment with semantic versioning
  • Docker/Podman-based build and push pipeline
  • Automated testing with coverage
  • SonarQube static code analysis
  • Pylint linting with SonarQube integration
  • Quality gates - deploy only when tests pass
  • Automatic changelog generation from commit trailers
  • Support for local and production pipelines
  • Global CLI tool
  • Automatic venv detection per project

Installation

pip install itw-python-builder

Install globally (outside any project venv). The itw command becomes available system-wide.

Quick Start

  1. Navigate to your Django project directory (must have a .venv or venv):

  2. Initialize versioning:

itw tag-init
  1. Run local pipeline:
itw pipelinelocal
  1. Deploy to staging:
itw incrementrc
  1. Deploy to production:
itw incrementpatch

Available Commands

Deployment Commands

  • itw incrementpatch — Increment patch version and deploy
  • itw incrementminor — Increment minor version and deploy
  • itw incrementmajor — Increment major version and deploy
  • itw incrementrc — Increment release candidate (staging)
  • itw release — Promote RC to stable release (master)

Local Development Commands

  • itw pipelinelocal — Run full local pipeline (lint → test → analyze → build)
  • itw lintlocal — Run pylint with human-readable output
  • itw lint — Run pylint and generate SonarQube report files
  • itw buildlocal — Build Docker image locally
  • itw testlocal — Run tests locally
  • itw analyzelocal — Run SonarQube analysis locally
  • itw changelog — Generate changelog manually
  • itw tag-init — Initialize version tagging

Skip Pipeline

itw incrementpatch --skip-pipeline

Virtual Environment Detection

itw is installed globally but automatically detects the project's virtual environment (.venv or venv) in the current directory. Tasks that need Python/Django dependencies (test, lint, analyze) activate the venv automatically — no need to manually activate it.

If no venv is found, those tasks will error with a clear message. Tasks that only use git (like changelog, tag-init, buildlocal) work without a venv.

Linting

The pipeline runs pylint automatically on every deployment and generates report files for SonarQube. The .pylintrc configuration is shipped with the package — no config files needed in your project.

# Review issues with human-readable output
itw lintlocal

# Generate report files for SonarQube
itw lint

Add this to your sonar-project.properties:

sonar.python.pylint.reportPaths=pylint-report.txt

Changelog Generation

Changelog entries are generated automatically on every deployment based on commit messages. To categorize a commit, add a Changelog: trailer to the commit body:

add user authentication

Changelog: added

Available categories: added, fixed, changed, deprecated, removed, security, performance, tests, docs, refactor

Commits without a trailer appear under Other Changes. The CHANGELOG.md file is committed and pushed automatically with each deployment.

Requirements

  • Python 3.10+
  • Podman
  • Git
  • SonarQube server

Configuration

Environment Variables

Add to your project .env:

SONAR_HOST_URL=https://your-sonar-server
SONAR_TOKEN=your-token
GIT_DEPTH=0

Project Files Required

  • Git repository with develop, staging, and master branches
  • VERSION file in project root
  • Dockerfile
  • sonar-project.properties

License

MIT

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

itw_python_builder-0.1.10.tar.gz (17.5 kB view details)

Uploaded Source

Built Distribution

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

itw_python_builder-0.1.10-py3-none-any.whl (17.3 kB view details)

Uploaded Python 3

File details

Details for the file itw_python_builder-0.1.10.tar.gz.

File metadata

  • Download URL: itw_python_builder-0.1.10.tar.gz
  • Upload date:
  • Size: 17.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for itw_python_builder-0.1.10.tar.gz
Algorithm Hash digest
SHA256 ad1a31dd3e8c10fd89d1650e392c1fb77358048cd41f62d8a3b9130610231730
MD5 c27600fe7cdde91d7f5081ce832c348b
BLAKE2b-256 cf4eae03553b4cb5b85fbe9298dd72cf07ec4aad0561e42cbd3f4cfb31d53e6f

See more details on using hashes here.

File details

Details for the file itw_python_builder-0.1.10-py3-none-any.whl.

File metadata

File hashes

Hashes for itw_python_builder-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 dca442b8df9ba1e39571f499767ea61c3ac30495866a429088de8d332c5436b3
MD5 3b3187817a4c4bf0ad202a0b5917068b
BLAKE2b-256 12a1db236856dfeccc2fdfae3831ef77b4ae0f3cbcc0cb78d0b86e1ac76f6474

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