This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the workflows category.
Last Updated: 2025-01-18
We had a long Makefile
used as a grab-box for commands)
log:
docker-compose logs -f ${container}
build_production:
docker-compose rm -vsf
docker-compose down -v --remove-orphans
docker-compose -f docker-compose.yml -f docker-compose-production.yml build
docker-compose -f docker-compose.yml -f docker-compose-production.yml up -d
I was asked to append a deploy
command, which really just did bin/deploy
.
Seeing the obvious patten, I added the following entry:
deploy:
bin/deploy
Because I knew that running this command make deploy
would not work on my
machine due to credential issues, I committed my changes and pushed without
testing.
My client then ran the make build_production
(a different command) and it was
suddenly broken. Somehow my adding a seemingly unrelated command broke all of
them! Here was the error:
Makefile:39: *** missing separator. Stop.
The issue? Makefiles require tabs not spaces....
As a new Makefile
user, I couldn't have easily known this old-fashioned
constraint beforehand, so this mistake was forgiveable.
What wasn't forgiveable was that I should have tested the changes in some
way before pushing the code. Even though, yes, I could not have deployed, I should have
unit-tested the change to the Makefile
by at least seeing if the deploy script
got called. That would have made me realize the entire Makefile was broken.