org.gradle.api.tasks.diagnostics.TaskReportTaskIntegrationTest.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-test-kit Show documentation
Show all versions of gradle-test-kit Show documentation
Gradle 6.2.1 API redistribution.
/*
* Copyright 2012 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.gradle.api.tasks.diagnostics
import org.gradle.integtests.fixtures.AbstractIntegrationSpec
import spock.lang.Issue
class TaskReportTaskIntegrationTest extends AbstractIntegrationSpec {
private final static String[] TASKS_REPORT_TASK = ['tasks'] as String[]
private final static String[] TASKS_DETAILED_REPORT_TASK = TASKS_REPORT_TASK + ['--all'] as String[]
private final static String GROUP = 'Hello world'
private final static String GROUP_1 = 'Group 1'
private final static String GROUP_2 = 'Group 2'
private final static String TASKS_GROUPS_REPORT_TASK = TASKS_REPORT_TASK + ['--groups', GROUP_1]
def "always renders default tasks running #tasks"() {
given:
String projectName = 'test'
settingsFile << "rootProject.name = '$projectName'"
when:
succeeds tasks
then:
output.contains("""
Build Setup tasks
-----------------
init - Initializes a new Gradle build.
updateDaemonJvm - Generates or updates the Gradle Daemon JVM criteria.
wrapper - Generates Gradle wrapper files.
Help tasks
----------
buildEnvironment - Displays all buildscript dependencies declared in root project '$projectName'.
dependencies - Displays all dependencies declared in root project '$projectName'.
dependencyInsight - Displays the insight into a specific dependency in root project '$projectName'.
help - Displays a help message.
javaToolchains - Displays the detected java toolchains.
outgoingVariants - Displays the outgoing variants of root project '$projectName'.
projects - Displays the sub-projects of root project '$projectName'.
properties - Displays the properties of root project '$projectName'.
resolvableConfigurations - Displays the configurations that can be resolved in root project '$projectName'.
tasks - Displays the tasks runnable from root project '$projectName'.""")
where:
tasks << [TASKS_REPORT_TASK, TASKS_DETAILED_REPORT_TASK]
}
def "shows task types when run with --types"() {
given:
String projectName = 'test'
settingsFile << "rootProject.name = '$projectName'"
when:
succeeds "tasks", "--types"
then:
output.contains("""
Build Setup tasks
-----------------
init (org.gradle.buildinit.tasks.InitBuild) - Initializes a new Gradle build.
updateDaemonJvm (org.gradle.buildconfiguration.tasks.UpdateDaemonJvm) - Generates or updates the Gradle Daemon JVM criteria.
wrapper (org.gradle.api.tasks.wrapper.Wrapper) - Generates Gradle wrapper files.
Help tasks
----------
buildEnvironment (org.gradle.api.tasks.diagnostics.BuildEnvironmentReportTask) - Displays all buildscript dependencies declared in root project '$projectName'.
dependencies (org.gradle.api.tasks.diagnostics.DependencyReportTask) - Displays all dependencies declared in root project '$projectName'.
dependencyInsight (org.gradle.api.tasks.diagnostics.DependencyInsightReportTask) - Displays the insight into a specific dependency in root project '$projectName'.
help (org.gradle.configuration.Help) - Displays a help message.
javaToolchains (org.gradle.jvm.toolchain.internal.task.ShowToolchainsTask) - Displays the detected java toolchains.
outgoingVariants (org.gradle.api.tasks.diagnostics.OutgoingVariantsReportTask) - Displays the outgoing variants of root project '$projectName'.
projects (org.gradle.api.tasks.diagnostics.ProjectReportTask) - Displays the sub-projects of root project '$projectName'.
properties (org.gradle.api.tasks.diagnostics.PropertyReportTask) - Displays the properties of root project '$projectName'.
resolvableConfigurations (org.gradle.api.tasks.diagnostics.ResolvableConfigurationsReportTask) - Displays the configurations that can be resolved in root project '$projectName'.
tasks (org.gradle.api.tasks.diagnostics.TaskReportTask) - Displays the tasks runnable from root project '$projectName'.""")
}
def "shows Default task defined in build file when run with --types"() {
given:
String projectName = 'test'
settingsFile << "rootProject.name = '$projectName'"
buildFile << """
task sayHello {
group = 'Build'
doLast {
println "Hello!"
}
}"""
when:
succeeds "tasks", "--types"
then:
output.contains("""
Build tasks
-----------
sayHello (org.gradle.api.DefaultTask)""")
}
def "shows Default tasks with same name defined in multiple projects when run with --types"() {
given:
buildFile << multiProjectBuild()
settingsFile << "include 'sub1', 'sub2'"
file('sub1/build.gradle') << """
task sayHello {
group = 'Build'
doLast {
println "Hello!"
}
}"""
file('sub2/build.gradle') << """
task sayHello {
group = 'Build'
doLast {
println "Hello!"
}
}"""
when:
succeeds "tasks", "--types", "--all"
then:
output.contains("""
Build tasks
-----------
sub1:sayHello (org.gradle.api.DefaultTask)
sub2:sayHello (org.gradle.api.DefaultTask)""")
}
def "shows Custom task defined in build file when run with --types"() {
given:
String projectName = 'test'
settingsFile << "rootProject.name = '$projectName'"
buildFile << """
class HelloTask extends DefaultTask {
final Property message = project.objects.property(String).convention("Hello!")
@TaskAction def sayHello() {
println(message.get())
}
}
task sayHi(type: HelloTask) {
group = 'Build'
message = 'Hi!'
}"""
when:
succeeds "tasks", "--types"
then:
output.contains("""
Build tasks
-----------
sayHi (HelloTask)""")
}
def "always renders task rule running #tasks"() {
given:
buildFile << """
tasks.addRule("Pattern: ping") { String taskName ->
if (taskName.startsWith("ping")) {
task(taskName) {
doLast {
println "Pinging: " + (taskName - 'ping')
}
}
}
}
"""
when:
succeeds tasks
then:
output.contains("""
Rules
-----
Pattern: ping
""")
where:
tasks << [TASKS_REPORT_TASK, TASKS_DETAILED_REPORT_TASK]
}
def "renders tasks with and without group running #tasks"() {
given:
buildFile << """
task a {
group = '$GROUP'
}
task b
"""
when:
succeeds tasks
then:
output.contains("""
$helloWorldGroupHeader
a
""") == rendersGroupedTask
output.contains("""
$otherGroupHeader
b
""") == rendersUngroupedTask
where:
tasks | rendersGroupedTask | rendersUngroupedTask
TASKS_REPORT_TASK | true | false
TASKS_DETAILED_REPORT_TASK | true | true
}
def "renders task with dependencies without group in detailed report running #tasks"() {
given:
buildFile << """
task a
task b {
dependsOn a
}
"""
when:
succeeds tasks
then:
output.contains("""
$otherGroupHeader
a
b
""") == rendersTasks
where:
tasks | rendersTasks
TASKS_REPORT_TASK | false
TASKS_DETAILED_REPORT_TASK | true
}
def "renders grouped task with dependencies in detailed report running #tasks"() {
given:
buildFile << """
task a {
group = '$GROUP'
}
task b {
group = '$GROUP'
dependsOn a
}
"""
when:
succeeds tasks
then:
output.contains("""
$helloWorldGroupHeader
a
b
""")
where:
tasks | rendersTasks
TASKS_REPORT_TASK | true
TASKS_DETAILED_REPORT_TASK | true
}
def "renders only tasks in given group running [tasks, --group=build setup]"() {
settingsFile << "rootProject.name = 'test'"
buildFile << """
task mytask {
group = "custom"
}
"""
when:
succeeds "tasks", "--group=build setup"
then:
output.contains("""
------------------------------------------------------------
Tasks runnable from root project 'test'
------------------------------------------------------------
Build Setup tasks
-----------------
init - Initializes a new Gradle build.
updateDaemonJvm - Generates or updates the Gradle Daemon JVM criteria.
wrapper - Generates Gradle wrapper files.
To see all tasks and more detail, run gradle tasks --all
To see more detail about a task, run gradle help --task
""")
!output.contains("custom")
}
def "renders only tasks in given group running [tasks, --groups=build setup]"() {
settingsFile << "rootProject.name = 'test'"
buildFile << """
task mytask {
group = "custom"
}
"""
when:
succeeds "tasks", "--groups=build setup"
then:
output.contains("""
------------------------------------------------------------
Tasks runnable from root project 'test'
------------------------------------------------------------
Build Setup tasks
-----------------
init - Initializes a new Gradle build.
updateDaemonJvm - Generates or updates the Gradle Daemon JVM criteria.
wrapper - Generates Gradle wrapper files.
To see all tasks and more detail, run gradle tasks --all
To see more detail about a task, run gradle help --task
""")
!output.contains("custom")
}
def "renders tasks in given groups running [tasks, --groups=Group 1]"() {
settingsFile << "rootProject.name = 'test'"
buildFile << twoGroupsTasks()
when:
succeeds "tasks", "--groups=Group 1"
then:
output.contains("$GROUP_1 tasks")
!output.contains("$GROUP_2 tasks")
!output.contains("Build Setup")
}
def "renders tasks in given groups running [tasks, --groups=Group 1, --groups=Group 2]"() {
settingsFile << "rootProject.name = 'test'"
buildFile << twoGroupsTasks()
when:
succeeds "tasks", "--groups=Group 1", "--groups=Group 2"
then:
output.contains("$GROUP_1 tasks")
output.contains("$GROUP_2 tasks")
!output.contains("Build Setup")
}
def "renders tasks given by group and groups running [tasks, --group=Group 1, --groups=Group 2]"() {
settingsFile << "rootProject.name = 'test'"
buildFile << twoGroupsTasks()
when:
succeeds "tasks", "--group=Group 1", "--groups=Group 2"
then:
output.contains("$GROUP_1 tasks")
output.contains("$GROUP_2 tasks")
!output.contains("Build Setup")
}
def "renders tasks in a multi-project build running [tasks]"() {
given:
buildFile << multiProjectBuild()
createDirs("sub1", "sub2")
settingsFile << "include 'sub1', 'sub2'"
when:
succeeds TASKS_REPORT_TASK
then:
output.contains("""
$helloWorldGroupHeader
a
""")
!output.contains("""
$otherGroupHeader
c
""")
}
def "renders tasks in a multi-project build running [tasks, --all]"() {
given:
buildFile << multiProjectBuild()
createDirs("sub1", "sub2")
settingsFile << "include 'sub1', 'sub2'"
when:
succeeds TASKS_DETAILED_REPORT_TASK
then:
output.contains("""
$helloWorldGroupHeader
a
sub1:a
sub2:a
""")
output.contains("""
$otherGroupHeader
sub1:b
sub2:b
c
""")
}
def "task selector description is taken from task that TaskNameComparator considers to be of lowest ordering"() {
given:
settingsFile << """
include 'sub1'
include 'sub2'
"""
file("sub1/build.gradle") << """
task alpha {
group = '$GROUP'
description = 'ALPHA_in_sub1'
}
"""
file("sub2/build.gradle") << """
task alpha {
group = '$GROUP'
description = 'ALPHA_in_sub2'
}
"""
when:
succeeds TASKS_REPORT_TASK
then:
output.contains """
$helloWorldGroupHeader
alpha - ALPHA_in_sub1
"""
}
def "task report includes tasks defined via model rules running #tasks"() {
when:
buildScript """
model {
tasks {
create('a') {
group = '$GROUP'
description = "from model rule 1"
}
create('b') {
description = "from model rule 2"
}
}
}
"""
then:
succeeds tasks
and:
output.contains("a - from model rule 1") == rendersGroupedTask
output.contains("b - from model rule 2") == rendersUngroupedTask
where:
tasks | rendersGroupedTask | rendersUngroupedTask
TASKS_REPORT_TASK | true | false
TASKS_DETAILED_REPORT_TASK | true | true
}
def "task report includes tasks with dependencies defined via model rules running #tasks"() {
when:
buildScript """
model {
tasks {
create('a')
create('b') {
dependsOn 'b'
}
}
}
"""
then:
succeeds tasks
output.contains("""
$otherGroupHeader
a
b
""") == rendersTasks
where:
tasks | rendersTasks
TASKS_REPORT_TASK | false
TASKS_DETAILED_REPORT_TASK | true
}
def "task report includes task container rule based tasks defined via model rule"() {
when:
buildScript """
tasks.addRule("Pattern: containerRule") { taskName ->
if (taskName.startsWith("containerRule")) {
task(taskName) {
description = "from container rule"
}
}
}
model {
tasks {
create("t1") {
description = "from model rule"
dependsOn "containerRule1"
}
}
}
"""
then:
succeeds TASKS_DETAILED_REPORT_TASK
and:
output.contains("t1 - from model rule")
output.contains("Pattern: containerRule")
}
@Issue("https://issues.gradle.org/browse/GRADLE-2023")
def "can deal with tasks with named task dependencies that are created by rules"() {
when:
buildFile << getBuildScriptContent()
then:
succeeds TASKS_DETAILED_REPORT_TASK
}
@Issue("https://issues.gradle.org/browse/GRADLE-2023")
def "can deal with tasks with named task dependencies that are created by rules - multiproject"() {
when:
settingsFile << "include 'module'"
file("module/build.gradle") << getBuildScriptContent()
then:
succeeds TASKS_DETAILED_REPORT_TASK
}
def "renders tasks with dependencies created by model rules running #tasks"() {
when:
settingsFile << "rootProject.name = 'test-project'"
buildScript """
model {
tasks {
create('a')
}
}
task b {
dependsOn 'a'
}
task c
model {
tasks {
create('d') {
dependsOn c
}
}
}
"""
then:
succeeds tasks
output.contains("""
$otherGroupHeader
a
b
c
components - Displays the components produced by root project 'test-project'. [deprecated]
d
dependentComponents - Displays the dependent components of components in root project 'test-project'. [deprecated]
model - Displays the configuration model of root project 'test-project'. [deprecated]
""") == rendersTasks
where:
tasks | rendersTasks
TASKS_REPORT_TASK | false
TASKS_DETAILED_REPORT_TASK | true
}
def "can run multiple task reports in parallel"() {
given:
buildFile << multiProjectBuild()
def projects = (1..100).collect {"project$it"}
createDirs(projects as String[])
settingsFile << "include '${projects.join("', '")}'"
expect:
succeeds(":tasks", *projects.collect { "$it:tasks" }, "--parallel")
}
protected static String getBuildScriptContent() {
"""
tasks.addRule("test rule") {
if (it.startsWith("autoCreate")) {
def name = it - "autoCreate"
name = name[0].toLowerCase() + name[1..-1]
if (tasks.findByName(name)) {
project.tasks.create(it)
}
}
}
// Source task must be alphabetically before task that is created by dependency
task aaa { dependsOn("autoCreateFoo") }
task foo
"""
}
static String getHelloWorldGroupHeader() {
getGroupHeader(GROUP)
}
static String getOtherGroupHeader() {
getGroupHeader('Other')
}
private static String getGroupHeader(String group) {
String header = "$group tasks"
"""$header
${'-' * header.length()}"""
}
static String multiProjectBuild() {
"""
allprojects {
task a {
group = '$GROUP'
}
}
subprojects {
task b
}
task c
"""
}
static String twoGroupsTasks() {
"""
task task1 {
group = "$GROUP_1"
}
task task2 {
group = "$GROUP_2"
}
"""
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy