All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.gradle.profile.BuildProfile Maven / Gradle / Ivy

/*
 * Copyright 2011 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.profile;

import com.google.common.collect.Maps;
import org.gradle.StartParameter;
import org.gradle.api.initialization.Settings;
import org.gradle.internal.service.scopes.Scopes;
import org.gradle.internal.service.scopes.ServiceScope;
import org.gradle.util.internal.CollectionUtils;

import java.io.File;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

/**
 * Root container for profile information about a build.  This includes summary
 * information about the overall build timing and collection of project specific
 * information.  All timing information is stored as milliseconds since epoch times.
 * 

* Setters are expected to be called in the following order: *

    *
  • setProfilingStarted
  • *
  • setBuildStarted
  • *
  • setSettingsEvaluated
  • *
  • setProjectsLoaded
  • *
  • setProjectsEvaluated
  • *
  • setBuildFinished
  • *
*/ @ServiceScope(Scopes.BuildTree.class) public class BuildProfile { private static final DateFormat DATE_FORMAT = new SimpleDateFormat("yyyy/MM/dd - HH:mm:ss"); private final Map projects = new LinkedHashMap<>(); private final Map dependencySets = new LinkedHashMap<>(); private final Map transformations = Maps.newLinkedHashMap(); private long profilingStarted; private long buildStarted; private long settingsEvaluated; private long projectsLoaded; private long projectsEvaluated; private long buildFinished; private final StartParameter startParameter; private boolean successful; private File buildDir; public BuildProfile(StartParameter startParameter) { this.startParameter = startParameter; } public long getBuildStarted() { return buildStarted; } /** * Get a description of this profiled build. It contains info about tasks passed to gradle as targets from the command line. */ public String getBuildDescription() { StringBuilder sb = new StringBuilder(); for (String name : startParameter.getExcludedTaskNames()) { sb.append("-x "); sb.append(name); sb.append(" "); } for (String name : startParameter.getTaskNames()) { sb.append(name); sb.append(" "); } String tasks = sb.toString(); if (tasks.length() == 0) { tasks = "(no tasks specified)"; } return "Profiled build: " + tasks; } public boolean isSuccessful() { return successful; } public void setSuccessful(boolean successful) { this.successful = successful; } /** * Get the profiling container for the specified project * * @param projectPath to look up */ public ProjectProfile getProjectProfile(String projectPath) { ProjectProfile result = projects.get(projectPath); if (result == null) { result = new ProjectProfile(projectPath); projects.put(projectPath, result); } return result; } /** * Get a list of the profiling containers for all projects * * @return list */ public List getProjects() { return CollectionUtils.sort(projects.values(), Operation.slowestFirst()); } public CompositeOperation getProjectConfiguration() { List operations = new ArrayList<>(); for (ProjectProfile projectProfile : projects.values()) { operations.add(projectProfile.getConfigurationOperation()); } operations = CollectionUtils.sort(operations, Operation.slowestFirst()); return new CompositeOperation<>(operations); } public ContinuousOperation getDependencySetProfile(String dependencySetDescription) { ContinuousOperation profile = dependencySets.get(dependencySetDescription); if (profile == null) { profile = new ContinuousOperation(dependencySetDescription); dependencySets.put(dependencySetDescription, profile); } return profile; } public CompositeOperation getDependencySets() { final List profiles = CollectionUtils.sort(dependencySets.values(), Operation.slowestFirst()); return new CompositeOperation<>(profiles); } public FragmentedOperation getTransformationProfile(String transformationDescription) { FragmentedOperation profile = transformations.get(transformationDescription); if (profile == null) { profile = new FragmentedOperation(transformationDescription); transformations.put(transformationDescription, profile); } return profile; } public CompositeOperation getTransformations() { final List profiles = CollectionUtils.sort(transformations.values(), Operation.slowestFirst()); return new CompositeOperation<>(profiles); } /** * Should be set with a time as soon as possible after startup. */ public void setProfilingStarted(long profilingStarted) { this.profilingStarted = profilingStarted; } /** * Should be set with a timestamp from a {@link org.gradle.BuildListener#beforeSettings(Settings)} * callback. */ public void setBuildStarted(long buildStarted) { this.buildStarted = buildStarted; } /** * Should be set with a timestamp from a {@link org.gradle.BuildListener#settingsEvaluated} * callback. */ public void setSettingsEvaluated(long settingsEvaluated) { this.settingsEvaluated = settingsEvaluated; } /** * Should be set with a timestamp from a {@link org.gradle.BuildListener#projectsLoaded} * callback. */ public void setProjectsLoaded(long projectsLoaded) { this.projectsLoaded = projectsLoaded; } /** * Should be set with a timestamp from a {@link org.gradle.BuildListener#projectsEvaluated} * callback. */ public void setProjectsEvaluated(long projectsEvaluated) { this.projectsEvaluated = projectsEvaluated; } /** * Should be set with a timestamp from a {@link org.gradle.BuildListener#buildFinished} * callback. */ public void setBuildFinished(long buildFinished) { this.buildFinished = buildFinished; } /** * Get the elapsed time (in mSec) between the start of profiling and the buildStarted event. */ public long getElapsedStartup() { return buildStarted - profilingStarted; } /** * Get the total elapsed time (in mSec) between the start of profiling and the buildFinished event. */ public long getElapsedTotal() { return buildFinished - profilingStarted; } /** * Get the elapsed time (in mSec) between the buildStarted event and the settingsEvaluated event. * Note that this will include processing of buildSrc as well as the settings file. */ public long getElapsedSettings() { return settingsEvaluated - buildStarted; } /** * Get the elapsed time (in mSec) between the settingsEvaluated event and the projectsLoaded event. */ public long getElapsedProjectsLoading() { return projectsLoaded - settingsEvaluated; } /** * Get the elapsed time (in mSec) between the projectsLoaded event and the projectsEvaluated event. */ public long getElapsedProjectsConfiguration() { return projectsEvaluated - projectsLoaded; } /** * Get the total artifact transformation time. */ public long getElapsedArtifactTransformTime() { long result = 0; for (FragmentedOperation transform : transformations.values()) { result += transform.getElapsedTime(); } return result; } /** * Get the total task execution time from all projects. */ public long getElapsedTotalExecutionTime() { long result = 0; for (ProjectProfile projectProfile : projects.values()) { result += projectProfile.getElapsedTime(); } return result; } public String getBuildStartedDescription() { return "Started on: " + DATE_FORMAT.format(buildStarted); } public File getBuildDir() { return buildDir; } public void setBuildDir(File buildDir) { this.buildDir = buildDir; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy