data:image/s3,"s3://crabby-images/6668c/6668c70d0e273c7625716b098e3adefb284952da" alt="Teamcity pipeline"
data:image/s3,"s3://crabby-images/b2b7a/b2b7a69bec3b878cbad1e4e22fde9f835afc89a0" alt="teamcity pipeline teamcity pipeline"
In my team we use C# as a programming language, but these rules are more or less the same in other languages too. This is achieved by using rules you and your team has agreed upon. The idea of Continuous Integration (CI) is to ensure the proposed changes (by your PR) can be merged into the trunk without negatively affecting the existing code. Such a package is used by Octopus and is deployed automatically on each environment, starting from test and getting promoted to staging and production. we can always create a deployable package from master. The master branch is considered stable in terms of deployability, i.e. Tasks are created by the reviewers to improve the PR
data:image/s3,"s3://crabby-images/fcd04/fcd04f02fba5d1a3fb18797b406805078bfe45d1" alt="teamcity pipeline teamcity pipeline"
We apply trunk-based development, meaning all changes go to one master branch in our version control system (VCS) (we use git on BitBucket).
data:image/s3,"s3://crabby-images/bab59/bab5999b91c18d2e3da8df4038c4fd8236fedbb6" alt="teamcity pipeline teamcity pipeline"
I will focus on two concrete tools I have used in the past years – TeamCity and Octopus Deploy, which have helped me create automated deployment pipelines. In this post, I want to summarize my experience with creating deployment pipelines and I will try to provide as many details as possible, despite the broad topic. Nowadays it is essential to be able to deploy to production in a reasonably short amount of time and in an automated manner.
data:image/s3,"s3://crabby-images/6668c/6668c70d0e273c7625716b098e3adefb284952da" alt="Teamcity pipeline"