From 3e84019ae4b4f936caf192e14805e2d68882325b Mon Sep 17 00:00:00 2001 From: Keith Smiley Date: Thu, 11 Feb 2021 10:08:45 -0800 Subject: [PATCH] Add --host_macos_minimum_os flag This flag makes sure we set the minimum macOS version when compiling host tools. Otherwise you can end up not sharing caches across different OS versions. Fixes https://github.com/bazelbuild/bazel/issues/12988 --- .../rules/apple/AppleCommandLineOptions.java | 12 ++++++ .../rules/objc/ObjcBuildVariablesTest.java | 38 +++++++++++++++++++ 2 files changed, 50 insertions(+) diff --git a/src/main/java/com/google/devtools/build/lib/rules/apple/AppleCommandLineOptions.java b/src/main/java/com/google/devtools/build/lib/rules/apple/AppleCommandLineOptions.java index 2d7798e6563d96..2085133756ff56 100644 --- a/src/main/java/com/google/devtools/build/lib/rules/apple/AppleCommandLineOptions.java +++ b/src/main/java/com/google/devtools/build/lib/rules/apple/AppleCommandLineOptions.java @@ -162,6 +162,17 @@ public class AppleCommandLineOptions extends FragmentOptions { + "If unspecified, uses 'macos_sdk_version'.") public DottedVersion.Option macosMinimumOs; + @Option( + name = "host_macos_minimum_os", + defaultValue = "null", + converter = DottedVersionConverter.class, + documentationCategory = OptionDocumentationCategory.OUTPUT_PARAMETERS, + effectTags = {OptionEffectTag.LOSES_INCREMENTAL_STATE}, + help = + "Minimum compatible macOS version for host targets. " + + "If unspecified, uses 'macos_sdk_version'.") + public DottedVersion.Option hostMacosMinimumOs; + @Option( name = "experimental_prefer_mutual_xcode", defaultValue = "true", @@ -460,6 +471,7 @@ public FragmentOptions getHost() { host.watchOsSdkVersion = watchOsSdkVersion; host.tvOsSdkVersion = tvOsSdkVersion; host.macOsSdkVersion = macOsSdkVersion; + host.macosMinimumOs = hostMacosMinimumOs; // The host apple platform type will always be MACOS, as no other apple platform type can // currently execute build actions. If that were the case, a host_apple_platform_type flag might // be needed. diff --git a/src/test/java/com/google/devtools/build/lib/rules/objc/ObjcBuildVariablesTest.java b/src/test/java/com/google/devtools/build/lib/rules/objc/ObjcBuildVariablesTest.java index 00e48a133de6d4..fc3a6768c94c18 100644 --- a/src/test/java/com/google/devtools/build/lib/rules/objc/ObjcBuildVariablesTest.java +++ b/src/test/java/com/google/devtools/build/lib/rules/objc/ObjcBuildVariablesTest.java @@ -196,6 +196,44 @@ public void testAppleBuildVariablesMacos() throws Exception { .contains(dummyMinimumOsValue); } + @Test + public void testAppleBuildVariablesMacosHost() throws Exception { + MockObjcSupport.setup(mockToolsConfig); + String dummyMinimumOsValue = "13.579"; + useConfiguration( + "--crosstool_top=//tools/osx/crosstool", + "--cpu=darwin_x86_64", + "--macos_minimum_os=10.11", + "--host_macos_minimum_os=" + dummyMinimumOsValue); + scratch.file( + "x/BUILD", + "apple_binary(", + " name = 'bin',", + " deps = [':a'],", + " platform_type = 'macos',", + ")", + "cc_library(", + " name = 'a',", + " srcs = ['a.cc'],", + ")"); + scratch.file("x/a.cc"); + + ConfiguredTarget target = getHostConfiguredTarget("//x:bin"); + Artifact lipoBin = + getBinArtifact( + Label.parseAbsolute("//x:bin", ImmutableMap.of()).getName() + "_lipobin", target); + Action lipoAction = getGeneratingAction(lipoBin); + Artifact bin = ActionsTestUtil.getFirstArtifactEndingWith(lipoAction.getInputs(), "_bin"); + CommandAction appleBinLinkAction = (CommandAction) getGeneratingAction(bin); + Artifact archive = + ActionsTestUtil.getFirstArtifactEndingWith(appleBinLinkAction.getInputs(), "liba.a"); + CppLinkAction ccArchiveAction = (CppLinkAction) getGeneratingAction(archive); + + CcToolchainVariables variables = ccArchiveAction.getLinkCommandLine().getBuildVariables(); + assertThat(getVariableValue(getRuleContext(), variables, AppleCcToolchain.VERSION_MIN_KEY)) + .contains(dummyMinimumOsValue); + } + @Test public void testDefaultBuildVariablesIos() throws Exception { MockObjcSupport.setup(mockToolsConfig);