-
Notifications
You must be signed in to change notification settings - Fork 548
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor(whl_library): reimplement wheel platform parsing in starlark (…
…#1636) It seems that the CI did not catch the `macosx_10_9_universal2` wheels edge case, which this new code is handling. I moved the implementation to starlark because #1625 needs this. No changelog is needed because the feature this is fixing/refactoring an unreleased feature. --------- Co-authored-by: Richard Levasseur <richardlev@gmail.com>
- Loading branch information
Showing
8 changed files
with
173 additions
and
60 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
# Copyright 2023 The Bazel Authors. All rights reserved. | ||
# | ||
# Licensed under the Apache License, Version 2.0 (the "License"); | ||
# you may not use this file except in compliance with the License. | ||
# You may obtain a copy of the License at | ||
# | ||
# http://www.apache.org/licenses/LICENSE-2.0 | ||
# | ||
# Unless required by applicable law or agreed to in writing, software | ||
# distributed under the License is distributed on an "AS IS" BASIS, | ||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
# See the License for the specific language governing permissions and | ||
# limitations under the License. | ||
|
||
""" | ||
A starlark implementation of the wheel platform tag parsing to get the target platform. | ||
""" | ||
|
||
# The order of the dictionaries is to keep definitions with their aliases next to each | ||
# other | ||
_CPU_ALIASES = { | ||
"x86_32": "x86_32", | ||
"i386": "x86_32", | ||
"i686": "x86_32", | ||
"x86": "x86_32", | ||
"x86_64": "x86_64", | ||
"amd64": "x86_64", | ||
"aarch64": "aarch64", | ||
"arm64": "aarch64", | ||
"ppc": "ppc", | ||
"ppc64le": "ppc", | ||
"s390x": "s390x", | ||
} # buildifier: disable=unsorted-dict-items | ||
|
||
_OS_PREFIXES = { | ||
"linux": "linux", | ||
"manylinux": "linux", | ||
"musllinux": "linux", | ||
"macos": "osx", | ||
"win": "windows", | ||
} # buildifier: disable=unsorted-dict-items | ||
|
||
def whl_target_platforms(tag): | ||
"""Parse the wheel platform tag and return (os, cpu) tuples. | ||
Args: | ||
tag (str): The platform_tag part of the wheel name. See | ||
./parse_whl_name.bzl for more details. | ||
Returns: | ||
A list of structs, with attributes: | ||
* os: str, one of the _OS_PREFIXES values | ||
* cpu: str, one of the _CPU_PREFIXES values | ||
""" | ||
cpus = _cpu_from_tag(tag) | ||
|
||
for prefix, os in _OS_PREFIXES.items(): | ||
if tag.startswith(prefix): | ||
return [ | ||
struct(os = os, cpu = cpu) | ||
for cpu in cpus | ||
] | ||
|
||
fail("unknown tag os: {}".format(tag)) | ||
|
||
def _cpu_from_tag(tag): | ||
candidate = [ | ||
cpu | ||
for input, cpu in _CPU_ALIASES.items() | ||
if tag.endswith(input) | ||
] | ||
if candidate: | ||
return candidate | ||
|
||
if tag == "win32": | ||
return ["x86_32"] | ||
elif tag.endswith("universal2") and tag.startswith("macosx"): | ||
return ["x86_64", "aarch64"] | ||
else: | ||
fail("Unrecognized tag: '{}': cannot determine CPU".format(tag)) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
# Copyright 2023 The Bazel Authors. All rights reserved. | ||
# | ||
# Licensed under the Apache License, Version 2.0 (the "License"); | ||
# you may not use this file except in compliance with the License. | ||
# You may obtain a copy of the License at | ||
# | ||
# http://www.apache.org/licenses/LICENSE-2.0 | ||
# | ||
# Unless required by applicable law or agreed to in writing, software | ||
# distributed under the License is distributed on an "AS IS" BASIS, | ||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
# See the License for the specific language governing permissions and | ||
# limitations under the License. | ||
|
||
load(":whl_target_platforms_tests.bzl", "whl_target_platforms_test_suite") | ||
|
||
whl_target_platforms_test_suite(name = "whl_target_platforms_tests") |
54 changes: 54 additions & 0 deletions
54
tests/private/whl_target_platforms/whl_target_platforms_tests.bzl
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
# Copyright 2023 The Bazel Authors. All rights reserved. | ||
# | ||
# Licensed under the Apache License, Version 2.0 (the "License"); | ||
# you may not use this file except in compliance with the License. | ||
# You may obtain a copy of the License at | ||
# | ||
# http://www.apache.org/licenses/LICENSE-2.0 | ||
# | ||
# Unless required by applicable law or agreed to in writing, software | ||
# distributed under the License is distributed on an "AS IS" BASIS, | ||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
# See the License for the specific language governing permissions and | ||
# limitations under the License. | ||
|
||
"" | ||
|
||
load("@rules_testing//lib:test_suite.bzl", "test_suite") | ||
load("//python/private:whl_target_platforms.bzl", "whl_target_platforms") # buildifier: disable=bzl-visibility | ||
|
||
_tests = [] | ||
|
||
def _test_simple(env): | ||
tests = { | ||
"macosx_10_9_arm64": [ | ||
struct(os = "osx", cpu = "aarch64"), | ||
], | ||
"macosx_10_9_universal2": [ | ||
struct(os = "osx", cpu = "x86_64"), | ||
struct(os = "osx", cpu = "aarch64"), | ||
], | ||
"manylinux1_i686.manylinux_2_17_i686": [ | ||
struct(os = "linux", cpu = "x86_32"), | ||
], | ||
"musllinux_1_1_ppc64le": [ | ||
struct(os = "linux", cpu = "ppc"), | ||
], | ||
"win_amd64": [ | ||
struct(os = "windows", cpu = "x86_64"), | ||
], | ||
} | ||
|
||
for give, want in tests.items(): | ||
got = whl_target_platforms(give) | ||
env.expect.that_collection(got).contains_exactly(want) | ||
|
||
_tests.append(_test_simple) | ||
|
||
def whl_target_platforms_test_suite(name): | ||
"""Create the test suite. | ||
Args: | ||
name: the name of the test suite | ||
""" | ||
test_suite(name = name, basic_tests = _tests) |