| // Copyright 2016 The Bazel Authors. All rights reserved. |
| // |
| // 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 com.google.devtools.build.lib.buildeventstream; |
| |
| import com.google.devtools.build.lib.buildeventstream.BuildEventStreamProtos.BuildEventId; |
| import com.google.devtools.build.lib.buildeventstream.BuildEventStreamProtos.BuildEventId.ActionCompletedId; |
| import com.google.devtools.build.lib.buildeventstream.BuildEventStreamProtos.BuildEventId.ConfigurationId; |
| import com.google.devtools.build.lib.cmdline.Label; |
| import com.google.devtools.build.lib.skyframe.BuildConfigurationKey; |
| import com.google.devtools.build.lib.vfs.PathFragment; |
| import java.util.List; |
| import javax.annotation.Nullable; |
| import javax.annotation.concurrent.Immutable; |
| |
| /** |
| * Utilities for working with {@link BuildEventId}. |
| * |
| * <p>Since event identifiers need to be created before the actual event, the event IDs are highly |
| * structured so that equal identifiers can easily be generated. The main way of pregenerating event |
| * identifiers that do not accidentally coincide is by providing a target or a target pattern; |
| * therefore, those (if provided) are made specially visible. |
| */ |
| @Immutable |
| public final class BuildEventIdUtil { |
| private static final ConfigurationId NULL_CONFIGURATION_ID_MESSAGE = |
| configurationIdMessage("none"); |
| private static final BuildEventId NULL_CONFIGURATION_ID = |
| configurationId(NULL_CONFIGURATION_ID_MESSAGE); |
| |
| private BuildEventIdUtil() {} |
| |
| public static BuildEventId unknownBuildEventId(String details) { |
| BuildEventId.UnknownBuildEventId id = |
| BuildEventId.UnknownBuildEventId.newBuilder().setDetails(details).build(); |
| return BuildEventId.newBuilder().setUnknown(id).build(); |
| } |
| |
| public static BuildEventId progressId(int count) { |
| BuildEventId.ProgressId id = BuildEventId.ProgressId.newBuilder().setOpaqueCount(count).build(); |
| return BuildEventId.newBuilder().setProgress(id).build(); |
| } |
| |
| public static BuildEventId buildStartedId() { |
| BuildEventId.BuildStartedId startedId = BuildEventId.BuildStartedId.getDefaultInstance(); |
| return BuildEventId.newBuilder().setStarted(startedId).build(); |
| } |
| |
| public static BuildEventId unstructuredCommandlineId() { |
| BuildEventId.UnstructuredCommandLineId commandLineId = |
| BuildEventId.UnstructuredCommandLineId.getDefaultInstance(); |
| return BuildEventId.newBuilder().setUnstructuredCommandLine(commandLineId).build(); |
| } |
| |
| public static BuildEventId structuredCommandlineId(String commandLineLabel) { |
| BuildEventId.StructuredCommandLineId commandLineId = |
| BuildEventId.StructuredCommandLineId.newBuilder() |
| .setCommandLineLabel(commandLineLabel) |
| .build(); |
| return BuildEventId.newBuilder().setStructuredCommandLine(commandLineId).build(); |
| } |
| |
| public static BuildEventId optionsParsedId() { |
| BuildEventId.OptionsParsedId optionsParsedId = |
| BuildEventId.OptionsParsedId.getDefaultInstance(); |
| return BuildEventId.newBuilder().setOptionsParsed(optionsParsedId).build(); |
| } |
| |
| public static BuildEventId workspaceStatusId() { |
| return BuildEventId.newBuilder() |
| .setWorkspaceStatus(BuildEventId.WorkspaceStatusId.getDefaultInstance()) |
| .build(); |
| } |
| |
| public static BuildEventId buildMetadataId() { |
| BuildEventId.BuildMetadataId buildMetadataId = |
| BuildEventId.BuildMetadataId.getDefaultInstance(); |
| return BuildEventId.newBuilder().setBuildMetadata(buildMetadataId).build(); |
| } |
| |
| public static BuildEventId workspaceConfigId() { |
| BuildEventId.WorkspaceConfigId workspaceConfigId = |
| BuildEventId.WorkspaceConfigId.getDefaultInstance(); |
| return BuildEventId.newBuilder().setWorkspace(workspaceConfigId).build(); |
| } |
| |
| static BuildEventId fetchId(String url) { |
| BuildEventId.FetchId fetchId = BuildEventId.FetchId.newBuilder().setUrl(url).build(); |
| return BuildEventId.newBuilder().setFetch(fetchId).build(); |
| } |
| |
| public static BuildEventId configurationId(@Nullable BuildConfigurationKey key) { |
| return configurationId(configurationIdMessage(key)); |
| } |
| |
| private static BuildEventId configurationId(ConfigurationId id) { |
| return BuildEventId.newBuilder().setConfiguration(id).build(); |
| } |
| |
| public static BuildEventId configurationId(String id) { |
| return configurationId(configurationIdMessage(id)); |
| } |
| |
| public static ConfigurationId configurationIdMessage(@Nullable BuildConfigurationKey key) { |
| return key == null |
| ? nullConfigurationIdMessage() |
| : configurationIdMessage(key.getOptions().checksum()); |
| } |
| |
| public static ConfigurationId configurationIdMessage(String checksum) { |
| return ConfigurationId.newBuilder().setId(checksum).build(); |
| } |
| |
| public static BuildEventId nullConfigurationId() { |
| return NULL_CONFIGURATION_ID; |
| } |
| |
| public static ConfigurationId nullConfigurationIdMessage() { |
| return NULL_CONFIGURATION_ID_MESSAGE; |
| } |
| |
| private static BuildEventId targetPatternExpanded(List<String> targetPattern, boolean skipped) { |
| BuildEventId.PatternExpandedId patternId = |
| BuildEventId.PatternExpandedId.newBuilder().addAllPattern(targetPattern).build(); |
| BuildEventId.Builder builder = BuildEventId.newBuilder(); |
| if (skipped) { |
| builder.setPatternSkipped(patternId); |
| } else { |
| builder.setPattern(patternId); |
| } |
| return builder.build(); |
| } |
| |
| public static BuildEventId targetPatternExpanded(List<String> targetPattern) { |
| return targetPatternExpanded(targetPattern, false); |
| } |
| |
| public static BuildEventId targetPatternSkipped(List<String> targetPattern) { |
| return targetPatternExpanded(targetPattern, true); |
| } |
| |
| public static BuildEventId targetConfigured(Label label) { |
| BuildEventId.TargetConfiguredId configuredId = |
| BuildEventId.TargetConfiguredId.newBuilder().setLabel(label.toString()).build(); |
| return BuildEventId.newBuilder().setTargetConfigured(configuredId).build(); |
| } |
| |
| public static BuildEventId coverageActionsFinished() { |
| return BuildEventId.newBuilder() |
| .setCoverageActionsFinished(BuildEventId.CoverageActionsFinishedId.getDefaultInstance()) |
| .build(); |
| } |
| |
| public static BuildEventId aspectConfigured(Label label, String aspect) { |
| BuildEventId.TargetConfiguredId configuredId = |
| BuildEventId.TargetConfiguredId.newBuilder() |
| .setLabel(label.toString()) |
| .setAspect(aspect) |
| .build(); |
| return BuildEventId.newBuilder().setTargetConfigured(configuredId).build(); |
| } |
| |
| public static BuildEventId targetCompleted(Label target, BuildEventId configuration) { |
| BuildEventId.ConfigurationId configId = configuration.getConfiguration(); |
| BuildEventId.TargetCompletedId targetId = |
| BuildEventId.TargetCompletedId.newBuilder() |
| .setLabel(target.toString()) |
| .setConfiguration(configId) |
| .build(); |
| return BuildEventId.newBuilder().setTargetCompleted(targetId).build(); |
| } |
| |
| public static BuildEventId configuredLabelId( |
| Label label, BuildEventId.ConfigurationId configurationId) { |
| BuildEventId.ConfiguredLabelId labelId = |
| BuildEventId.ConfiguredLabelId.newBuilder() |
| .setLabel(label.toString()) |
| .setConfiguration(configurationId) |
| .build(); |
| return BuildEventId.newBuilder().setConfiguredLabel(labelId).build(); |
| } |
| |
| public static BuildEventId unconfiguredLabelId(Label label) { |
| BuildEventId.UnconfiguredLabelId labelId = |
| BuildEventId.UnconfiguredLabelId.newBuilder().setLabel(label.toString()).build(); |
| return BuildEventId.newBuilder().setUnconfiguredLabel(labelId).build(); |
| } |
| |
| public static BuildEventId aspectCompleted( |
| Label target, BuildEventId configuration, String aspect) { |
| BuildEventId.ConfigurationId configId = configuration.getConfiguration(); |
| BuildEventId.TargetCompletedId targetId = |
| BuildEventId.TargetCompletedId.newBuilder() |
| .setLabel(target.toString()) |
| .setConfiguration(configId) |
| .setAspect(aspect) |
| .build(); |
| return BuildEventId.newBuilder().setTargetCompleted(targetId).build(); |
| } |
| |
| public static BuildEventId actionCompleted(PathFragment path) { |
| return actionCompleted(path, null, null); |
| } |
| |
| public static BuildEventId actionCompleted( |
| PathFragment path, @Nullable Label label, @Nullable String configurationChecksum) { |
| ActionCompletedId.Builder actionId = |
| ActionCompletedId.newBuilder().setPrimaryOutput(path.toString()); |
| if (label != null) { |
| actionId.setLabel(label.toString()); |
| } |
| if (configurationChecksum != null) { |
| actionId.setConfiguration(ConfigurationId.newBuilder().setId(configurationChecksum)); |
| } |
| return BuildEventId.newBuilder().setActionCompleted(actionId).build(); |
| } |
| |
| public static BuildEventId fromArtifactGroupName(String name) { |
| BuildEventId.NamedSetOfFilesId namedSetId = |
| BuildEventId.NamedSetOfFilesId.newBuilder().setId(name).build(); |
| return BuildEventId.newBuilder().setNamedSet(namedSetId).build(); |
| } |
| |
| public static BuildEventId testResult( |
| Label target, Integer run, Integer shard, Integer attempt, BuildEventId configuration) { |
| BuildEventId.ConfigurationId configId = configuration.getConfiguration(); |
| BuildEventId.TestResultId resultId = |
| BuildEventId.TestResultId.newBuilder() |
| .setLabel(target.toString()) |
| .setConfiguration(configId) |
| .setRun(run + 1) |
| .setShard(shard + 1) |
| .setAttempt(attempt) |
| .build(); |
| return BuildEventId.newBuilder().setTestResult(resultId).build(); |
| } |
| |
| public static BuildEventId testResult( |
| Label target, Integer run, Integer shard, BuildEventId configuration) { |
| return testResult(target, run, shard, 1, configuration); |
| } |
| |
| public static BuildEventId testSummary(Label target, BuildEventId configuration) { |
| BuildEventId.ConfigurationId configId = configuration.getConfiguration(); |
| BuildEventId.TestSummaryId summaryId = |
| BuildEventId.TestSummaryId.newBuilder() |
| .setLabel(target.toString()) |
| .setConfiguration(configId) |
| .build(); |
| return BuildEventId.newBuilder().setTestSummary(summaryId).build(); |
| } |
| |
| public static BuildEventId targetSummary(Label target, BuildEventId configuration) { |
| BuildEventId.ConfigurationId configId = configuration.getConfiguration(); |
| BuildEventId.TargetSummaryId summaryId = |
| BuildEventId.TargetSummaryId.newBuilder() |
| .setLabel(target.toString()) |
| .setConfiguration(configId) |
| .build(); |
| return BuildEventId.newBuilder().setTargetSummary(summaryId).build(); |
| } |
| |
| public static BuildEventId buildFinished() { |
| BuildEventId.BuildFinishedId finishedId = BuildEventId.BuildFinishedId.getDefaultInstance(); |
| return BuildEventId.newBuilder().setBuildFinished(finishedId).build(); |
| } |
| |
| public static BuildEventId buildToolLogs() { |
| return BuildEventId.newBuilder() |
| .setBuildToolLogs(BuildEventId.BuildToolLogsId.getDefaultInstance()) |
| .build(); |
| } |
| |
| public static BuildEventId buildMetrics() { |
| return BuildEventId.newBuilder() |
| .setBuildMetrics(BuildEventId.BuildMetricsId.getDefaultInstance()) |
| .build(); |
| } |
| |
| public static BuildEventId convenienceSymlinksIdentifiedId() { |
| return BuildEventId.newBuilder() |
| .setConvenienceSymlinksIdentified( |
| BuildEventId.ConvenienceSymlinksIdentifiedId.getDefaultInstance()) |
| .build(); |
| } |
| } |