diff options
author | Jordan Galby <67924449+Jordan474@users.noreply.github.com> | 2024-09-09 10:42:04 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-09 10:42:04 +0200 |
commit | 2502a3c2b647e71b1643eab0e11b4b8eeb1b1122 (patch) | |
tree | 545d763aba03a4ec13979493f05fb6b074173442 | |
parent | 9bdc97043e021245611d0e62a2c3609c1b388dcb (diff) | |
download | spack-2502a3c2b647e71b1643eab0e11b4b8eeb1b1122.tar.gz spack-2502a3c2b647e71b1643eab0e11b4b8eeb1b1122.tar.bz2 spack-2502a3c2b647e71b1643eab0e11b4b8eeb1b1122.tar.xz spack-2502a3c2b647e71b1643eab0e11b4b8eeb1b1122.zip |
Fix regression in spec format string for indiviual variants (#46206)
Fix a regression in {variants.X} and {variants.X.value} spec format strings.
-rw-r--r-- | lib/spack/spack/spec.py | 7 | ||||
-rw-r--r-- | lib/spack/spack/test/spec_semantics.py | 14 |
2 files changed, 19 insertions, 2 deletions
diff --git a/lib/spack/spack/spec.py b/lib/spack/spack/spec.py index 0c869febb1..e420eaada9 100644 --- a/lib/spack/spack/spec.py +++ b/lib/spack/spack/spec.py @@ -3914,9 +3914,12 @@ class Spec: if part.startswith("_"): raise SpecFormatStringError("Attempted to format private attribute") else: - if part == "variants" and isinstance(current, VariantMap): + if isinstance(current, VariantMap): # subscript instead of getattr for variant names - current = current[part] + try: + current = current[part] + except KeyError: + raise SpecFormatStringError(f"Variant '{part}' does not exist") else: # aliases if part == "arch": diff --git a/lib/spack/spack/test/spec_semantics.py b/lib/spack/spack/test/spec_semantics.py index cd0f930acd..0f3b58e486 100644 --- a/lib/spack/spack/test/spec_semantics.py +++ b/lib/spack/spack/test/spec_semantics.py @@ -741,6 +741,13 @@ class TestSpecSemantics: ("{/hash}", "/", lambda s: "/" + s.dag_hash()), ] + variants_segments = [ + ("{variants.debug}", spec, "debug"), + ("{variants.foo}", spec, "foo"), + ("{^pkg-a.variants.bvv}", spec["pkg-a"], "bvv"), + ("{^pkg-a.variants.foo}", spec["pkg-a"], "foo"), + ] + other_segments = [ ("{spack_root}", spack.paths.spack_root), ("{spack_install}", spack.store.STORE.layout.root), @@ -768,6 +775,12 @@ class TestSpecSemantics: callpath, fmt_str = depify("callpath", named_str, sigil) assert spec.format(fmt_str) == getter(callpath) + for named_str, test_spec, variant_name in variants_segments: + assert test_spec.format(named_str) == str(test_spec.variants[variant_name]) + assert test_spec.format(named_str[:-1] + ".value}") == str( + test_spec.variants[variant_name].value + ) + for named_str, expected in other_segments: actual = spec.format(named_str) assert expected == actual @@ -827,6 +840,7 @@ class TestSpecSemantics: r"{dag_hash}", r"{foo}", r"{+variants.debug}", + r"{variants.this_variant_does_not_exist}", ], ) def test_spec_formatting_bad_formats(self, default_mock_concretization, fmt_str): |