Etsy Storefront
Let me be honest: Git has punched me in the face more times than I can count. Every time I think I’ve got a smooth release flow down, Git yells, “Not so fast!” and two quick jabs, a left hook an uppercut and I’m on the mat wondering what happened: Branches out of sync, conflicts popping up like whack-a-moles, version numbers that look more like lottery tickets… it’s been a mess.
But after a lot of hacking, stashing, and learning the hard way, I finally landed a process I can follow with confidence. And let me tell you—it feels good to know that the code I’m releasing is actually the code that ends up on PyPI and GitHub, not some Frankenstein version stitched together at the last second.
Here’s how I got here.
When I started this project, I didn’t really have any branching strategy. Everything happened in main, which meant that anyone who tried cloning the repo would likely end up with a broken snapshot.
I’m a systems architect, I really and truly appreciate the value of Git and all of the features it brings. I just couldn’t figure out how to use it effectively. When I ventured into the wonderful world of branching, branching off a branch, merging…. let’s just say, I didn’t fare well. Things would go sideways, and my 0.15.0 would be 0.15.8 by the time I got things sorted.
It became obvious, that I needed a plan—something clear and repeatable. So I sat down and wrote out a branching strategy: main for stable releases, dev for integration, feature branches for new work, release branches for final prep, and bugfix branches off main. It’s not just high level, it has every command I needed. To be honest, it’s about 95% there.
I documented this process, not just in the repo, but also in my knowledge base outside the project. Because here’s the kicker: the release process itself kept changing as I switched branches and updated docs inside the repo. It was like trying to follow a map that redraws itself every few steps. Keeping a stable, external copy of the doc saved my sanity.
The big eye-opener? That infamous pyproject.toml version bump conflict. Both main and the release branch had different version numbers, and Git wanted me to pick a side. I learned to spot and fix those conflicts quickly, and now I make sure to bump the version only on the release branch.
Also, stashing is my best friend. When main was a mess, I’d stash the chaos, do the merge, then drop the stash because I didn’t actually want those local changes. It’s not elegant, but it saved my bacon more than once.
Finally, after simulating the entire release process—feature branch, merge to dev, release branch, bump version, merge to main, tag, push—I got it all pushed to GitHub and PyPI with no surprises.
The best moment? Creating a fresh virtual environment, installing my package from PyPI, and seeing that it was the exact code I meant to release. That’s the sweet spot.
And don’t be shy, have a Git veteran by your side as you step through the process.
Git will probably keep punching me, but I’m no longer running scared. I’ve got a plan, a process, and a sense of control. If you’re struggling too, stick with it—there’s a light at the end of the Git tunnel, and it’s worth the fight.
Got your own Git war stories? I’d love to hear them.
Introduction
Introduction
A Complicated Setup
Round One Knockout
Textual Documentation Error
What I Started With:
Hey folks,
A Modest Module That Found Its Moment
As part of my goal to be more visible in the world, I setup this domain i.e. https://osoyalc.com. I use it to publish information about the projects I’m work...
It’s been a while since I started and then abandoned this blog. My last post was in June of 2024!!
I decided that I didn’t like the way that the main blog page looks. I am using GitHub to host the website and am using a fork of the jekyll/minima theme. My ...
Current Status
Impromptu Poetry
Hey Folks,
I can’t help but notice the trope of the evil AI is a bit overused in Sci-Fi media. But I think films like Atlas are starting to shift the narrative and show...
Hello Friends!
This is it! I’m embarking on my blogging journey! It’s exciting, exhilerating and I’m a tiny bit nervous too. But, as my good friend Sally told me,