aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main/java/com/google/devtools/build/lib/analysis/TargetCompleteEvent.java
diff options
context:
space:
mode:
authorGravatar Klaus Aehlig <aehlig@google.com>2016-11-30 12:12:56 +0000
committerGravatar Irina Iancu <elenairina@google.com>2016-11-30 12:21:36 +0000
commit6f978506b7ba4894990e053880836d295e811b24 (patch)
tree25ec00a70aca99920dc214e3b11513e7eafae746 /src/main/java/com/google/devtools/build/lib/analysis/TargetCompleteEvent.java
parent1e943aeda5ca72fde74fab97b02e61e8c8d3745d (diff)
Only announce test summaries in BEP if expected
In some situations, we do not even expect a test summary to appear in the BEP, e.g., if testing is not asked for. Do not announce a test summary in this case. -- Change-Id: Ifd46e3582292b087bb1d37f255a140f631854830 Reviewed-on: https://cr.bazel.build/7373 MOS_MIGRATED_REVID=140589645
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/analysis/TargetCompleteEvent.java')
-rw-r--r--src/main/java/com/google/devtools/build/lib/analysis/TargetCompleteEvent.java24
1 files changed, 15 insertions, 9 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/analysis/TargetCompleteEvent.java b/src/main/java/com/google/devtools/build/lib/analysis/TargetCompleteEvent.java
index e2ebbb8624..aa2e9b44db 100644
--- a/src/main/java/com/google/devtools/build/lib/analysis/TargetCompleteEvent.java
+++ b/src/main/java/com/google/devtools/build/lib/analysis/TargetCompleteEvent.java
@@ -24,7 +24,6 @@ import com.google.devtools.build.lib.causes.Cause;
import com.google.devtools.build.lib.collect.nestedset.NestedSet;
import com.google.devtools.build.lib.collect.nestedset.NestedSetBuilder;
import com.google.devtools.build.lib.collect.nestedset.Order;
-import com.google.devtools.build.lib.packages.TargetUtils;
import com.google.devtools.build.lib.util.Preconditions;
import com.google.devtools.build.skyframe.SkyValue;
import java.util.Collection;
@@ -35,8 +34,10 @@ public final class TargetCompleteEvent implements SkyValue, BuildEventWithOrderC
private final ConfiguredTarget target;
private final NestedSet<Cause> rootCauses;
private final Collection<BuildEventId> postedAfter;
+ private final boolean isTest;
- private TargetCompleteEvent(ConfiguredTarget target, NestedSet<Cause> rootCauses) {
+ private TargetCompleteEvent(
+ ConfiguredTarget target, NestedSet<Cause> rootCauses, boolean isTest) {
this.target = target;
this.rootCauses =
(rootCauses == null) ? NestedSetBuilder.<Cause>emptySet(Order.STABLE_ORDER) : rootCauses;
@@ -46,21 +47,26 @@ public final class TargetCompleteEvent implements SkyValue, BuildEventWithOrderC
postedAfterBuilder.add(BuildEventId.fromCause(cause));
}
this.postedAfter = postedAfterBuilder.build();
+ this.isTest = isTest;
}
- /**
- * Construct a successful target completion event.
- */
- public static TargetCompleteEvent createSuccessful(ConfiguredTarget ct) {
- return new TargetCompleteEvent(ct, null);
+ /** Construct a successful target completion event. */
+ public static TargetCompleteEvent createSuccessfulTarget(ConfiguredTarget ct) {
+ return new TargetCompleteEvent(ct, null, false);
}
+ /** Construct a successful target completion event for a target that will be tested. */
+ public static TargetCompleteEvent createSuccessfulTestTarget(ConfiguredTarget ct) {
+ return new TargetCompleteEvent(ct, null, true);
+ }
+
+
/**
* Construct a target completion event for a failed target, with the given non-empty root causes.
*/
public static TargetCompleteEvent createFailed(ConfiguredTarget ct, NestedSet<Cause> rootCauses) {
Preconditions.checkArgument(!Iterables.isEmpty(rootCauses));
- return new TargetCompleteEvent(ct, rootCauses);
+ return new TargetCompleteEvent(ct, rootCauses, false);
}
/**
@@ -93,7 +99,7 @@ public final class TargetCompleteEvent implements SkyValue, BuildEventWithOrderC
for (Cause cause : getRootCauses()) {
childrenBuilder.add(BuildEventId.fromCause(cause));
}
- if (TargetUtils.isTestRule(target.getTarget())) {
+ if (isTest) {
childrenBuilder.add(BuildEventId.testSummary(target.getTarget().getLabel()));
}
return childrenBuilder.build();