From f0874119b6b19f97b4e381163f229a8efdf745f1 Mon Sep 17 00:00:00 2001 From: "bazel.build machine account" <15028808+bazel-io@users.noreply.github.com> Date: Sat, 27 Jan 2024 02:10:12 +0100 Subject: [PATCH] [7.1.0] Disable `--legacy_external_runfiles` in Bazel tests (#21086) This requires fixing an actual bug that causes the Windows Java launcher to not find the Java runtime with `--nolegacy_external_runfiles`. Work towards https://github.com/bazelbuild/bazel/issues/12821 Closes #20680. Commit https://github.com/bazelbuild/bazel/commit/3d4491c9ab0c063356d3c017a9308c50fa604294 PiperOrigin-RevId: 601826685 Change-Id: Ib45e60901d47efc06bf875c334edafcaeabc5f1e Co-authored-by: Fabian Meumertzheim --- .../builtins_bzl/bazel/java/bazel_java_binary.bzl | 3 +-- .../lib/analysis/LocationExpanderIntegrationTest.java | 3 ++- .../lib/analysis/RunfilesRepoMappingManifestTest.java | 3 +-- .../build/lib/analysis/util/AnalysisTestCase.java | 10 ++++++++-- src/test/py/bazel/test_base.py | 1 + src/test/shell/bazel/bazel_java_test.sh | 1 + src/test/shell/bazel/external_integration_test.sh | 4 ++-- src/test/shell/testenv.sh.tmpl | 3 +++ 8 files changed, 19 insertions(+), 9 deletions(-) diff --git a/src/main/starlark/builtins_bzl/bazel/java/bazel_java_binary.bzl b/src/main/starlark/builtins_bzl/bazel/java/bazel_java_binary.bzl index 21f7e09c0f1439..8c28c0d9316633 100644 --- a/src/main/starlark/builtins_bzl/bazel/java/bazel_java_binary.bzl +++ b/src/main/starlark/builtins_bzl/bazel/java/bazel_java_binary.bzl @@ -250,8 +250,7 @@ def _create_windows_exe_launcher(ctx, java_executable, classpath, main_class, jv launch_info.add(main_class, format = "java_start_class=%s") launch_info.add_joined(classpath, map_each = _short_path, join_with = ";", format_joined = "classpath=%s", omit_if_empty = False) launch_info.add_joined(jvm_flags_for_launcher, join_with = "\t", format_joined = "jvm_flags=%s", omit_if_empty = False) - jar_bin_path = semantics.find_java_runtime_toolchain(ctx).java_home + "/bin/jar.exe" - launch_info.add(jar_bin_path, format = "jar_bin_path=%s") + launch_info.add(semantics.find_java_runtime_toolchain(ctx).java_home_runfiles_path, format = "jar_bin_path=%s/bin/jar.exe") # TODO(b/295221112): Change to use the "launcher" attribute (only windows use a fixed _launcher attribute) launcher_artifact = ctx.executable._launcher diff --git a/src/test/java/com/google/devtools/build/lib/analysis/LocationExpanderIntegrationTest.java b/src/test/java/com/google/devtools/build/lib/analysis/LocationExpanderIntegrationTest.java index 951f810f148334..10a0b4aef58f2a 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/LocationExpanderIntegrationTest.java +++ b/src/test/java/com/google/devtools/build/lib/analysis/LocationExpanderIntegrationTest.java @@ -155,7 +155,7 @@ public void otherPathExpansion() throws Exception { } @Test - public void otherPathExternalExpansion() throws Exception { + public void otherPathExternalExpansionLegacyExternalRunfiles() throws Exception { scratch.file( "expansion/BUILD", "sh_library(name='lib', srcs=['@r//p:foo'])"); @@ -171,6 +171,7 @@ public void otherPathExternalExpansion() throws Exception { scratch.file("/r/WORKSPACE", "workspace(name = 'r')"); scratch.file("/r/p/BUILD", "genrule(name='foo', outs=['foo.txt'], cmd='never executed')"); + useConfiguration("--legacy_external_runfiles"); LocationExpander expander = makeExpander("//expansion:lib"); assertThat(expander.expand("foo $(execpath @r//p:foo) bar")) .matches("foo .*-out/.*/external/r/p/foo\\.txt bar"); diff --git a/src/test/java/com/google/devtools/build/lib/analysis/RunfilesRepoMappingManifestTest.java b/src/test/java/com/google/devtools/build/lib/analysis/RunfilesRepoMappingManifestTest.java index 21cd1832c3ba50..523d6fec469193 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/RunfilesRepoMappingManifestTest.java +++ b/src/test/java/com/google/devtools/build/lib/analysis/RunfilesRepoMappingManifestTest.java @@ -371,9 +371,8 @@ public void hasMappingForSymlinks() throws Exception { .map(PathFragment::getPathString) .collect(toImmutableList()); assertThat(runfilesPaths) - .containsExactly( + .containsAtLeast( "aaa~1.0/aaa", - getRuleClassProvider().getRunfilesPrefix() + "/external/aaa~1.0/aaa", getRuleClassProvider().getRunfilesPrefix() + "/path/to/pkg/symlink", "symlinks~1.0/path/to/pkg/root_symlink", "_repo_mapping"); diff --git a/src/test/java/com/google/devtools/build/lib/analysis/util/AnalysisTestCase.java b/src/test/java/com/google/devtools/build/lib/analysis/util/AnalysisTestCase.java index 2ef4e359f74a2d..c186294e059d6f 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/util/AnalysisTestCase.java +++ b/src/test/java/com/google/devtools/build/lib/analysis/util/AnalysisTestCase.java @@ -129,7 +129,9 @@ public enum Flag { // Flags from TestConstants.PRODUCT_SPECIFIC_FLAGS. PRODUCT_SPECIFIC_FLAGS, // The --enable_bzlmod flags. - ENABLE_BZLMOD + ENABLE_BZLMOD, + // The --nolegacy_external_runfiles flag. + NO_LEGACY_EXTERNAL_RUNFILES } /** Helper class to make it easy to enable and disable flags. */ @@ -354,6 +356,9 @@ public void useConfiguration(String... args) throws Exception { } else { optionsParser.parse("--noenable_bzlmod"); } + if (defaultFlags().contains(Flag.NO_LEGACY_EXTERNAL_RUNFILES)) { + optionsParser.parse("--nolegacy_external_runfiles"); + } optionsParser.parse(args); buildOptions = @@ -364,7 +369,8 @@ protected FlagBuilder defaultFlags() { return new FlagBuilder() .with(Flag.PUBLIC_VISIBILITY) .with(Flag.CPU_K8) - .with(Flag.PRODUCT_SPECIFIC_FLAGS); + .with(Flag.PRODUCT_SPECIFIC_FLAGS) + .with(Flag.NO_LEGACY_EXTERNAL_RUNFILES); } protected Action getGeneratingAction(Artifact artifact) { diff --git a/src/test/py/bazel/test_base.py b/src/test/py/bazel/test_base.py index a9362e9f73b5b3..959cb9342ccc85 100644 --- a/src/test/py/bazel/test_base.py +++ b/src/test/py/bazel/test_base.py @@ -115,6 +115,7 @@ def setUp(self): self._test_cwd = tempfile.mkdtemp(dir=self._tests_root) self._test_bazelrc = os.path.join(self._temp, 'test_bazelrc') with open(self._test_bazelrc, 'wt') as f: + f.write('common --nolegacy_external_runfiles\n') shared_repo_home = os.environ.get('TEST_REPOSITORY_HOME') if shared_repo_home and os.path.exists(shared_repo_home): for repo in self._SHARED_REPOS: diff --git a/src/test/shell/bazel/bazel_java_test.sh b/src/test/shell/bazel/bazel_java_test.sh index 1dda5b4ad8bab3..83cd617fbc1b07 100755 --- a/src/test/shell/bazel/bazel_java_test.sh +++ b/src/test/shell/bazel/bazel_java_test.sh @@ -1576,6 +1576,7 @@ EOF chmod +x "${pkg}"/run.sh bazel test //"${pkg}":bar --test_output=all --verbose_failures >& "$TEST_log" \ + --legacy_external_runfiles \ || fail "Expected success" } diff --git a/src/test/shell/bazel/external_integration_test.sh b/src/test/shell/bazel/external_integration_test.sh index 7ee18e3ecc6305..ca6c8fc8ae139e 100755 --- a/src/test/shell/bazel/external_integration_test.sh +++ b/src/test/shell/bazel/external_integration_test.sh @@ -624,7 +624,7 @@ genrule( name = "test_sh", outs = ["test.sh"], srcs = ["@toto//file"], - cmd = "echo '#!/bin/sh' > $@ && echo $(location @toto//file) >> $@", + cmd = "echo '#!/bin/sh' > $@ && echo $(rootpath @toto//file) >> $@", ) EOF @@ -682,7 +682,7 @@ genrule( name = "test_sh", outs = ["test.sh"], srcs = ["@toto//file"], - cmd = "echo '#!/bin/sh' > $@ && echo cat $(location @toto//file) >> $@", + cmd = "echo '#!/bin/sh' > $@ && echo cat $(rootpath @toto//file) >> $@", ) EOF diff --git a/src/test/shell/testenv.sh.tmpl b/src/test/shell/testenv.sh.tmpl index 80d15b6df85e54..70b69ff7353a13 100755 --- a/src/test/shell/testenv.sh.tmpl +++ b/src/test/shell/testenv.sh.tmpl @@ -267,6 +267,9 @@ build --incompatible_use_toolchain_resolution_for_java_rules # Enable Bzlmod in all shell integration tests common --enable_bzlmod +# Verify compatibility before the flip (https://github.com/bazelbuild/bazel/issues/12821) +common --nolegacy_external_runfiles + ${EXTRA_BAZELRC:-} EOF