- User interface changes
- Inherited build steps configuration improvements
- Enforced settings
- PowerShell Core support
- Docker plugin improvements
- Re-run build action improvements
- Shared resources in composite builds
- Other improvements
User interface changes
The user interface update that we started in the previous version continues in the future 2018.1 version.
In this EAP build the build line has been redesigned a bit and agent history page now looks similar to "All builds page" (which was introduced in 2017.2.x):
We're working on other pages where lists of builds are shown. Expect more changes in the next EAP build.
Inherited build steps configuration improvements
Ability to redefine inherited build step settings
In the current TeamCity version, if a build step is defined in a template, it is shown as read-only in a build configuration inheriting this build step. If some customization is required, then a parameter reference has to be defined for some settings in the template, and a specific value should be set for this parameter in the build configuration. However, this workaround works for text fields only.
In this EAP it is finally possible to customize an inherited build step, i.e. it is possible to change every setting of the inherited build step without the need to introduce parameters.
Ability to have pre- and post-steps in a template
There is sometimes a need to define a common build step in a template, so that this step will be executed either before all build configuration steps or after them.
In this EAP build, for a given template it is possible to define such steps and then define their placement in respect to the build configuration steps. All build configuration steps are represented as a placeholder in the Reorder Build Steps dialog. The template steps can be placed before or after this placeholder.
Note: you still can have a completely custom order of steps in a build configuration inherited from a template.
Starting with this EAP it is now possible to enforce settings for all of the build configurations in a projects hierarchy. For instance, with help of this feature it is possible to enforce agent side checkout everywhere, or make sure that all build configurations have some strict execution timeout.
To enforce some settings in the projects hierarchy a template with these settings must be created. After that a system administrator can set this template as enforced settings template in a project:
To some extent enforced settings template works similar to default templates - i.e. all of it's settings are inherited in build configurations of a projects hierarchy. The difference is that these inherited settings cannot be disabled or overridden anyhow. In addition to that only system administrator can associate a project with a specific enforced settings template. It's not enough to be a project administrator to do that. On the other hand, the template itself can be edited by a project administrator who can administer the project where the template is defined.
If enforced settings template is specified in a project and another template is assigned as enforced settings in a subproject, then for this subproject it's template will have the higher priority.
For parameters and options their specs will be forced. So to force a parameter value read-only attribute (“readOnly=’true’”) should be added to its spec.
Limitations: not all of the settings can be enforced. Dependencies, triggers and build steps are currently not enforced. We're not convinced there are useful use cases for them, please let us know if you have some cases in mind.
PowerShell Core support
- Cross-platform PowerShell (PowerShell Core) is now supported on Windows, MacOS and Linux
- Side-by-side installations of PowerShell Desktop and PowerShell Core is supported under Windows
Docker plugin improvements
- Docker wrapper now forms build step environment more correctly and passes the relevenat environment variables to the container. TW-53498
- Docker wrapper can now use Gradle and Maven provided by the Docker images in the corresponding build steps. TW-54066, TW-51179
Re-run build action improvements
Now when re-running a build, TeamCity preserves all the custom parameters of this build and its dependencies as of the time of the original run.
Besides that, on the dependencies tab, there is now an additional option to rerun the failed/failed to start or cancelled dependencies of the build:
Shared resources in composite builds
Since this EAP shared resources can be locked not only for regular builds, but for composite builds as well. A lock on the specified resource will be acquired when a composite build starts (when the first build of the composite build chain starts); the lock will be released when the composite build finishes (the last build in its chain is finished).
The locks acquired on composite builds affect only these composite builds and are not propagated to their individual parts.
For example, if a resource has a quota of N, then N composite builds that have a read lock on this resource can be run concurrently. The number of concurrent individual builds inside these composite builds will not be affected by the resource quota.
Adding a lock on a composite build is done the same way it is done for a regular build: it can be done by adding the Shared Resources build feature.
- Browsing of artifacts inside archives is now supported for all external artifacts storages too (previously this feature was available only if artifacts were stored in the internal artifacts storage).
Java 9 and Java 10 can now be used to run an agent.
Commit Status Publisher now allows an admin to configure custom values for success and failure instead of +1 and -1 respectively. This label is also configurable. Note that since TeamCity 2018.1 Gerrit 2.6. is the minimal version supported by Commit Status Publisher.
- Build chains page has got new grouping option: it groups together in a single node all of the build configurations which are not related to the current context.
- Duplicates finder (.NET) and Inspections (.NET) runners have been renamed to Duplicates finder (ReSharper) and Inspections (ReSharper) respectively. You can now select the platform bitness for InspectCode when using Inspections (ReSharper).
- All fixed issues