Skip to main content

Interactive Git release cleanup and checkout utility.

Project description

🧹 Release Clean — Deterministic Git cleanup and release checkout

Python License Last Commit Open Issues

PyPI Version PyPI Downloads PyPI


Release Clean is a deterministic Git utility designed to clean, reset, and position your local repository into a trusted release state before working on a specific release branch.

Its goal is simple and critical:

Ensure that your local environment is clean, consistent, and aligned with the correct release version, eliminating any hidden state that could compromise reliability.


🎯 Purpose

Release Clean was created to solve a common and dangerous problem in release workflows:

How can we guarantee that a developer’s local environment is not polluted before switching to a release branch?

Typical risks include:

  • Residual build artifacts
  • Ignored files affecting runtime behavior
  • Untracked inconsistencies between developers
  • Dirty working trees
  • Outdated local branches

The solution is not manual cleanup — it is deterministic cleanup based on the repository state.


✨ Key Features

  • 🧹 Cleanup based on .gitignore:

    • uses git clean -fdX
  • 🧩 Preserves node_modules/ to improve developer experience

  • 🔄 Reset of tracked changes:

    • git checkout -- .
  • 🌿 Safe synchronization of main

  • 🚀 Deterministic checkout of release/<VERSION>

  • 🔁 Pull of remote release branch

  • 🔍 Validation of:

    • Git repository context
    • Version format
  • ⚠️ Explicit confirmation (y/N) before destructive actions

  • 🛑 Immediate stop on first failure

  • 📋 Full execution trace (audit-friendly)

  • 🎨 Highlighted execution steps (bold magenta)

  • 🧩 Zero external dependencies (pure Python)


🧠 Operational Philosophy

Release Clean follows a strict principle:

The only reliable environment is a deterministic environment.

Instead of relying on manual cleanup or assumptions, the tool ensures that:

  • Cleanup is aligned with .gitignore
  • The working tree is fully reset
  • The correct branch is used
  • No hidden state leaks into the release

This ensures consistency across machines, teams, and environments.


⚙️ Executed Workflow

Release Clean executes the following sequence:

git clean -fdX -e node_modules/
git checkout -- .
git checkout main
git pull
git fetch --all
git checkout release/<VERSION>
git checkout -- .
git pull origin release/<VERSION>

🔍 Workflow Breakdown

1. Clean ignored files

git clean -fdX -e node_modules/
  • Removes all files listed in .gitignore
  • Preserves node_modules/ to avoid unnecessary reinstalls

2. Reset tracked changes

git checkout -- .
  • Discards all tracked local changes

3. Synchronize base branch

git checkout main
git pull
git fetch --all
  • Ensures main is up to date

4. Switch to release branch

git checkout release/<VERSION>

5. Enforce clean state on release

git checkout -- .
  • Guarantees no local state leaks into the release branch

6. Update release branch

git pull origin release/<VERSION>

🚀 Installation

Requirements

  • Python 3.9+
  • Git installed and available in PATH

🍎 macOS Installation (recommended)

1️⃣ Install pipx

python3 -m pip install --user pipx
python3 -m pipx ensurepath

⚠️ Restart your terminal after installation.


2️⃣ Navigate to project directory

cd release-clean

3️⃣ Install globally

pipx install .

Now the command is available globally:

release-clean

▶️ Quick Test

release-clean

If the interactive prompt appears, installation is successful ✅


🔍 Optional Checks

which release-clean
pipx list

🧹 Updating

pipx reinstall release-clean

❌ Uninstall

pipx uninstall release-clean

⚠️ Important Notes

  • Do not use sudo pip install
  • Do not install CLI tools with system Python
  • Always prefer pipx for CLI isolation

🧠 Rule of Thumb

Python library → pip install Python CLI tool → pipx install


🧾 Usage

Run inside a Git repository:

release-clean

🔄 Execution Flow

  1. Prompt for version
  2. Validate version format
  3. Validate Git repository
  4. Display execution plan
  5. Request confirmation (y/N)
  6. Execute workflow
  7. Stop on first failure
  8. Print final summary

📌 Version Format

Accepted formats:

  • 1.0.0
  • 2.100.1
  • 2.100.1-hotfix
  • 3.4.5-rc1

Invalid examples:

  • 1.0
  • release/1.0.0
  • empty values

⚠️ Important Behavior

🔥 Cleanup behavior

git clean -fdX -e node_modules/

This means:

Type of file Behavior
.gitignore files ❌ removed
tracked files ❌ reset
node_modules/ ✅ preserved

⚠️ Destructive actions

The tool will:

  • remove ignored files
  • discard tracked changes
  • change branches

Execution only proceeds with explicit confirmation:

Continue? [y/N]

📊 Execution Summary

At the end, Release Clean prints:

  • 🕒 Start and end time
  • 📁 Repository path
  • 🌿 Version and branch
  • ✅ Successful actions
  • ❌ Failed actions
  • 📋 Full command list in execution order

🛡️ Ideal Use Cases

  • Preparing local environment before a release
  • Eliminating “works on my machine” issues
  • Teams using release/<version> strategy
  • Multi-developer environments
  • Regulated or mission-critical systems

🔮 Future Enhancements

  • --dry-run mode (preview cleanup)

  • --version (non-interactive execution)

  • --no-color

  • --ci (auto-confirm)

  • Configurable exclusions (--exclude node_modules)

  • Summary export (.md, .txt)

  • Integration with:

    • Slack
    • Discord
    • Jira

📜 License

MIT License.


👤 Author

André Argôlo CTO • Software Architect • DevOps


🧭 About

Release Clean embodies a key engineering principle:

A clean environment is not optional — it is a prerequisite for reliability.

In modern development, subtle local inconsistencies can lead to:

  • hidden bugs
  • inconsistent builds
  • unreliable validations

Release Clean eliminates that risk by enforcing:

  • deterministic cleanup
  • explicit control
  • reproducible state

It is a minimal tool with a strong purpose:

protect the integrity of your release process.

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

release_clean-1.0.1.tar.gz (8.7 kB view details)

Uploaded Source

Built Distribution

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

release_clean-1.0.1-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file release_clean-1.0.1.tar.gz.

File metadata

  • Download URL: release_clean-1.0.1.tar.gz
  • Upload date:
  • Size: 8.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for release_clean-1.0.1.tar.gz
Algorithm Hash digest
SHA256 7e51ea93aac419b18fc925392ec1fa1ab34d024d58b3dfcce9d65fb93e7bedc3
MD5 e5a44fe13ceeea4d1a985198aef866d9
BLAKE2b-256 5a6d8378d3a90c4af8b322bef9c3df9dba84b05c3c187d2e4de0c2a235317f3e

See more details on using hashes here.

Provenance

The following attestation bundles were made for release_clean-1.0.1.tar.gz:

Publisher: release.yml on argolo/release-clean

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

File details

Details for the file release_clean-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: release_clean-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 10.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for release_clean-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c4db45aa5bc36e971c6ad4088b9c36cc98dde192d6831f6d2081e0721c582006
MD5 2da96c2cc5321833f86e60e9c7b6e121
BLAKE2b-256 06f56dd3ae219189d7a7f4beabda573571b25558bbdd73545949535878fcab2c

See more details on using hashes here.

Provenance

The following attestation bundles were made for release_clean-1.0.1-py3-none-any.whl:

Publisher: release.yml on argolo/release-clean

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