From d30c90c7dc91f5fe9f35adb3d11ab792232b8ca5 Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Thu, 14 Mar 2024 12:08:07 +0100 Subject: [PATCH 1/9] Add CI jobs for conda/conda-build pre-release test Signed-off-by: Marcel Bargull --- .github/workflows/main.yml | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 742f2818..d528f33a 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -17,12 +17,17 @@ jobs: matrix: os: [ubuntu-latest, macos-latest, windows-latest] python-version: [3.7] + conda-channel: ['conda-forge', 'conda-canary/label/dev'] steps: - uses: actions/checkout@v2 - name: install mamba uses: mamba-org/setup-micromamba@v1 with: environment-file: tests/env.yml + create-args: >- + --channel-priority=flexible + ${{ matrix.conda-channel }}::conda + ${{ matrix.conda-channel }}::conda-build - name: Install boa shell: bash -l {0} run: | From 9de8323c611e1c71dc9c366f1175362583950c44 Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Thu, 14 Mar 2024 12:10:20 +0100 Subject: [PATCH 2/9] Run CI for older Python versions, too Signed-off-by: Marcel Bargull --- .github/workflows/main.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index d528f33a..aec72c16 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -16,7 +16,7 @@ jobs: fail-fast: false matrix: os: [ubuntu-latest, macos-latest, windows-latest] - python-version: [3.7] + python-version: ['3.8', '*'] # Lowest and unbound version to test for. conda-channel: ['conda-forge', 'conda-canary/label/dev'] steps: - uses: actions/checkout@v2 @@ -26,6 +26,7 @@ jobs: environment-file: tests/env.yml create-args: >- --channel-priority=flexible + python=${{ matrix.python-version }} ${{ matrix.conda-channel }}::conda ${{ matrix.conda-channel }}::conda-build - name: Install boa From 776609b38ccf5e8fd1cd39ae38d011136cc367fc Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Thu, 14 Mar 2024 14:00:24 +0100 Subject: [PATCH 3/9] Use non-conda-vendored boltons.setutils.IndexedSet conda._vendor.boltons has been marked for deprecation in conda=23.3 and will be removed in conda=23.4. refs: - https://github.com/conda/conda/pull/12453/files Signed-off-by: Marcel Bargull --- boa/core/solver.py | 3 ++- setup.py | 1 + tests/env.yml | 1 + 3 files changed, 4 insertions(+), 1 deletion(-) diff --git a/boa/core/solver.py b/boa/core/solver.py index 7779c7a9..a8423d13 100644 --- a/boa/core/solver.py +++ b/boa/core/solver.py @@ -4,12 +4,13 @@ import os import tempfile +from boltons.setutils import IndexedSet + from conda.base.constants import ChannelPriority from conda.core.solve import diff_for_unlink_link_precs from conda.common.serialize import json_dump from conda.models.prefix_graph import PrefixGraph from conda.core.prefix_data import PrefixData -from conda._vendor.boltons.setutils import IndexedSet from conda.models.match_spec import MatchSpec from conda.common.url import remove_auth, split_anaconda_token from conda.core.index import _supplement_index_with_system diff --git a/setup.py b/setup.py index 28c6dd47..7cf1d867 100644 --- a/setup.py +++ b/setup.py @@ -20,6 +20,7 @@ "prompt-toolkit", "joblib", "beautifulsoup4", + "boltons", ] setup( diff --git a/tests/env.yml b/tests/env.yml index cb9dfb5c..af0c0dbc 100644 --- a/tests/env.yml +++ b/tests/env.yml @@ -4,6 +4,7 @@ channels: dependencies: - python>=3.7 - pip + - boltons - conda - libmambapy >=1.5,<1.6 - pytest From 010849136a104e3d3b1502981258070862842b14 Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Sat, 16 Mar 2024 08:31:53 +0100 Subject: [PATCH 4/9] Raise minimum conda-build version to 3.25 Signed-off-by: Marcel Bargull --- .github/workflows/main.yml | 12 ++++++++++-- boa/core/utils.py | 12 +----------- tests/env.yml | 2 +- 3 files changed, 12 insertions(+), 14 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index aec72c16..5b1a85cc 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -16,8 +16,16 @@ jobs: fail-fast: false matrix: os: [ubuntu-latest, macos-latest, windows-latest] - python-version: ['3.8', '*'] # Lowest and unbound version to test for. conda-channel: ['conda-forge', 'conda-canary/label/dev'] + include: + # Lowest versions to test for. + - conda-channel: 'conda-forge' + conda-build-version: '3.25' + python-version: '3.8' + # Unbound/dev versions to test for. + - conda-channel: 'conda-canary/label/dev' + conda-build-version: '*' + python-version: '*' steps: - uses: actions/checkout@v2 - name: install mamba @@ -28,7 +36,7 @@ jobs: --channel-priority=flexible python=${{ matrix.python-version }} ${{ matrix.conda-channel }}::conda - ${{ matrix.conda-channel }}::conda-build + ${{ matrix.conda-channel }}::conda-build=${{ matrix.conda-build-version }} - name: Install boa shell: bash -l {0} run: | diff --git a/boa/core/utils.py b/boa/core/utils.py index 927590b7..aff6c7e2 100644 --- a/boa/core/utils.py +++ b/boa/core/utils.py @@ -14,7 +14,6 @@ from conda_build import utils from conda_build.config import get_or_merge_config from conda_build.variants import find_config_files, parse_config_file, combine_specs -from conda_build import __version__ as cb_version from conda.base.constants import ChannelPriority from conda.gateways.connection.session import CondaHttpAuth from conda.core.index import check_allowlist @@ -33,11 +32,6 @@ console = boa_config.console -if "+" in cb_version: - cb_version = cb_version[: cb_version.index("+")] -cb_split_version = tuple(int(x) for x in cb_version.split(".")) - - if "bsd" in sys.platform: shell_path = "/bin/sh" elif utils.on_win: @@ -58,11 +52,7 @@ def get_config( variant = {} config = get_or_merge_config(config, variant) - if cb_split_version >= (3, 20, 5): - config_files = find_config_files(folder, config) - else: - config_files = find_config_files(folder) - + config_files = find_config_files(folder, config) all_files = [os.path.abspath(p) for p in config_files + additional_files] # reverse files an uniquify diff --git a/tests/env.yml b/tests/env.yml index af0c0dbc..f869910b 100644 --- a/tests/env.yml +++ b/tests/env.yml @@ -8,7 +8,7 @@ dependencies: - conda - libmambapy >=1.5,<1.6 - pytest - - "conda-build>=3.20" + - conda-build >=3.25 - conda-index - ruamel - ruamel.yaml From a5220206d73c0a373a693ce6617f9a5cf72d5f8e Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Sat, 16 Mar 2024 08:38:43 +0100 Subject: [PATCH 5/9] Support conda-build>=24.1 actions/Dist-less package resolution Signed-off-by: Marcel Bargull --- boa/cli/mambabuild.py | 55 +++++++++++++++++++++++++++++++++++++++---- boa/core/solver.py | 15 +++++------- 2 files changed, 56 insertions(+), 14 deletions(-) diff --git a/boa/cli/mambabuild.py b/boa/cli/mambabuild.py index 65aaa4e5..00ca3a63 100644 --- a/boa/cli/mambabuild.py +++ b/boa/cli/mambabuild.py @@ -105,7 +105,7 @@ def _get_solver(channel_urls, subdir, output_folder): return solver -def mamba_get_install_actions( +def mamba_get_package_records( prefix, specs, env, @@ -138,7 +138,8 @@ def mamba_get_install_actions( _specs = [s.conda_build_form() for s in _specs] try: - solution = solver.solve_for_action(_specs, prefix) + # We only create fresh environments in builds and can ignore unlink precs. + _, link_precs = solver.solve_for_unlink_link_precs(_specs, prefix) except RuntimeError as e: conflict_packages = parse_problems(str(e)) @@ -149,10 +150,54 @@ def mamba_get_install_actions( err.subdir = subdir raise err - return solution - + return link_precs + + +if hasattr(conda_build.environ, "get_package_records"): + # conda-build>=24.1 avoids the legacy "actions"/"Dist"-based installs. + conda_build.environ.get_package_records = mamba_get_package_records +else: + # conda-build<24.1 needs get_package_records' result wrapped in "actions" dict. + def mamba_get_install_actions( + prefix, + specs, + env, + retries=0, + subdir=None, + verbose=True, + debug=False, + locking=True, + bldpkgs_dirs=None, + timeout=900, + disable_pip=False, + max_env_retry=3, + output_folder=None, + channel_urls=None, + ): + from conda.models.dist import Dist + from conda.plan import get_blank_actions + + link_precs = mamba_get_package_records( + prefix=prefix, + specs=specs, + env=env, + retries=retries, + subdir=subdir, + verbose=verbose, + debug=debug, + locking=locking, + bldpkgs_dirs=bldpkgs_dirs, + timeout=timeout, + disable_pip=disable_pip, + max_env_retry=max_env_retry, + output_folder=output_folder, + channel_urls=channel_urls, + ) + actions = get_blank_actions(prefix) + actions["LINK"].extend(Dist(prec) for prec in link_precs) + return actions -conda_build.environ.get_install_actions = mamba_get_install_actions + conda_build.environ.get_install_actions = mamba_get_install_actions def prepare(**kwargs): diff --git a/boa/core/solver.py b/boa/core/solver.py index a8423d13..ecec23c4 100644 --- a/boa/core/solver.py +++ b/boa/core/solver.py @@ -15,8 +15,6 @@ from conda.common.url import remove_auth, split_anaconda_token from conda.core.index import _supplement_index_with_system from conda.base.context import context -from conda.plan import get_blank_actions -from conda.models.dist import Dist from conda_build.conda_interface import pkgs_dirs from conda.core.package_cache_data import PackageCacheData @@ -60,7 +58,9 @@ def get_url_from_channel(c): return split_anaconda_token(remove_auth(c))[0] -def to_action(specs_to_add, specs_to_remove, prefix, to_link, to_unlink, index): +def to_unlink_link_precs( + specs_to_add, specs_to_remove, prefix, to_link, to_unlink, index +): to_link_records = [] prefix_data = PrefixData(prefix) @@ -86,10 +86,7 @@ def to_action(specs_to_add, specs_to_remove, prefix, to_link, to_unlink, index): specs_to_add=specs_to_add, ) - actions = get_blank_actions(prefix) - actions["UNLINK"].extend(Dist(prec) for prec in unlink_precs) - actions["LINK"].extend(Dist(prec) for prec in link_precs) - return actions + return unlink_precs, link_precs def get_virtual_packages(): @@ -239,7 +236,7 @@ def solve(self, specs, pkg_cache_path=None): package_cache = libmambapy.MultiPackageCache(pkg_cache_path) return libmambapy.Transaction(api_solver, package_cache) - def solve_for_action(self, specs, prefix): + def solve_for_unlink_link_precs(self, specs, prefix): t = self.solve(specs) if not boa_config.quiet and not boa_config.is_mambabuild: t.print() @@ -248,7 +245,7 @@ def solve_for_action(self, specs, prefix): specs_to_add = [MatchSpec(m) for m in mmb_specs[0]] specs_to_remove = [MatchSpec(m) for m in mmb_specs[1]] - return to_action( + return to_unlink_link_precs( specs_to_add, specs_to_remove, prefix, From 36a92f838604481545311414b0da1078d3bd88ac Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Sat, 16 Mar 2024 09:23:54 +0100 Subject: [PATCH 6/9] Stop using conda_build.conda_interface refs: - https://github.com/conda/conda-build/pull/5222 - https://github.com/conda/conda-build/blob/24.1.2/conda_build/conda_interface.py#L15 - https://github.com/conda/conda-build/blob/24.1.2/conda_build/conda_interface.py#L95 - https://github.com/conda/conda-build/blob/24.1.2/conda_build/conda_interface.py#L104 - https://github.com/conda/conda-build/blob/24.1.2/conda_build/conda_interface.py#L114 - https://github.com/conda/conda/blob/24.1.2/conda/utils.py#L235 Signed-off-by: Marcel Bargull --- boa/cli/boa.py | 4 +++- boa/core/build.py | 8 ++++++-- boa/core/monkey_patch_emscripten.py | 3 ++- boa/core/solver.py | 8 ++++++-- boa/core/test.py | 10 +++------- boa/core/utils.py | 3 +++ 6 files changed, 23 insertions(+), 13 deletions(-) diff --git a/boa/cli/boa.py b/boa/cli/boa.py index 1a26ec8e..89a68fb5 100644 --- a/boa/cli/boa.py +++ b/boa/cli/boa.py @@ -4,6 +4,8 @@ import sys import argparse +from conda.base.context import context + from boa.core import monkey_patch_emscripten if any("emscripten" in arg for arg in sys.argv): @@ -14,7 +16,7 @@ from boa._version import __version__ from boa.core.utils import init_api_context -from conda_build.conda_interface import cc_conda_build +cc_conda_build = context.conda_build if hasattr(context, "conda_build") else {} banner = r""" _ diff --git a/boa/core/build.py b/boa/core/build.py index 33c43d81..2f6a2e7c 100644 --- a/boa/core/build.py +++ b/boa/core/build.py @@ -25,7 +25,7 @@ import conda_package_handling.api # used to get version -from conda_build.conda_interface import env_path_backup_var_exists, TemporaryDirectory +from conda.gateways.disk.create import TemporaryDirectory from conda_build.utils import tmp_chdir from conda_build import source, utils @@ -44,7 +44,11 @@ if sys.platform == "win32": import boa.core.windows as windows -from boa.core.utils import shell_path, get_sys_vars_stubs +from boa.core.utils import ( + env_path_backup_var_exists, + get_sys_vars_stubs, + shell_path, +) from boa.core.recipe_handling import copy_recipe from boa.core.config import boa_config from boa.tui.exceptions import BoaRunBuildException diff --git a/boa/core/monkey_patch_emscripten.py b/boa/core/monkey_patch_emscripten.py index 4d7e97e8..0b58967e 100644 --- a/boa/core/monkey_patch_emscripten.py +++ b/boa/core/monkey_patch_emscripten.py @@ -32,8 +32,9 @@ def patch(): # CONDA-BUILD MONKEY-PATCH ############################################### + from conda.base.context import non_x86_machines as non_x86_linux_machines + from conda_build import utils, variants, environ - from conda_build.conda_interface import non_x86_linux_machines from conda_build import metadata from conda_build.features import feature_list diff --git a/boa/core/solver.py b/boa/core/solver.py index ecec23c4..b23027a1 100644 --- a/boa/core/solver.py +++ b/boa/core/solver.py @@ -15,12 +15,16 @@ from conda.common.url import remove_auth, split_anaconda_token from conda.core.index import _supplement_index_with_system from conda.base.context import context -from conda_build.conda_interface import pkgs_dirs from conda.core.package_cache_data import PackageCacheData import libmambapy -from boa.core.utils import get_index, load_channels, to_package_record_from_subjson +from boa.core.utils import ( + get_index, + load_channels, + pkgs_dirs, + to_package_record_from_subjson, +) from boa.core.config import boa_config console = boa_config.console diff --git a/boa/core/test.py b/boa/core/test.py index 525a13a4..b7039dfd 100644 --- a/boa/core/test.py +++ b/boa/core/test.py @@ -16,6 +16,7 @@ from libmambapy import PrefixData from libmambapy import Context as MambaContext +from conda.common.url import path_to_url from conda.gateways.disk.create import mkdir_p from conda_build.utils import CONDA_PACKAGE_EXTENSIONS, get_site_packages @@ -25,11 +26,6 @@ get_all_replacements, log_stats, ) -from conda_build.conda_interface import ( - url_path, - env_path_backup_var_exists, - pkgs_dirs, -) from conda_build.create_test import create_all_test_files from conda_build.post import post_build from conda_build.render import bldpkg_path, try_download @@ -40,7 +36,7 @@ from conda_build import utils from conda_build.environ import clean_pkg_cache -from boa.core.utils import shell_path +from boa.core.utils import env_path_backup_var_exists, pkgs_dirs, shell_path from boa.core.recipe_output import Output from boa.core.metadata import MetaData from boa.core import environ @@ -359,7 +355,7 @@ def _construct_metadata_for_test_from_package(package, config): metadata.config.used_vars = list(hash_input.keys()) urls = list(utils.ensure_list(metadata.config.channel_urls)) - local_path = url_path(local_channel) + local_path = path_to_url(local_channel) # replace local with the appropriate real channel. Order is maintained. urls = [url if url != "local" else local_path for url in urls] if local_path not in urls: diff --git a/boa/core/utils.py b/boa/core/utils.py index aff6c7e2..89516fd4 100644 --- a/boa/core/utils.py +++ b/boa/core/utils.py @@ -32,6 +32,9 @@ console = boa_config.console +env_path_backup_var_exists = os.environ.get("CONDA_PATH_BACKUP", None) +pkgs_dirs = list(context.pkgs_dirs) + if "bsd" in sys.platform: shell_path = "/bin/sh" elif utils.on_win: From 69fe724f76ee8ad62b8dfdaca36837b9ddb0b579 Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Sat, 16 Mar 2024 09:29:08 +0100 Subject: [PATCH 7/9] Port conda-build=24.1.2 clean_pkg_cache change ref: - https://github.com/conda/conda-build/pull/5184 Signed-off-by: Marcel Bargull --- boa/core/test.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/boa/core/test.py b/boa/core/test.py index b7039dfd..7fed5848 100644 --- a/boa/core/test.py +++ b/boa/core/test.py @@ -710,7 +710,10 @@ def run_test( not hasattr(recipedir_or_package_or_metadata, "config") and os.path.isfile(recipedir_or_package_or_metadata) and recipedir_or_package_or_metadata.endswith(CONDA_PACKAGE_EXTENSIONS) - and os.path.dirname(recipedir_or_package_or_metadata) in pkgs_dirs[0] + and any( + os.path.dirname(recipedir_or_package_or_metadata) in pkgs_dir + for pkgs_dir in pkgs_dirs + ) ) if not in_pkg_cache: clean_pkg_cache(metadata.dist(), metadata.config) From 1aa8d1f5a851685843cbdc565337b697bbb8bf9f Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Sat, 16 Mar 2024 09:51:05 +0100 Subject: [PATCH 8/9] Use .meta in MetaData.get_value for correct types Fixes https://github.com/mamba-org/boa/issues/388 Signed-off-by: Marcel Bargull --- boa/core/metadata.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/boa/core/metadata.py b/boa/core/metadata.py index ecf92145..c82aaf86 100644 --- a/boa/core/metadata.py +++ b/boa/core/metadata.py @@ -149,7 +149,7 @@ def get_value(self, in_key: str, default: Any = None, autotype=True) -> Any: if autotype and default is None and FIELDS.get(section, {}).get(key): default = FIELDS[section][key]() - section = self.output.sections.get(section, {}) + section = self.meta.get(section, {}) if isinstance(section, list): return section[int(num)].get(key, default) else: From e26063868367d93953d032a32cf6552363ff02b4 Mon Sep 17 00:00:00 2001 From: Marcel Bargull Date: Sat, 16 Mar 2024 15:42:57 +0100 Subject: [PATCH 9/9] Update to actions/checkout@v4 to avoid CI warnings Signed-off-by: Marcel Bargull --- .github/workflows/lint.yml | 2 +- .github/workflows/main.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 04859603..e20845b0 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -12,7 +12,7 @@ jobs: build: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v1 + - uses: actions/checkout@v4 - name: install mamba uses: mamba-org/setup-micromamba@v1 with: diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 5b1a85cc..e3cd5b83 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -27,7 +27,7 @@ jobs: conda-build-version: '*' python-version: '*' steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 - name: install mamba uses: mamba-org/setup-micromamba@v1 with: