oliverdavies.uk/source/_daily_emails/2024-07-29.md

1.8 KiB

title date permalink tags cta snippet
Don't run code formatting in your CI pipeline 2024-07-29 daily/2024/07/29/dont-run-code-formatting-in-your-ci-pipeline
software-development
continuous-integration
pipelines
git
~ Why I don't run code formatting tools in my CI pipelines.

Something I commonly used to see, and did myself, was running code formatting tools, such as PHP CS Fixer or prettier, automatically their CI pipeline.

And not using it as a check to fail the pipeline if your code isn't formatted correctly.

Running it, fixing any code and committing any updates.

It wasn't long before I stopped doing this.

Firstly, I wasn't comfortable with a CI pipeline have write access to my codebase. It's fine to be able to clone it and run checks against it, but making changes to my code and pushing it makes me nervous.

Particularly if you're doing trunk-based development and everyone works on the same branch.

This also causes additional upstream commits, because the pipeline has committed a change. If you don't remember to pull those commits, you can end up in a tricky situation.

I'm also not a fan of having a lot of php-cs-fixer fixes or prettier fixes commits. I'd prefer the commits be correct when they're pushed, if possible, which is why I usually do micro commits locally and tidy things before pushing them.

If you're working on a topic branch and creating a pull or merge request, you can squash commits when merging, but I'm not a fan of squashing commits, either.

Instead of relying on a CI pipeline to run code formatting, make it easy to run those tasks locally.