diff options
-rw-r--r-- | lib/spack/spack/database.py | 3 | ||||
-rw-r--r-- | lib/spack/spack/test/database.py | 20 | ||||
-rw-r--r-- | var/spack/repos/builtin.mock/packages/hdf5/package.py | 15 |
3 files changed, 37 insertions, 1 deletions
diff --git a/lib/spack/spack/database.py b/lib/spack/spack/database.py index c06d1ae546..65b85e026b 100644 --- a/lib/spack/spack/database.py +++ b/lib/spack/spack/database.py @@ -1254,7 +1254,8 @@ class Database(object): if not (start_date < inst_date < end_date): continue - if query_spec is any or rec.spec.satisfies(query_spec): + if (query_spec is any or + rec.spec.satisfies(query_spec, strict=True)): results.append(rec.spec) return results diff --git a/lib/spack/spack/test/database.py b/lib/spack/spack/test/database.py index a2b9677ec6..1af125a723 100644 --- a/lib/spack/spack/test/database.py +++ b/lib/spack/spack/test/database.py @@ -729,3 +729,23 @@ def test_query_unused_specs(mutable_database): unused = spack.store.db.unused_specs assert len(unused) == 1 assert unused[0].name == 'cmake' + + +@pytest.mark.regression('10019') +def test_query_spec_with_conditional_dependency(mutable_database): + # The issue is triggered by having dependencies that are + # conditional on a Boolean variant + s = spack.spec.Spec('hdf5~mpi') + s.concretize() + s.package.do_install(fake=True, explicit=True) + + results = spack.store.db.query_local('hdf5 ^mpich') + assert not results + + +@pytest.mark.regression('10019') +def test_query_spec_with_non_conditional_virtual_dependency(database): + # Ensure the same issue doesn't come up for virtual + # dependency that are not conditional on variants + results = spack.store.db.query_local('mpileaks ^mpich') + assert len(results) == 1 diff --git a/var/spack/repos/builtin.mock/packages/hdf5/package.py b/var/spack/repos/builtin.mock/packages/hdf5/package.py new file mode 100644 index 0000000000..495dbcbaa8 --- /dev/null +++ b/var/spack/repos/builtin.mock/packages/hdf5/package.py @@ -0,0 +1,15 @@ +# Copyright 2013-2020 Lawrence Livermore National Security, LLC and other +# Spack Project Developers. See the top-level COPYRIGHT file for details. +# +# SPDX-License-Identifier: (Apache-2.0 OR MIT) + + +class Hdf5(Package): + homepage = "http://www.llnl.gov" + url = "http://www.llnl.gov/hdf5-1.0.tar.gz" + + version(2.3, 'foobarbaz') + + variant('mpi', default=True, description='Debug variant') + + depends_on('mpi', when='mpi') |