#release-engineering (2022-05)
All things CI/CD. Specific emphasis on Codefresh and CodeBuild with CodePipeline.
CI/CD Discussions
Archive: https://archive.sweetops.com/release-engineering/
2022-05-17
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
New tool for managing self hosted GitHub runners, https://cloudbase.it/manage-your-own-github-runners-using-garm/
Garm is a self-hosted, automated system that maintains pools of GitHub runners on potentially any IaaS which has an API that will allow us to create compute resources.
2022-05-18
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
We recently moved to a monorepo in gitlab. I setup the pipeline to run jobs based on what files have changed using rules:changes
. Unfortunately I missed this gem in the troubleshooting section until after the changes were released:
The changes rule always evaluates to true when pushing a new branch or a new tag to GitLab.
So now every new branch is building and deploying all apps instead of just the one(s) with changes. Anyone run into this? Any recommendations on fixes?
I’m hoping to avoid adding some sort of check to all jobs as to whether or not they should run and exit early if not.
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
Looks like the way to go is dynamic pipelines. https://infinitelambda.com/post/dynamic-pipeline-generation-gitlab/
data:image/s3,"s3://crabby-images/0c7f6/0c7f6e3080aa788fd941ca63cc7a0601ffc438be" alt="attachment image"
Dynamic pipeline generation on GitLab: see how to create a well-organised yaml file with less effort and make your life easier with automation.
data:image/s3,"s3://crabby-images/e66aa/e66aaef0f2aea03cffe304c6b4886d150b5f98c1" alt="Brandon avatar"
Can’t you just add - when:never
to the bottom of the rules section to stop any other non specified rules
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
Since the changes rule always evaluates to true when pushing a new branch or tag, that wouldn’t help.
data:image/s3,"s3://crabby-images/ccb0d/ccb0dfb2c1c2d5a447c28b1321995b6c10efeaaa" alt="Zeeshan S avatar"
@bradym interesting .. as I am seeing a host of other issues with a monorepo and we are thinking to separate at least the infrastructure as a code out of the repo
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
I’m not at all a fan of using a monorepo, it makes everything more difficult when it comes to CI.
data:image/s3,"s3://crabby-images/10a98/10a98ef184c122ac883080c44ef50d9ae835fc49" alt="tommy avatar"
@bradym You can still separate these repos and develop separately while have a monolithic view with google repo tools or something like that.
data:image/s3,"s3://crabby-images/10a98/10a98ef184c122ac883080c44ef50d9ae835fc49" alt="tommy avatar"
Link to the tool: https://gerrit.googlesource.com/git-repo/