|
32 | 32 | import com.google.devtools.build.skyframe.SkyKey; |
33 | 33 | import com.google.devtools.build.skyframe.SkyValue; |
34 | 34 | import java.io.Serializable; |
| 35 | +import java.util.Collection; |
35 | 36 | import java.util.Objects; |
36 | 37 | import javax.annotation.Nullable; |
37 | 38 |
|
@@ -64,38 +65,34 @@ public final class TargetPatternPhaseValue implements SkyValue { |
64 | 65 | this.workspaceName = workspaceName; |
65 | 66 | } |
66 | 67 |
|
| 68 | + private static ImmutableSet<Target> getTargetsFromLabels( |
| 69 | + Collection<Label> labels, ExtendedEventHandler eventHandler, PackageManager packageManager) |
| 70 | + throws InterruptedException { |
| 71 | + ImmutableSet.Builder<Target> result = ImmutableSet.builderWithExpectedSize(labels.size()); |
| 72 | + for (Label label : labels) { |
| 73 | + try { |
| 74 | + result.add( |
| 75 | + packageManager |
| 76 | + .getPackage(eventHandler, label.getPackageIdentifier()) |
| 77 | + .getTarget(label.getName())); |
| 78 | + } catch (NoSuchTargetException | NoSuchPackageException e) { |
| 79 | + throw new IllegalStateException( |
| 80 | + "Failed to get preloaded package from TargetPatternPhaseValue for " + label, e); |
| 81 | + } |
| 82 | + } |
| 83 | + return result.build(); |
| 84 | + } |
| 85 | + |
67 | 86 | public ImmutableSet<Target> getTargets( |
68 | | - ExtendedEventHandler eventHandler, PackageManager packageManager) { |
69 | | - return targetLabels |
70 | | - .stream() |
71 | | - .map( |
72 | | - (label) -> { |
73 | | - try { |
74 | | - return packageManager |
75 | | - .getPackage(eventHandler, label.getPackageIdentifier()) |
76 | | - .getTarget(label.getName()); |
77 | | - } catch (NoSuchPackageException | NoSuchTargetException | InterruptedException e) { |
78 | | - throw new RuntimeException("Failed to get package from TargetPatternPhaseValue", e); |
79 | | - } |
80 | | - }) |
81 | | - .collect(ImmutableSet.toImmutableSet()); |
| 87 | + ExtendedEventHandler eventHandler, PackageManager packageManager) |
| 88 | + throws InterruptedException { |
| 89 | + return getTargetsFromLabels(targetLabels, eventHandler, packageManager); |
82 | 90 | } |
83 | 91 |
|
84 | 92 | public ImmutableSet<Target> getTestsToRun( |
85 | | - ExtendedEventHandler eventHandler, PackageManager packageManager) { |
86 | | - return testsToRunLabels |
87 | | - .stream() |
88 | | - .map( |
89 | | - (label) -> { |
90 | | - try { |
91 | | - return packageManager |
92 | | - .getPackage(eventHandler, label.getPackageIdentifier()) |
93 | | - .getTarget(label.getName()); |
94 | | - } catch (NoSuchPackageException | NoSuchTargetException | InterruptedException e) { |
95 | | - throw new RuntimeException("Failed to get package from TargetPatternPhaseValue", e); |
96 | | - } |
97 | | - }) |
98 | | - .collect(ImmutableSet.toImmutableSet()); |
| 93 | + ExtendedEventHandler eventHandler, PackageManager packageManager) |
| 94 | + throws InterruptedException { |
| 95 | + return getTargetsFromLabels(testsToRunLabels, eventHandler, packageManager); |
99 | 96 | } |
100 | 97 |
|
101 | 98 | public ImmutableSet<Label> getTargetLabels() { |
|
0 commit comments