Gradle Release Notes

Version 2.6-rc-1

Gradle 2.6 is an exciting release with some shiny new features and many under the hood improvements.

The new support for the Play framework is exciting for many reasons. If you build Play applications, you can now do so with Gradle and take advantage of all of Gradle's features and capabilities. Play developers with more sophisticated dependency management or orchestration requirements in particular may find building Play apps with Gradle to be particularly appealing.

The Play support is also an exciting development for non-Play users as well. The development time reloading implementation leverages the continuous build capabilities in Gradle 2.5 to be “change aware”. This mechanism will eventually be generally available to be used by integrations with other web frameworks or indeed any long running “thing” being built.

The new “Gradle TestKit” provides an official mechanism for testing custom plugins which will greatly improve the Gradle plugin development experience. This initial version of the TestKit focuses on executing real builds and asserting the result (i.e. functional testing). Expect the TestKit to improve and expand over coming releases.

Table Of Contents

New and noteworthy

Here are the new features introduced in this Gradle release.

Play Framework Support incubating feature

Gradle can now build Play applications for Play version 2.3.x and 2.4.x. The new play plugin allows users to build, test, run and package Play applications.

It includes support for:

Compatibility with Play 2.4.x is limited. The play plugin does not work with a few new build-related features in 2.4. Specifically, Gradle does not allow you to configure reverse routes or use "injected" routes generators. Future releases will add support for these features as well as other features and versions of the Play Framework.

When running a Play application as part of a continuous build, changes to the source are reflected in the running app automatically… no restart required. This facilitates a fast development cycle. The mechanism empowering this “hot reloading” will be made generally available to other types of applications and services in future versions of Gradle.

See the User Guide as well as the sample builds delivered with the Gradle distribution for more information on using the play plugin.

Support for functionally testing Gradle plugins

This release brings the initial version of, the long awaited, official support for functionally testing Gradle plugins. That is, being able to programmatically execute a contrived build leveraging a plugin under development as part of the plugin's build. This functionality is being delivered as part of the new Gradle TestKit.

Many community members stepped up and filled the void created by the absence of a built in way to do this. Notably, the folks at Netflix contributed the very popular Nebula Test as part of their Nebula Project. The functionality provided by this and other similar projects will over time be rolled into the Gradle TestKit.

See the new Gradle TestKit user guide chapter for more information.

Tooling API TestLauncher incubating feature

This releases introduces a new TestLauncher interface for launching tests using the Tooling API.

The following is an example of using the new API…

ProjectConnection connection = GradleConnector.newConnector()
           .forProjectDirectory(new File("someFolder"))

    try {
       //run tests
        .withTests(descriptor1, descriptor2)
        .addProgressListener(new MyTestListener(), EnumSet.of(OperationType.TEST))
    } finally {

See the Javadoc for ProjectConnection and TestLauncher for more information on using the new TestLauncher API.

Rule based model configuration reporting improvements incubating feature

Gradle 2.5 brings significant usability enhancements to the new Rule based model configuration mechanism, through better reporting.

The in-built “Model report” now exposes much more information about the build model, including:

The model report makes it much easier to see the effective configuration of the build, and comprehend how it came to be. Future improvements to the model report will include:

In addition to the model report improvements, rule “binding failure” error messages have also been improved. A binding failure occurs when the declared subject or any of the inputs for a given rule cannot be found when the rule is required. Such a failure is fatal to the build.

The new format presents vital debugging information such as:

e.g. Consider the following rule configuration which is invalid because of an unsatisfied input: bar.

```groovy class Rules extends RuleSource { @Model Integer foo(@Path("bar") Integer bar) { return 22 } }

apply type: Rules ```

The resulting error message gives some clear insight into what went wrong and why:

``` The following model rules could not be applied due to unbound inputs and/or subjects:

Rules#foo inputs: - bar Integer (parameter 1) [*]

[*] - indicates that a model item could not be found for the path or type. ```

In the above example, the error occurred due to there being no model element at path bar.

This is an area of active development and will continue to improve and evolve in coming Gradle releases.

Support for verifying Gradle wrapper distribution download against SHA-256 hash

It is now possible to verify the integrity of the Gradle distribution used by the Gradle wrapper against a known checksum. This provides an extra level of assurance that the Gradle runtime is exactly the intended version.

To enable verification you need only specify a distributionSha256Sum property in your project's file.


Please see section Verification of downloaded Gradle distributions of the User Guide for more information.

This feature was contributed by Dominik Schürmann.

Fixed issues


Features that have become superseded or irrelevant due to the natural evolution of Gradle become deprecated, and scheduled to be removed in the next major Gradle version (Gradle 3.0). See the User guide section on the “Feature Lifecycle” for more information.

The following are the newly deprecated items in this Gradle release. If you have concerns about a deprecation, please raise it via the Gradle Forums.

Deprecation of methods on (incubating) software model

These incubating methods will be removed in the next minor version.

Potential breaking changes

Removal of methods on (incubating) software model

Updated default Scala Zinc compiler version

The default version of the Scala Zinc compiler has changed from to 0.3.7.

Changes to source set handling of binaries

Binaries now distinguish between source sets that are specific to them (owned source set) and external source sets that are also required to build them.

External contributions

We would like to thank the following community members for making contributions to this release of Gradle.

We love getting contributions from the Gradle community. For information on contributing, please see

Known issues

Known issues are problems that were discovered post release that are directly related to changes made in this release.