From f5d2fa73ae6f118588d080d2400f7596671d0479 Mon Sep 17 00:00:00 2001 From: Fabian Meumertzheim Date: Sun, 14 Jan 2024 22:13:24 +0100 Subject: [PATCH] Emit labels in display form in Java rules The Starlark actions can use `Label.to_display_form()`. Java compilation actions, which are still implemented in Java, can't access the main repository mapping via `BazelModuleContext` and instead retrieve it from a new field on `AnalysisEnvironment`. --- .../lib/analysis/AnalysisEnvironment.java | 7 ++ .../analysis/CachingAnalysisEnvironment.java | 12 ++- .../build/lib/analysis/RuleContext.java | 6 ++ .../lib/rules/java/JavaCompilationHelper.java | 29 +++++++ .../rules/java/JavaCompileActionBuilder.java | 15 ++-- .../rules/java/JavaHeaderCompileAction.java | 15 ++-- .../build/lib/skyframe/AspectFunction.java | 15 +++- .../skyframe/ConfiguredTargetFunction.java | 13 ++- .../build/lib/skyframe/SkyframeBuildView.java | 7 +- .../builtins_bzl/common/java/android_lint.bzl | 2 +- .../builtins_bzl/common/java/java_common.bzl | 2 +- .../java_common_internal_for_builtins.bzl | 2 +- .../builtins_bzl/common/java/java_helper.bzl | 12 +++ .../lib/analysis/util/AnalysisTestUtil.java | 11 +++ .../devtools/build/lib/analysis/util/BUILD | 1 + .../analysis/util/BuildViewForTesting.java | 9 ++- .../lib/analysis/util/BuildViewTestCase.java | 14 +++- .../devtools/build/lib/rules/android/BUILD | 1 + .../lib/rules/android/ResourceTestBase.java | 9 ++- src/test/shell/bazel/BUILD | 16 +++- src/test/shell/bazel/bazel_java_test.sh | 79 +++++++++++++++++++ src/test/shell/bazel/local_repository_test.sh | 2 +- 22 files changed, 249 insertions(+), 30 deletions(-) diff --git a/src/main/java/com/google/devtools/build/lib/analysis/AnalysisEnvironment.java b/src/main/java/com/google/devtools/build/lib/analysis/AnalysisEnvironment.java index d4b6ec7ff51dc9..527c27572cfde0 100644 --- a/src/main/java/com/google/devtools/build/lib/analysis/AnalysisEnvironment.java +++ b/src/main/java/com/google/devtools/build/lib/analysis/AnalysisEnvironment.java @@ -25,6 +25,7 @@ import com.google.devtools.build.lib.actions.ArtifactRoot; import com.google.devtools.build.lib.actions.MiddlemanFactory; import com.google.devtools.build.lib.analysis.config.BuildConfigurationValue; +import com.google.devtools.build.lib.cmdline.RepositoryMapping; import com.google.devtools.build.lib.events.ExtendedEventHandler; import com.google.devtools.build.lib.vfs.PathFragment; import com.google.devtools.build.skyframe.SkyFunction; @@ -166,4 +167,10 @@ Artifact.DerivedArtifact getDerivedArtifact( ImmutableSet getTreeArtifactsConflictingWithFiles(); ActionKeyContext getActionKeyContext(); + + /** + * The repository mapping applicable to the main repository. This is purely meant to support + * {@link com.google.devtools.build.lib.cmdline.Label#getDisplayForm)}. + */ + RepositoryMapping getMainRepoMapping(); } diff --git a/src/main/java/com/google/devtools/build/lib/analysis/CachingAnalysisEnvironment.java b/src/main/java/com/google/devtools/build/lib/analysis/CachingAnalysisEnvironment.java index 0ee01e8cf7b47d..48b8a258b82614 100644 --- a/src/main/java/com/google/devtools/build/lib/analysis/CachingAnalysisEnvironment.java +++ b/src/main/java/com/google/devtools/build/lib/analysis/CachingAnalysisEnvironment.java @@ -27,6 +27,7 @@ import com.google.devtools.build.lib.actions.ArtifactFactory; import com.google.devtools.build.lib.actions.ArtifactRoot; import com.google.devtools.build.lib.actions.MiddlemanFactory; +import com.google.devtools.build.lib.cmdline.RepositoryMapping; import com.google.devtools.build.lib.events.ExtendedEventHandler; import com.google.devtools.build.lib.events.StoredEventHandler; import com.google.devtools.build.lib.packages.Target; @@ -84,6 +85,8 @@ public final class CachingAnalysisEnvironment implements AnalysisEnvironment { */ private final List actions = new ArrayList<>(); + private final RepositoryMapping mainRepoMapping; + public CachingAnalysisEnvironment( ArtifactFactory artifactFactory, ActionKeyContext actionKeyContext, @@ -92,7 +95,8 @@ public CachingAnalysisEnvironment( boolean allowAnalysisFailures, ExtendedEventHandler errorEventListener, SkyFunction.Environment env, - StarlarkBuiltinsValue starlarkBuiltinsValue) { + StarlarkBuiltinsValue starlarkBuiltinsValue, + RepositoryMapping mainRepoMapping) { this.artifactFactory = artifactFactory; this.actionKeyContext = actionKeyContext; this.owner = Preconditions.checkNotNull(owner); @@ -101,6 +105,7 @@ public CachingAnalysisEnvironment( this.errorEventListener = errorEventListener; this.skyframeEnv = env; this.starlarkBuiltinsValue = starlarkBuiltinsValue; + this.mainRepoMapping = mainRepoMapping; middlemanFactory = new MiddlemanFactory(artifactFactory, this); } @@ -227,6 +232,11 @@ public ActionKeyContext getActionKeyContext() { return actionKeyContext; } + @Override + public RepositoryMapping getMainRepoMapping() { + return mainRepoMapping; + } + @Override public boolean hasErrors() { Preconditions.checkState(enabled); diff --git a/src/main/java/com/google/devtools/build/lib/analysis/RuleContext.java b/src/main/java/com/google/devtools/build/lib/analysis/RuleContext.java index a2c4e5ac4f6cdd..95dccd67c07012 100644 --- a/src/main/java/com/google/devtools/build/lib/analysis/RuleContext.java +++ b/src/main/java/com/google/devtools/build/lib/analysis/RuleContext.java @@ -54,6 +54,7 @@ import com.google.devtools.build.lib.analysis.starlark.StarlarkRuleContext; import com.google.devtools.build.lib.analysis.stringtemplate.TemplateContext; import com.google.devtools.build.lib.cmdline.Label; +import com.google.devtools.build.lib.cmdline.RepositoryMapping; import com.google.devtools.build.lib.cmdline.RepositoryName; import com.google.devtools.build.lib.collect.ImmutableSortedKeyListMultimap; import com.google.devtools.build.lib.collect.nestedset.NestedSet; @@ -375,6 +376,11 @@ public String getWorkspaceName() { return rule.getPackage().getWorkspaceName(); } + /** Returns the repository mapping of the main repository. */ + public RepositoryMapping getMainRepoMapping() { + return getAnalysisEnvironment().getMainRepoMapping(); + } + /** The configuration conditions that trigger this rule's configurable attributes. */ public ImmutableMap getConfigConditions() { return configConditions; diff --git a/src/main/java/com/google/devtools/build/lib/rules/java/JavaCompilationHelper.java b/src/main/java/com/google/devtools/build/lib/rules/java/JavaCompilationHelper.java index 984065b31e65a1..8f941718114ab4 100644 --- a/src/main/java/com/google/devtools/build/lib/rules/java/JavaCompilationHelper.java +++ b/src/main/java/com/google/devtools/build/lib/rules/java/JavaCompilationHelper.java @@ -16,6 +16,8 @@ import static com.google.common.base.Preconditions.checkNotNull; import static com.google.devtools.build.lib.packages.ExecGroup.DEFAULT_EXEC_GROUP_NAME; +import com.github.benmanes.caffeine.cache.Caffeine; +import com.github.benmanes.caffeine.cache.LoadingCache; import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableMap; @@ -23,6 +25,7 @@ import com.google.common.collect.Interner; import com.google.common.collect.Iterables; import com.google.devtools.build.lib.actions.Artifact; +import com.google.devtools.build.lib.actions.CommandLineItem; import com.google.devtools.build.lib.actions.ExecutionRequirements; import com.google.devtools.build.lib.actions.ParamFileInfo; import com.google.devtools.build.lib.actions.ParameterFile; @@ -38,6 +41,7 @@ import com.google.devtools.build.lib.analysis.config.CoreOptionConverters.StrictDepsMode; import com.google.devtools.build.lib.analysis.test.InstrumentedFilesCollector; import com.google.devtools.build.lib.cmdline.Label; +import com.google.devtools.build.lib.cmdline.RepositoryMapping; 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; @@ -63,6 +67,31 @@ */ public final class JavaCompilationHelper { + /** + * Cache for the {@link com.google.devtools.build.lib.actions.CommandLineItem.MapFn} that turns a + * {@link Label} into its possibly @-prefixed display form, which requires the repository mapping + * of the main repo. + * + *

The capacity of this cache after weakly reachable object have been cleaned will always be 1 + * as there is only a single main repo mapping in a given build. + */ + static final LoadingCache> + TARGET_LABEL_MAP_FN_CACHE = + Caffeine.newBuilder() + .initialCapacity(1) + .weakKeys() + .build( + mainRepoMapping -> + (label, args) -> { + String displayForm = label.getDisplayForm(mainRepoMapping); + if (displayForm.startsWith("@")) { + // @-prefixed strings will be assumed to be filenames and expanded by + // {@link JavaLibraryBuildRequest}, so add an extra &at; to escape it. + args.accept("@" + displayForm); + } else { + args.accept(displayForm); + } + }); private static final Interner> javacOptsInterner = BlazeInterners.newWeakInterner(); private static final Interner> executionInfoInterner = diff --git a/src/main/java/com/google/devtools/build/lib/rules/java/JavaCompileActionBuilder.java b/src/main/java/com/google/devtools/build/lib/rules/java/JavaCompileActionBuilder.java index 2237d1b703f757..c195b4d2ac2461 100644 --- a/src/main/java/com/google/devtools/build/lib/rules/java/JavaCompileActionBuilder.java +++ b/src/main/java/com/google/devtools/build/lib/rules/java/JavaCompileActionBuilder.java @@ -28,6 +28,7 @@ import com.google.devtools.build.lib.actions.extra.JavaCompileInfo; import com.google.devtools.build.lib.analysis.RuleContext; import com.google.devtools.build.lib.analysis.actions.CustomCommandLine; +import com.google.devtools.build.lib.analysis.actions.CustomCommandLine.VectorArg; import com.google.devtools.build.lib.analysis.config.CoreOptionConverters.StrictDepsMode; import com.google.devtools.build.lib.cmdline.Label; import com.google.devtools.build.lib.collect.nestedset.NestedSet; @@ -313,14 +314,12 @@ private CustomCommandLine buildParamFileContents(ImmutableList javacOpts result.add("--"); } if (targetLabel != null) { - result.add("--target_label"); - if (targetLabel.getRepository().isMain()) { - result.addLabel(targetLabel); - } else { - // @-prefixed strings will be assumed to be filenames and expanded by - // {@link JavaLibraryBuildRequest}, so add an extra &at; to escape it. - result.addPrefixedLabel("@", targetLabel); - } + result.addAll( + "--target_label", + VectorArg.of(ImmutableList.of(targetLabel)) + .mapped( + JavaCompilationHelper.TARGET_LABEL_MAP_FN_CACHE.get( + ruleContext.getMainRepoMapping()))); } result.add("--injecting_rule_kind", injectingRuleKind); // strict_java_deps controls whether the mapping from jars to targets is diff --git a/src/main/java/com/google/devtools/build/lib/rules/java/JavaHeaderCompileAction.java b/src/main/java/com/google/devtools/build/lib/rules/java/JavaHeaderCompileAction.java index b37facf9e5c57b..3ad7a2a21291a9 100644 --- a/src/main/java/com/google/devtools/build/lib/rules/java/JavaHeaderCompileAction.java +++ b/src/main/java/com/google/devtools/build/lib/rules/java/JavaHeaderCompileAction.java @@ -38,6 +38,7 @@ import com.google.devtools.build.lib.actions.SpawnResult; import com.google.devtools.build.lib.analysis.RuleContext; import com.google.devtools.build.lib.analysis.actions.CustomCommandLine; +import com.google.devtools.build.lib.analysis.actions.CustomCommandLine.VectorArg; import com.google.devtools.build.lib.analysis.actions.PathMappers; import com.google.devtools.build.lib.analysis.actions.SpawnAction; import com.google.devtools.build.lib.analysis.config.CoreOptionConverters.StrictDepsMode; @@ -439,14 +440,12 @@ public void build(JavaToolchainProvider javaToolchain) throws RuleErrorException } if (targetLabel != null) { - commandLine.add("--target_label"); - if (targetLabel.getRepository().isMain()) { - commandLine.addLabel(targetLabel); - } else { - // @-prefixed strings will be assumed to be params filenames and expanded, - // so add an extra @ to escape it. - commandLine.addPrefixedLabel("@", targetLabel); - } + commandLine.addAll( + "--target_label", + VectorArg.of(ImmutableList.of(targetLabel)) + .mapped( + JavaCompilationHelper.TARGET_LABEL_MAP_FN_CACHE.get( + ruleContext.getMainRepoMapping()))); } ImmutableMap executionInfo = diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/AspectFunction.java b/src/main/java/com/google/devtools/build/lib/skyframe/AspectFunction.java index 931ba5154cff55..e152b94d945f12 100644 --- a/src/main/java/com/google/devtools/build/lib/skyframe/AspectFunction.java +++ b/src/main/java/com/google/devtools/build/lib/skyframe/AspectFunction.java @@ -58,6 +58,8 @@ import com.google.devtools.build.lib.causes.LabelCause; import com.google.devtools.build.lib.cmdline.Label; import com.google.devtools.build.lib.cmdline.PackageIdentifier; +import com.google.devtools.build.lib.cmdline.RepositoryMapping; +import com.google.devtools.build.lib.cmdline.RepositoryName; import com.google.devtools.build.lib.collect.nestedset.NestedSet; import com.google.devtools.build.lib.collect.nestedset.NestedSetBuilder; import com.google.devtools.build.lib.events.Event; @@ -763,12 +765,23 @@ private AspectValue createAspect( if (env.valuesMissing()) { return null; } + RepositoryMappingValue mainRepoMappingValue = + (RepositoryMappingValue) env.getValue(RepositoryMappingValue.key(RepositoryName.MAIN)); + if (mainRepoMappingValue == null) { + return null; + } SkyframeBuildView view = buildViewProvider.getSkyframeBuildView(); StoredEventHandler events = new StoredEventHandler(); CachingAnalysisEnvironment analysisEnvironment = - view.createAnalysisEnvironment(key, events, env, configuration, starlarkBuiltinsValue); + view.createAnalysisEnvironment( + key, + events, + env, + configuration, + starlarkBuiltinsValue, + mainRepoMappingValue.getRepositoryMapping()); ConfiguredAspect configuredAspect; if (aspect.getDefinition().applyToGeneratingRules() && associatedTarget instanceof OutputFile) { diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/ConfiguredTargetFunction.java b/src/main/java/com/google/devtools/build/lib/skyframe/ConfiguredTargetFunction.java index 0b4cd97ac20f48..a22cf7e8d19039 100644 --- a/src/main/java/com/google/devtools/build/lib/skyframe/ConfiguredTargetFunction.java +++ b/src/main/java/com/google/devtools/build/lib/skyframe/ConfiguredTargetFunction.java @@ -46,6 +46,7 @@ import com.google.devtools.build.lib.causes.AnalysisFailedCause; import com.google.devtools.build.lib.causes.Cause; import com.google.devtools.build.lib.cmdline.Label; +import com.google.devtools.build.lib.cmdline.RepositoryName; 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; @@ -373,11 +374,21 @@ private static ConfiguredTargetValue createConfiguredTarget( if (starlarkBuiltinsValue == null) { return null; } + RepositoryMappingValue mainRepoMappingValue = + (RepositoryMappingValue) env.getValue(RepositoryMappingValue.key(RepositoryName.MAIN)); + if (mainRepoMappingValue == null) { + return null; + } StoredEventHandler events = new StoredEventHandler(); CachingAnalysisEnvironment analysisEnvironment = view.createAnalysisEnvironment( - configuredTargetKey, events, env, configuration, starlarkBuiltinsValue); + configuredTargetKey, + events, + env, + configuration, + starlarkBuiltinsValue, + mainRepoMappingValue.getRepositoryMapping()); Preconditions.checkNotNull(depValueMap); ConfiguredTarget configuredTarget; diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/SkyframeBuildView.java b/src/main/java/com/google/devtools/build/lib/skyframe/SkyframeBuildView.java index 6e4a424e3ad879..5d3a9064ed936d 100644 --- a/src/main/java/com/google/devtools/build/lib/skyframe/SkyframeBuildView.java +++ b/src/main/java/com/google/devtools/build/lib/skyframe/SkyframeBuildView.java @@ -77,6 +77,7 @@ import com.google.devtools.build.lib.buildeventstream.BuildEventStreamProtos.BuildMetrics.BuildGraphMetrics; import com.google.devtools.build.lib.causes.AnalysisFailedCause; import com.google.devtools.build.lib.cmdline.Label; +import com.google.devtools.build.lib.cmdline.RepositoryMapping; 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; @@ -1267,7 +1268,8 @@ CachingAnalysisEnvironment createAnalysisEnvironment( ExtendedEventHandler eventHandler, Environment env, BuildConfigurationValue config, - StarlarkBuiltinsValue starlarkBuiltinsValue) { + StarlarkBuiltinsValue starlarkBuiltinsValue, + RepositoryMapping mainRepoMapping) { boolean extendedSanityChecks = config != null && config.extendedSanityChecks(); boolean allowAnalysisFailures = config != null && config.allowAnalysisFailures(); return new CachingAnalysisEnvironment( @@ -1278,7 +1280,8 @@ CachingAnalysisEnvironment createAnalysisEnvironment( allowAnalysisFailures, eventHandler, env, - starlarkBuiltinsValue); + starlarkBuiltinsValue, + mainRepoMapping); } /** diff --git a/src/main/starlark/builtins_bzl/common/java/android_lint.bzl b/src/main/starlark/builtins_bzl/common/java/android_lint.bzl index 2d14b2ac95e4cb..46db235b0913a2 100644 --- a/src/main/starlark/builtins_bzl/common/java/android_lint.bzl +++ b/src/main/starlark/builtins_bzl/common/java/android_lint.bzl @@ -98,7 +98,7 @@ def _android_lint_action(ctx, source_files, source_jars, compilation_info): args.add_all("--bootclasspath", bootclasspath) args.add_all("--classpath", classpath) args.add_all("--lint_rules", compilation_info.plugins.processor_jars) - args.add("--target_label", ctx.label) + args.add_all("--target_label", [ctx.label], map_each = helper.map_to_display_form) javac_opts = compilation_info.javac_options if javac_opts: diff --git a/src/main/starlark/builtins_bzl/common/java/java_common.bzl b/src/main/starlark/builtins_bzl/common/java/java_common.bzl index c8a5d8c3638686..a4a1d1cbf63f8a 100644 --- a/src/main/starlark/builtins_bzl/common/java/java_common.bzl +++ b/src/main/starlark/builtins_bzl/common/java/java_common.bzl @@ -120,7 +120,7 @@ def _stamp_jar(actions, jar, java_toolchain, target_label): args.add(jar) args.add(output) args.add("--nostrip_jar") - args.add("--target_label", target_label) + args.add_all("--target_label", [target_label], map_each = helper.map_to_display_form) actions.run( mnemonic = "JavaIjar", inputs = [jar], diff --git a/src/main/starlark/builtins_bzl/common/java/java_common_internal_for_builtins.bzl b/src/main/starlark/builtins_bzl/common/java/java_common_internal_for_builtins.bzl index ee11a669739bf0..7ba7ef4c8b66e7 100644 --- a/src/main/starlark/builtins_bzl/common/java/java_common_internal_for_builtins.bzl +++ b/src/main/starlark/builtins_bzl/common/java/java_common_internal_for_builtins.bzl @@ -375,7 +375,7 @@ def run_ijar( args.add(jar) args.add(output) if target_label != None: - args.add("--target_label", target_label) + args.add_all("--target_label", [target_label], map_each = helper.map_to_display_form) if injecting_rule_kind != None: args.add("--injecting_rule_kind", injecting_rule_kind) diff --git a/src/main/starlark/builtins_bzl/common/java/java_helper.bzl b/src/main/starlark/builtins_bzl/common/java/java_helper.bzl index d91dc25f7c3235..111c405648ee70 100644 --- a/src/main/starlark/builtins_bzl/common/java/java_helper.bzl +++ b/src/main/starlark/builtins_bzl/common/java/java_helper.bzl @@ -453,6 +453,17 @@ def _derive_output_file(ctx, base_file, *, name_suffix = "", extension = None, e new_basename = paths.replace_extension(base_file.basename, name_suffix + "." + extension + extension_suffix) return ctx.actions.declare_file(new_basename, sibling = base_file) +def _map_to_display_form(label): + """`map_each` callback that formats a `Label` with `Label.to_display_form()` + + Args: + label: (Label) the label of a target. + + Returns: + (str) the display form representation of `label` + """ + return label.to_display_form() + helper = struct( collect_all_targets_as_deps = _collect_all_targets_as_deps, filter_launcher_for_target = _filter_launcher_for_target, @@ -479,4 +490,5 @@ helper = struct( tokenize_javacopts = _tokenize_javacopts, detokenize_javacopts = _detokenize_javacopts, derive_output_file = _derive_output_file, + map_to_display_form = _map_to_display_form, ) diff --git a/src/test/java/com/google/devtools/build/lib/analysis/util/AnalysisTestUtil.java b/src/test/java/com/google/devtools/build/lib/analysis/util/AnalysisTestUtil.java index 82b2edf7b46e10..ac75a8cb096687 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/util/AnalysisTestUtil.java +++ b/src/test/java/com/google/devtools/build/lib/analysis/util/AnalysisTestUtil.java @@ -49,6 +49,7 @@ import com.google.devtools.build.lib.analysis.config.BuildOptionsView; import com.google.devtools.build.lib.analysis.config.ExecutionTransitionFactory; import com.google.devtools.build.lib.cmdline.Label; +import com.google.devtools.build.lib.cmdline.RepositoryMapping; import com.google.devtools.build.lib.cmdline.RepositoryName; import com.google.devtools.build.lib.collect.nestedset.NestedSetBuilder; import com.google.devtools.build.lib.collect.nestedset.Order; @@ -225,6 +226,11 @@ public ImmutableSet getTreeArtifactsConflictingWithFiles() { public ActionKeyContext getActionKeyContext() { return original.getActionKeyContext(); } + + @Override + public RepositoryMapping getMainRepoMapping() { + return original.getMainRepoMapping(); + } } /** A dummy WorkspaceStatusAction. */ @@ -455,6 +461,11 @@ public ImmutableSet getTreeArtifactsConflictingWithFiles() { public ActionKeyContext getActionKeyContext() { return null; } + + @Override + public RepositoryMapping getMainRepoMapping() { + throw new UnsupportedOperationException(); + } } /** Matches the output path prefix contributed by a C++ configuration fragment. */ diff --git a/src/test/java/com/google/devtools/build/lib/analysis/util/BUILD b/src/test/java/com/google/devtools/build/lib/analysis/util/BUILD index 2a1b4229aaf330..3aefbf1a290922 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/util/BUILD +++ b/src/test/java/com/google/devtools/build/lib/analysis/util/BUILD @@ -104,6 +104,7 @@ java_library( "//src/main/java/com/google/devtools/build/lib/skyframe:diff_awareness", "//src/main/java/com/google/devtools/build/lib/skyframe:package_roots_no_symlink_creation", "//src/main/java/com/google/devtools/build/lib/skyframe:precomputed_value", + "//src/main/java/com/google/devtools/build/lib/skyframe:repository_mapping_value", "//src/main/java/com/google/devtools/build/lib/skyframe:sky_functions", "//src/main/java/com/google/devtools/build/lib/skyframe:skyframe_cluster", "//src/main/java/com/google/devtools/build/lib/skyframe:skyframe_executor_repository_helpers_holder", diff --git a/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewForTesting.java b/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewForTesting.java index d16f4b3242a9d7..3fd6a52d0195e3 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewForTesting.java +++ b/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewForTesting.java @@ -58,6 +58,7 @@ import com.google.devtools.build.lib.analysis.test.CoverageReportActionFactory; import com.google.devtools.build.lib.bugreport.BugReporter; import com.google.devtools.build.lib.cmdline.Label; +import com.google.devtools.build.lib.cmdline.RepositoryName; import com.google.devtools.build.lib.collect.nestedset.NestedSetBuilder; import com.google.devtools.build.lib.collect.nestedset.Order; import com.google.devtools.build.lib.concurrent.ThreadSafety.ThreadCompatible; @@ -77,6 +78,7 @@ import com.google.devtools.build.lib.skyframe.ConfiguredTargetEvaluationExceptions.UnreportedException; import com.google.devtools.build.lib.skyframe.ConfiguredTargetKey; import com.google.devtools.build.lib.skyframe.DependencyResolver; +import com.google.devtools.build.lib.skyframe.RepositoryMappingValue; import com.google.devtools.build.lib.skyframe.SkyFunctionEnvironmentForTesting; import com.google.devtools.build.lib.skyframe.SkyFunctions; import com.google.devtools.build.lib.skyframe.SkyframeBuildView; @@ -348,6 +350,10 @@ public RuleContext getRuleContextForTesting( StarlarkBuiltinsValue starlarkBuiltinsValue = (StarlarkBuiltinsValue) Preconditions.checkNotNull(skyframeEnv.getValue(StarlarkBuiltinsValue.key())); + RepositoryMappingValue mainRepoMappingValue = + (RepositoryMappingValue) + Preconditions.checkNotNull( + skyframeEnv.getValue(RepositoryMappingValue.key(RepositoryName.MAIN))); CachingAnalysisEnvironment analysisEnv = new CachingAnalysisEnvironment( getArtifactFactory(), @@ -360,7 +366,8 @@ public RuleContext getRuleContextForTesting( targetConfig.allowAnalysisFailures(), eventHandler, skyframeEnv, - starlarkBuiltinsValue); + starlarkBuiltinsValue, + mainRepoMappingValue.getRepositoryMapping()); return getRuleContextForTesting(eventHandler, target, analysisEnv); } diff --git a/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java b/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java index 440788fb3dfd80..b711f496db398d 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java +++ b/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java @@ -111,6 +111,7 @@ import com.google.devtools.build.lib.cmdline.LabelConstants; import com.google.devtools.build.lib.cmdline.LabelSyntaxException; import com.google.devtools.build.lib.cmdline.PackageIdentifier; +import com.google.devtools.build.lib.cmdline.RepositoryMapping; import com.google.devtools.build.lib.cmdline.RepositoryName; import com.google.devtools.build.lib.collect.nestedset.NestedSet; import com.google.devtools.build.lib.collect.nestedset.NestedSetBuilder; @@ -152,6 +153,7 @@ import com.google.devtools.build.lib.skyframe.PackageFunction; import com.google.devtools.build.lib.skyframe.PackageRootsNoSymlinkCreation; import com.google.devtools.build.lib.skyframe.PrecomputedValue; +import com.google.devtools.build.lib.skyframe.RepositoryMappingValue; import com.google.devtools.build.lib.skyframe.SequencedSkyframeExecutor; import com.google.devtools.build.lib.skyframe.SkyFunctionEnvironmentForTesting; import com.google.devtools.build.lib.skyframe.SkyFunctions; @@ -643,6 +645,10 @@ protected CachingAnalysisEnvironment getTestAnalysisEnvironment() throws Interru StarlarkBuiltinsValue starlarkBuiltinsValue = (StarlarkBuiltinsValue) Preconditions.checkNotNull(env.getValue(StarlarkBuiltinsValue.key())); + RepositoryMappingValue mainRepoMappingValue = + (RepositoryMappingValue) + Preconditions.checkNotNull( + env.getValue(RepositoryMappingValue.key(RepositoryName.MAIN))); return new CachingAnalysisEnvironment( view.getArtifactFactory(), actionKeyContext, @@ -668,7 +674,8 @@ public SkyFunctionName functionName() { /*allowAnalysisFailures=*/ false, reporter, env, - starlarkBuiltinsValue); + starlarkBuiltinsValue, + mainRepoMappingValue.getRepositoryMapping()); } /** @@ -2141,6 +2148,11 @@ public ImmutableSet getTreeArtifactsConflictingWithFiles() { public ActionKeyContext getActionKeyContext() { return actionKeyContext; } + + @Override + public RepositoryMapping getMainRepoMapping() { + throw new UnsupportedOperationException(); + } } protected Iterable baselineCoverageArtifactBasenames(ConfiguredTarget target) diff --git a/src/test/java/com/google/devtools/build/lib/rules/android/BUILD b/src/test/java/com/google/devtools/build/lib/rules/android/BUILD index b0e8a06011257f..b60a0b8225fc93 100644 --- a/src/test/java/com/google/devtools/build/lib/rules/android/BUILD +++ b/src/test/java/com/google/devtools/build/lib/rules/android/BUILD @@ -217,6 +217,7 @@ java_library( "//src/main/java/com/google/devtools/build/lib/collect/nestedset", "//src/main/java/com/google/devtools/build/lib/events", "//src/main/java/com/google/devtools/build/lib/skyframe:configured_target_key", + "//src/main/java/com/google/devtools/build/lib/skyframe:repository_mapping_value", "//src/main/java/com/google/devtools/build/lib/skyframe:starlark_builtins_value", "//src/main/java/com/google/devtools/build/lib/vfs", "//src/main/java/com/google/devtools/build/lib/vfs/inmemoryfs", diff --git a/src/test/java/com/google/devtools/build/lib/rules/android/ResourceTestBase.java b/src/test/java/com/google/devtools/build/lib/rules/android/ResourceTestBase.java index 7ed84bfc65b534..c22609568538c1 100644 --- a/src/test/java/com/google/devtools/build/lib/rules/android/ResourceTestBase.java +++ b/src/test/java/com/google/devtools/build/lib/rules/android/ResourceTestBase.java @@ -31,10 +31,12 @@ import com.google.devtools.build.lib.analysis.RuleErrorConsumer; import com.google.devtools.build.lib.cmdline.Label; import com.google.devtools.build.lib.cmdline.LabelSyntaxException; +import com.google.devtools.build.lib.cmdline.RepositoryName; import com.google.devtools.build.lib.collect.nestedset.NestedSet; import com.google.devtools.build.lib.events.ExtendedEventHandler; import com.google.devtools.build.lib.events.StoredEventHandler; import com.google.devtools.build.lib.skyframe.ConfiguredTargetKey; +import com.google.devtools.build.lib.skyframe.RepositoryMappingValue; import com.google.devtools.build.lib.skyframe.SkyFunctionEnvironmentForTesting; import com.google.devtools.build.lib.skyframe.StarlarkBuiltinsValue; import com.google.devtools.build.lib.vfs.DigestHashFunction; @@ -192,6 +194,10 @@ public RuleContext getRuleContextForActionTesting(ConfiguredTarget dummyTarget) StarlarkBuiltinsValue starlarkBuiltinsValue = (StarlarkBuiltinsValue) Preconditions.checkNotNull(skyframeEnv.getValue(StarlarkBuiltinsValue.key())); + RepositoryMappingValue mainRepoMappingValue = + (RepositoryMappingValue) + Preconditions.checkNotNull( + skyframeEnv.getValue(RepositoryMappingValue.key(RepositoryName.MAIN))); CachingAnalysisEnvironment analysisEnv = new CachingAnalysisEnvironment( view.getArtifactFactory(), @@ -204,7 +210,8 @@ public RuleContext getRuleContextForActionTesting(ConfiguredTarget dummyTarget) targetConfig.allowAnalysisFailures(), eventHandler, skyframeEnv, - starlarkBuiltinsValue); + starlarkBuiltinsValue, + mainRepoMappingValue.getRepositoryMapping()); return view.getRuleContextForTesting(eventHandler, dummyTarget, analysisEnv); } diff --git a/src/test/shell/bazel/BUILD b/src/test/shell/bazel/BUILD index 6ecfffbb0d2c4d..9431ed965dbab1 100644 --- a/src/test/shell/bazel/BUILD +++ b/src/test/shell/bazel/BUILD @@ -258,6 +258,10 @@ sh_test( "@bazel_tools//tools/bash/runfiles", ], exec_compatible_with = ["//:highcpu_machine"], + tags = [ + # bzlmod usage requires network + "requires-network", + ], ) JAVA_VERSIONS = ("11", "17") @@ -287,6 +291,10 @@ JAVA_VERSIONS_COVERAGE = ("11", "17") "@bazel_tools//tools/bash/runfiles", ], exec_compatible_with = ["//:highcpu_machine"], + tags = [ + # bzlmod usage requires network + "requires-network", + ], ) for java_version in JAVA_VERSIONS ] @@ -311,8 +319,12 @@ JAVA_VERSIONS_COVERAGE = ("11", "17") ":test-deps", "@bazel_tools//tools/bash/runfiles", ], - # This test is only run by the java_tools binaries pipeline. - tags = ["manual"], + tags = [ + # This test is only run by the java_tools binaries pipeline. + "manual", + # bzlmod usage requires network + "requires-network", + ], ) for java_version in JAVA_VERSIONS ] diff --git a/src/test/shell/bazel/bazel_java_test.sh b/src/test/shell/bazel/bazel_java_test.sh index 18bcb36c2ef1c4..32c557c76c8f0b 100755 --- a/src/test/shell/bazel/bazel_java_test.sh +++ b/src/test/shell/bazel/bazel_java_test.sh @@ -1944,4 +1944,83 @@ EOF bazel build //pkg:a >& $TEST_log || fail "build failed" } +function test_strict_deps_error_external_repo_native_action() { + cat << 'EOF' > MODULE.bazel +bazel_dep( + name = "lib_c", + repo_name = "c", +) +local_path_override( + module_name = "lib_c", + path = "lib_c", +) +EOF + + mkdir -p pkg + cat << 'EOF' > pkg/BUILD +java_library(name = "a", srcs = ["A.java"], deps = [":b"]) +java_library(name = "b", srcs = ["B.java"], deps = ["@c"]) +EOF + cat << 'EOF' > pkg/A.java +public class A extends B implements C {} +EOF + cat << 'EOF' > pkg/B.java +public class B implements C {} +EOF + + mkdir -p lib_c + cat << 'EOF' > lib_c/MODULE.bazel +module(name = "lib_c") +EOF + cat << 'EOF' > lib_c/BUILD +java_library(name = "c", srcs = ["C.java"], visibility = ["//visibility:public"]) +EOF + cat << 'EOF' > lib_c/C.java +public interface C {} +EOF + + bazel build //pkg:a >& $TEST_log && fail "build should fail" + expect_log "buildozer 'add deps @c//:c' //pkg:a" +} + +function test_strict_deps_error_external_repo_starlark_action() { + cat << 'EOF' > MODULE.bazel +bazel_dep( + name = "lib_c", + repo_name = "c", +) +local_path_override( + module_name = "lib_c", + path = "lib_c", +) +EOF + + mkdir -p pkg + cat << 'EOF' > pkg/BUILD +java_library(name = "a", srcs = ["A.java"], deps = [":b"]) +java_library(name = "b", srcs = ["B.java"], deps = ["@c"]) +EOF + cat << 'EOF' > pkg/A.java +public class A extends B implements C {} +EOF + cat << 'EOF' > pkg/B.java +public class B implements C {} +EOF + + mkdir -p lib_c + cat << 'EOF' > lib_c/MODULE.bazel +module(name = "lib_c") +EOF + cat << 'EOF' > lib_c/BUILD +java_library(name = "c_pregen", srcs = ["C.java"]) +java_import(name = "c", jars = ["libc_pregen.jar"], visibility = ["//visibility:public"]) +EOF + cat << 'EOF' > lib_c/C.java +public interface C {} +EOF + + bazel build //pkg:a >& $TEST_log && fail "build should fail" + expect_log "buildozer 'add deps @c//:c' //pkg:a" +} + run_suite "Java integration tests" diff --git a/src/test/shell/bazel/local_repository_test.sh b/src/test/shell/bazel/local_repository_test.sh index 7299fcd4ba02b5..ef4c553b3fdad5 100755 --- a/src/test/shell/bazel/local_repository_test.sh +++ b/src/test/shell/bazel/local_repository_test.sh @@ -1369,7 +1369,7 @@ EOF bazel build @x_repo//a >& $TEST_log && fail "Building @x_repo//a should error out" expect_log "** Please add the following dependencies:" - expect_log "@@x_repo//x to @@x_repo//a" + expect_log " @x_repo//x to @x_repo//a" } # This test verifies that the `public` pattern includes external dependencies.