Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add support to run build for recipes with linux-aarch64 additional-platforms #923

Merged
merged 5 commits into from
Oct 14, 2023
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions .github/workflows/GithubActionTests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ jobs:

steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0

- name: set path
run: echo "/opt/mambaforge/bin" >> $GITHUB_PATH
Expand Down Expand Up @@ -52,6 +54,8 @@ jobs:
runs-on: macos-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0

- name: set path
run: echo "/opt/mambaforge/bin" >> $GITHUB_PATH
Expand Down
26 changes: 26 additions & 0 deletions bioconda_utils/build.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
from . import upload
from . import lint
from . import graph
from . import recipe as _recipe

logger = logging.getLogger(__name__)

Expand Down Expand Up @@ -259,6 +260,27 @@ def get_subdags(dag, n_workers, worker_offset):
return subdags


def check_native_platform_skippable(recipe_folder: str, recipe: str):
Yikun marked this conversation as resolved.
Show resolved Hide resolved
"""
Given a recipe, check this recipe should skip in current platform or not.

Arguments:
recipe_folder: Directory containing possibly many, and possibly nested, recipes.
recipe: recipe name

Returns:
Return True if current native platform are not included in recipe's additional platforms (no need to build).
"""
recipe_obj = _recipe.Recipe.from_file(recipe_folder, recipe)
native_platform = utils.RepoData().native_platform()
# On linux-aarch64 env, only build recipe with linux-aarch64 extra_additional_platforms
if native_platform == "linux-aarch64":
if "linux-aarch64" not in recipe_obj.extra_additional_platforms:
logger.info("BUILD SKIP: skipping %s for %s platform", recipe, native_platform)
johanneskoester marked this conversation as resolved.
Show resolved Hide resolved
return True
return False


def build_recipes(recipe_folder: str, config_path: str, recipes: List[str],
mulled_test: bool = True, testonly: bool = False,
force: bool = False,
Expand Down Expand Up @@ -356,6 +378,10 @@ def build_recipes(recipe_folder: str, config_path: str, recipes: List[str],
failed_uploads = []

for recipe, name in recipes:
# If not force, skip recipes that are not for this platform
if not force and check_native_platform_skippable(recipe_folder, recipe):
continue

if name in skip_dependent:
logger.info('BUILD SKIP: skipping %s because it depends on %s '
'which had a failed build.',
Expand Down
7 changes: 7 additions & 0 deletions bioconda_utils/recipe.py
Original file line number Diff line number Diff line change
Expand Up @@ -406,6 +406,13 @@ def maintainers(self):
return utils.ensure_list(self.meta['extra']['recipe-maintainers'])
return []

@property
def extra_additional_platforms(self) -> list:
"""The extra additional-platforms list"""
if 'extra' in self.meta and 'additional-platforms' in self.meta['extra']:
return list(self.meta["extra"]["additional-platforms"])
return []

@property
def name(self) -> str:
"""The name of the toplevel package built by this recipe"""
Expand Down
12 changes: 12 additions & 0 deletions test/test_recipe.py
Original file line number Diff line number Diff line change
Expand Up @@ -258,6 +258,18 @@ def test_recipe_package_names(recipe):
assert recipe.package_names == expected


@with_recipes
def test_recipe_extra_additional_platforms(recipe):
assert recipe.extra_additional_platforms == []
recipe.meta_yaml += [
'extra:',
' additional-platforms:',
' - linux-aarch64'
]
recipe.render()
assert recipe.extra_additional_platforms == ["linux-aarch64"]


@with_recipes
def test_get_deps_dict(recipe):
recipe.meta_yaml.extend([
Expand Down
37 changes: 37 additions & 0 deletions test/test_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import tempfile
import requests
import uuid
import unittest.mock
import contextlib
import tarfile
import logging
Expand Down Expand Up @@ -889,6 +890,42 @@ def test_load_meta_skipping():
assert utils.load_all_meta(recipe) == []


@unittest.mock.patch('bioconda_utils.utils.RepoData.native_platform')
def test_native_platform_skipping(func_mock):
expections = [
# Don't skip linux-x86 for any recipes
["one", "linux", False],
["two", "linux", False],
# Skip recipe without linux aarch64 enable on linux-aarch64 platform
["one", "linux-aarch64", True],
# Don't skip recipe with linux aarch64 enable on linux-aarch64 platform
["two", "linux-aarch64", False],
]
r = Recipes(
"""
one:
meta.yaml: |
package:
name: one
version: "0.1"
two:
meta.yaml: |
package:
name: one
version: "0.1"
extra:
additional-platforms:
- linux-aarch64
""", from_string=True)
r.write_recipes()
# Make sure RepoData singleton init
utils.RepoData.register_config(config_fixture)
for recipe_name, native_platform, result in expections:
recipe_folder = os.path.dirname(r.recipe_dirs[recipe_name])
func_mock.return_value = native_platform
assert build.check_native_platform_skippable(recipe_folder, r.recipe_dirs[recipe_name]) == result


def test_variants():
"""
Multiple variants should return multiple metadata
Expand Down