Monorepo in Azure DevOps
When working with projects using microservices architecture I opt for monorepo pattern. A single repository containing source code of all the services. It facilitates knowledge sharing between teams and encourages more unified programming style. Microservices give a lot of technological freedom, but this freedom should be used wisely. Common standards across the organization are still important.
Working with a single repository forces all the programmers to at least have a glance at the list of commits from other teams when making git pull
. This channel of knowledge sharing can be very beneficial.
Despite having a single repository, we still need separate pipelines and policies for separate directories. Azure DevOps facilitates it by allowing directory path filter in crucial places:
- path filter in build trigger settings
- branch policies
- required reviewers
It allows to setup a clear ownership of different parts of the repository and apply different pipelines to different parts of the repo while still having all the benefits of monorepo pattern.