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.15.tar.gz (17.8 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.15-py3-none-any.whl (17.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: itw_python_builder-0.1.15.tar.gz
  • Upload date:
  • Size: 17.8 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.15.tar.gz
Algorithm Hash digest
SHA256 7997e3afe9707c2db37d83487d918d2a144029c33efa78c7f7afd68cfca783fe
MD5 e6a2ce60b24dceb9cce274e837972e07
BLAKE2b-256 a185e9169b6aa8036e80bb70022a7e0cd27dec1775a7661313df7698940a1ff6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for itw_python_builder-0.1.15-py3-none-any.whl
Algorithm Hash digest
SHA256 68ae77a576a380284c1f2849647b6718919627fd34c09425d4f31f948fa25645
MD5 856e138fbdc2b612b978a499fdadca02
BLAKE2b-256 78fff7616a739ee4da755f0b0f41b4e67a1a8593e712da6c27839a47d8c340ec

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