Build Dependencies Setup
Introduction
In many cases it is convenient to use output of one build in another, as well as to run a number of builds sequentially on the same sources. Consider a typical example - you have a cross-platform project that has to be tested under Windows and Mac before you get the production build. The best workflow for this simple case would be to:
Compile your project
Run tests under Windows and Mac simultaneously on the same sources
Build a release version, again, on the same sources and, of course, if tests have passed under both OSs.
This can be easily achieved by configuring dependencies between your build configurations in TeamCity that would look like this: Where compile, tests (win), tests (mac) and pack setup are build configurations, and naturally tests depend on compilation, which means they should wait till compilation is ready.
Basics
Generally known as "build pipeline" in TeamCity similar concept is referred to as "Build Chain". Before getting into details on how this works in TeamCity, let's clarify the legend behind diagrams given here (including the one in the introduction):
A build configuration. | |
---|---|
snapshotDep between 2 build configurations. Note, that the arrow shows the sequence of triggering build configurations, the build chain flow, meaning that B is executed before A. However the dependencies are configured in the opposite direction (A snaphot-depends on B). The arrows are drawn this way because buildChainsUI, you can find visual representation of build chains which are always displayed this way - according to the build chain flow. | |
artifactDep. The arrow shows the artifacts flow, the dependency is configured in the opposite direction. |
As you noticed, there are 2 types of dependencies in TeamCity: artifact dependencies and snapshot dependencies. In two words, the first one allows to use output of one build in another, while the second one can trigger builds from several build configurations in specific order, but on the same sources. These two dependencies are often configured together, because artifact dependency doesn't affect the way builds are triggered, while snapshot dependency itself doesn't reuse artifacts, and sometimes you may need only one of those.
Now, let's see what you can do with artifact and snapshot dependencies, and how exactly they work.
Artifact Dependencies
Artifact dependency allows to reuse the output of one build (or a part of it) in another. If build configuration A has artifact dependency on B, then the artifacts of B are downloaded to a build agent before a build of A starts. Note, that you can flexibly adjust Artifact Dependencies to configure which artifacts should be taken and where exactly they should be placed. If for some reason you need to store artifact dependency information together with your codebase and not in TeamCity, you can configure Artifact Dependencies to get the artifacts in your build script. If both snapshot and artifact dependency are configured, and Build from the same chain option is selected in artifact dependency settings, TeamCity ensures that artifacts are downloaded from the same-sources build.
Snapshot Dependencies
Snapshot dependency is a dependency between two build configurations that allows to launch builds from both build configurations in specific order and ensure they use the same sources snapshot (sources revisions correspond to the same moment).
When you have a number of build configurations interconnected by snapshot dependencies, they form a build chain.
When to create a build chain
The most common use case for creating a build chain is running the same test suite of your project on different platforms. For example, you may need to have a release build and want to make sure the tests are run correctly under different platforms and environments. For this purpose, you can instruct TeamCity first run an integration build and after that a release build, if the first one was successful.
Another case is when your tests take too much time to run, so you have to extract them into separate build configuration, but you also need to make sure the same sources snapshot is used.
Build Chains in TeamCity UI
Once you have snapshot dependencies defined and at least build chain was triggered, a new "Build Chains" tab appears among project tabs and among build configuration tabs, providing a visual representation of all related build chains and a way to re-run any chain step manually, using the same set of sources pulled originally. Build Chain
How do snapshot dependencies work?
The easiest way to get an idea of how snapshot dependencies work is to think of module dependencies, because these concepts are similar. However, let's start with the basics. Assume, we have a build chain: Here are the main rules:
If build of A1 is triggered, the whole build chain A1...AN is added to the build queue, but not vice versa! - if build AN is triggered, it doesn't affect anyhow the build chain, only AN is run.
Builds run sequentially starting from AN to A1. Build A(k-1) won't start until build Ak finishes successfully.
All builds in chain will use the same sources snapshot, i.e. with explicit specification of the sources revision, that is calculated at the moment when build chain is added to the queue.
Now let's go into details and examples.
Example 1
Assume we have following build chain with no extra options - plain snapshot dependencies.
What exactly happens when build A is triggered?
TeamCity resolves the whole build chain and queues all builds - A, B and C. TeamCity knows that builds are to run in strict order, so it won't run build A until build B is successfully finished and it won't run build B until build C is successfully finished.
When builds added to queue TeamCity starts checking for changes in the entire build chain and synchronizes them - all builds have to start with the same sources snapshot.
Note, that if the build configurations connected with snapshot dependency Configuring VCS Roots, all builds will run on the same sources. Otherwise, if the VCS roots are different, changes in the VCS will correspond to the same moment in time.
Once build C has successfully finished, build B starts, and so on. If build C failed, TeamCity won't further execute builds from the chain.
What happens when build B is triggered?
The same process will take place for build chain B->C. Build A won't be affected and won't run.
Example 2
When build A is triggered, TeamCity resolves the build chain and queues all builds - A, B1 and B2. Build A won't start until both B1 and B2 are ready. In this case it doesn't matter which build - B1 or B2 - starts first. As in the first example, when all builds are added to the queue, TeamCity checks for changes in the entire build chain and synchronizes them.
Advanced Snapshot Dependencies Setup
Reusing builds
Instead of enforcing running all builds from a build chain, TeamCity can check whether there are already «suitable» builds, i.e. finished builds that used the required sources snapshot. Matching queued builds will not be run and will be dropped from the queue; instead TeamCity will link the dependency to those builds. To enable this, select "Do not run new build if there is a suitable one" when configuring snapshot dependency options.
Another option that allows you to control how builds are re-used is called «Only use successful builds from suitable ones» and it may help when there's a suitable build, but it isn't successful. Normally when there's a failed build in chain, TeamCity doesn't proceed with the rest of the chain. However with this option enabled, TeamCity will run this failed build on these sources one more time. When is this helpful? For example, when the build failure was caused by a problem when connecting to VCS.
Run build even if dependency has failed
When this option is enabled, a build of A will run after build B is finished, even if B failed.
Run build on the same agent
This option was designed for the cases when a build from build chain modifies system environment, and the next build relies on that system state and thus has to run on the same build agent.
Trigger on changes in snapshot dependencies
Another option that alters triggering behavior within a build chain you can find in VCS build trigger options. It allows to trigger the whole build chain even if changes are detected in some further build configuration, not in the root. Let's take a build chain from the first example: Pack setup
--depends on-->Tests
--depends on-->Compile
. Normally, the whole build chain is triggered when TeamCity detects changes in Pack setup
, changes in Compile
do not trigger the whole chain - only Compile
is run. If you want the whole chain to be triggered on VCS change in Compile
, add a VCS trigger with "Trigger on changes in snapshot dependencies" to your Pack setup
configuration. This won't anyhow change the order in which builds are executed. This will only trigger the whole build chain, if there's a change in any of snapshot dependencies.
Changes from Dependencies For a build configuration with snapshot dependencies you can enable showing of changes from these dependencies transitively. The setting is called "Show changes from snapshot dependencies" and is available on the "Version Control Settings" step of the build configuration administration pages.
Enabling of this setting affects pending changes of build configuration, builds changes in builds history, change log and issue log. Changes from dependencies are marked with . For example:
With this setting enabled, "Schedule Trigger" with a "Trigger build only if there are pending changes" option will consider changes from dependencies too.
Parameters in dependent builds
TeamCity provides the ability to use properties provided by the builds the current build depends on (via snapshot or artifact dependency). When build A depends on build B, you can pass properties from build B to build A, i.e. properties can be passed only in the direction of build chain flow and not vice versa. For the details on how to use parameters of the previous build in chain, please refer to the Predefined Build Parameters page.
Miscellaneous notes on using dependencies
Build chain and clean-up By default, TeamCity preserves builds that are a part of a chain from clean-up, but you can switch off the option. Refer to the Clean-Up description for more details.
Artifact dependency and clean-up Artifacts may not be Clean-Up if they were downloaded by other builds and these builds are not yet cleaned up. For a build configuration with configured artifact dependencies you can specify whether artifacts downloaded by this configuration from other builds can be cleaned or not. This setting is available on the Clean-Up page.