org.gradle.api.reporting.dependencies.HtmlDependencyReportTask 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 2013 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.reporting.dependencies;
import groovy.lang.Closure;
import org.gradle.api.Action;
import org.gradle.api.Project;
import org.gradle.api.file.DirectoryProperty;
import org.gradle.api.internal.CollectionCallbackActionDecorator;
import org.gradle.api.internal.ConventionTask;
import org.gradle.api.internal.artifacts.configurations.ConfigurationInternal;
import org.gradle.api.internal.artifacts.ivyservice.ivyresolve.strategy.VersionComparator;
import org.gradle.api.internal.artifacts.ivyservice.ivyresolve.strategy.VersionParser;
import org.gradle.api.internal.artifacts.ivyservice.ivyresolve.strategy.VersionSelectorScheme;
import org.gradle.api.model.ObjectFactory;
import org.gradle.api.reporting.Reporting;
import org.gradle.api.reporting.dependencies.internal.DefaultDependencyReportContainer;
import org.gradle.api.reporting.dependencies.internal.HtmlDependencyReporter;
import org.gradle.api.tasks.Internal;
import org.gradle.api.tasks.Nested;
import org.gradle.api.tasks.TaskAction;
import org.gradle.api.tasks.UntrackedTask;
import org.gradle.api.tasks.diagnostics.internal.ConfigurationDetails;
import org.gradle.api.tasks.diagnostics.internal.ProjectDetails;
import org.gradle.api.tasks.diagnostics.internal.ProjectsWithConfigurations;
import org.gradle.internal.logging.ConsoleRenderer;
import org.gradle.internal.serialization.Cached;
import org.gradle.internal.serialization.Transient;
import org.gradle.util.internal.ClosureBackedAction;
import javax.inject.Inject;
import java.util.Set;
import java.util.stream.Stream;
import static java.util.Collections.singleton;
import static org.gradle.internal.Cast.uncheckedCast;
/**
* Generates an HTML dependency report. This report
* combines the features of the ASCII dependency report and those of the ASCII
* dependency insight report. For a given project, it generates a tree of the dependencies
* of every configuration, and each dependency can be clicked to show the insight of
* this dependency.
*
* This task generates a report for the task's containing project by default. But it can also generate
* a report for multiple projects, by setting the value of the
* projects
property. Here's how to generate an HTML
* dependency report for all the projects of a multi-project build, for example:
*
* htmlDependencyReport {
* projects = project.allprojects
* }
*
*
* The report is generated in the build/reports/project/dependencies
directory by default.
* This can also be changed by setting the reports.html.destination
property:
*
* htmlDependencyReport {
* reports.html.outputLocation = file("build/reports/project/dependencies")
* }
*
*/
@UntrackedTask(because = "We can't describe the dependency tree of all projects as input")
public abstract class HtmlDependencyReportTask extends ConventionTask implements Reporting {
private final Transient.Var> projects = Transient.varOf(uncheckedCast(singleton(getProject())));
private final Cached> projectsWithConfigurations = Cached.of(this::computeProjectsWithConfigurations);
private final DirectoryProperty reportDir;
private final DependencyReportContainer reports;
public HtmlDependencyReportTask() {
reports = getObjectFactory().newInstance(DefaultDependencyReportContainer.class, this, getCallbackActionDecorator());
reportDir = getObjectFactory().directoryProperty();
reports.getHtml().getRequired().set(true);
}
/**
* Returns the project report directory.
*
* @return the directory to store project reports
*
* @since 7.1
*/
@Internal
public DirectoryProperty getProjectReportDirectory() {
return reportDir;
}
@Nested
@Override
public DependencyReportContainer getReports() {
return reports;
}
@Override
@SuppressWarnings("rawtypes")
public DependencyReportContainer reports(Closure closure) {
return reports(new ClosureBackedAction<>(closure));
}
@Override
public DependencyReportContainer reports(Action super DependencyReportContainer> configureAction) {
configureAction.execute(reports);
return reports;
}
@Inject
protected ObjectFactory getObjectFactory() {
throw new UnsupportedOperationException();
}
@Inject
protected VersionSelectorScheme getVersionSelectorScheme() {
throw new UnsupportedOperationException();
}
@Inject
protected VersionComparator getVersionComparator() {
throw new UnsupportedOperationException();
}
@Inject
protected VersionParser getVersionParser() {
throw new UnsupportedOperationException();
}
/**
* Required for decorating reports container callbacks for tracing user code application.
*
* @since 5.1
*/
@Inject
protected CollectionCallbackActionDecorator getCallbackActionDecorator() {
throw new UnsupportedOperationException();
}
@TaskAction
public void generate() {
if (!reports.getHtml().getRequired().get()) {
setDidWork(false);
return;
}
HtmlDependencyReporter reporter = new HtmlDependencyReporter(getVersionSelectorScheme(), getVersionComparator(), getVersionParser());
reporter.render(projectsWithConfigurations.get(), reports.getHtml().getOutputLocation().getAsFile().get());
getLogger().lifecycle("See the report at: {}", new ConsoleRenderer().asClickableFileUrl(reports.getHtml().getEntryPoint()));
}
/**
* Returns the set of projects to generate a report for. By default, the report is generated for the task's
* containing project.
*
* @return The set of files.
*/
@Internal
public Set getProjects() {
return projects.get();
}
/**
* Specifies the set of projects to generate this report for.
*
* @param projects The set of projects. Must not be null.
*/
public void setProjects(Set projects) {
this.projects.set(projects);
}
private ProjectsWithConfigurations computeProjectsWithConfigurations() {
return ProjectsWithConfigurations.from(
getProjects(),
ProjectDetails::withNameAndPath,
HtmlDependencyReportTask::getConfigurationsWhichCouldHaveDependencyInfo
);
}
private static Stream extends ConfigurationDetails> getConfigurationsWhichCouldHaveDependencyInfo(Project project) {
return project.getConfigurations().stream()
.map(ConfigurationInternal.class::cast)
.filter(c -> c.isDeclarableByExtension())
.map(ConfigurationDetails::of);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy