From ed7f5e32d289cecadd14de735ff0ba39208d33d1 Mon Sep 17 00:00:00 2001 From: Ken Odegard Date: Thu, 12 Oct 2023 16:41:39 -0400 Subject: [PATCH] Add test for `conda_build.metadata.get_selectors` (#5024) --- conda_build/metadata.py | 7 +-- tests/test_metadata.py | 102 +++++++++++++++++++++++++++++++++++++++- 2 files changed, 105 insertions(+), 4 deletions(-) diff --git a/conda_build/metadata.py b/conda_build/metadata.py index 0681bcf90c..1160c1e9fe 100644 --- a/conda_build/metadata.py +++ b/conda_build/metadata.py @@ -147,15 +147,16 @@ def get_selectors(config: Config) -> dict[str, bool]: py = py[0] # go from "3.6 *_cython" -> "36" # or from "3.6.9" -> "36" - py = int("".join(py.split(" ")[0].split(".")[:2])) + py_major, py_minor, *_ = py.split(" ")[0].split(".") + py = int(f"{py_major}{py_minor}") d["build_platform"] = config.build_subdir d.update( dict( py=py, - py3k=bool(30 <= py < 40), - py2k=bool(20 <= py < 30), + py3k=bool(py_major == "3"), + py2k=bool(py_major == "2"), py26=bool(py == 26), py27=bool(py == 27), py33=bool(py == 33), diff --git a/tests/test_metadata.py b/tests/test_metadata.py index b5a696ff6f..9c2ab7bd30 100644 --- a/tests/test_metadata.py +++ b/tests/test_metadata.py @@ -4,11 +4,21 @@ import os import subprocess +import sys import pytest +from conda.base.context import context +from pytest import MonkeyPatch from conda_build import api -from conda_build.metadata import MetaData, _hash_dependencies, select_lines, yamlize +from conda_build.config import Config +from conda_build.metadata import ( + MetaData, + _hash_dependencies, + get_selectors, + select_lines, + yamlize, +) from conda_build.utils import DEFAULT_SUBDIRS from .utils import metadata_dir, thisdir @@ -323,3 +333,93 @@ def test_yamlize_versions(): ) assert yml == ["1.2.3", "1.2.3.4"] + + +OS_ARCH = ( + "aarch64", + "arm", + "arm64", + "armv6l", + "armv7l", + "emscripten", + "linux", + "linux32", + "linux64", + "osx", + "ppc64", + "ppc64le", + "riscv64", + "s390x", + "unix", + "wasi", + "wasm32", + "win", + "win32", + "win64", + "x86", + "x86_64", +) + + +@pytest.mark.parametrize( + ( + "subdir", # defined in conda.base.constants.KNOWN_SUBDIRS + "expected", # OS_ARCH keys expected to be True + ), + [ + ("emscripten-wasm32", {"unix", "emscripten", "wasm32"}), + ("wasi-wasm32", {"wasi", "wasm32"}), + ("freebsd-64", {"x86", "x86_64"}), + ("linux-32", {"unix", "linux", "linux32", "x86"}), + ("linux-64", {"unix", "linux", "linux64", "x86", "x86_64"}), + ("linux-aarch64", {"unix", "linux", "aarch64"}), + ("linux-armv6l", {"unix", "linux", "arm", "armv6l"}), + ("linux-armv7l", {"unix", "linux", "arm", "armv7l"}), + ("linux-ppc64", {"unix", "linux", "ppc64"}), + ("linux-ppc64le", {"unix", "linux", "ppc64le"}), + ("linux-riscv64", {"unix", "linux", "riscv64"}), + ("linux-s390x", {"unix", "linux", "s390x"}), + ("osx-64", {"unix", "osx", "x86", "x86_64"}), + ("osx-arm64", {"unix", "osx", "arm64"}), + ("win-32", {"win", "win32", "x86"}), + ("win-64", {"win", "win64", "x86", "x86_64"}), + ("win-arm64", {"win", "arm64"}), + ("zos-z", {}), + ], +) +@pytest.mark.parametrize("nomkl", [0, 1]) +def test_get_selectors( + monkeypatch: MonkeyPatch, + subdir: str, + expected: set[str], + nomkl: int, +): + monkeypatch.setenv("FEATURE_NOMKL", str(nomkl)) + + config = Config(host_subdir=subdir) + assert get_selectors(config) == { + # defaults + "build_platform": context.subdir, + "lua": "5", # see conda_build.variants.DEFAULT_VARIANTS["lua"] + "luajit": False, # lua[0] == 2 + "np": 122, # see conda_build.variants.DEFAULT_VARIANTS["numpy"] + "os": os, + "pl": "5.26.2", # see conda_build.variants.DEFAULT_VARIANTS["perl"] + "py": int(f"{sys.version_info.major}{sys.version_info.minor}"), + "py26": sys.version_info.major == 2 and sys.version_info.minor == 6, + "py27": sys.version_info.major == 2 and sys.version_info.minor == 7, + "py2k": sys.version_info.major == 2, + "py33": sys.version_info.major == 3 and sys.version_info.minor == 3, + "py34": sys.version_info.major == 3 and sys.version_info.minor == 4, + "py35": sys.version_info.major == 3 and sys.version_info.minor == 5, + "py36": sys.version_info.major == 3 and sys.version_info.minor == 6, + "py3k": sys.version_info.major == 3, + "nomkl": bool(nomkl), + # default OS/arch values + **{key: False for key in OS_ARCH}, + # environment variables + "environ": os.environ, + **os.environ, + # override with True values + **{key: True for key in expected}, + }