summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/spack/spack/database.py3
-rw-r--r--lib/spack/spack/test/database.py20
-rw-r--r--var/spack/repos/builtin.mock/packages/hdf5/package.py15
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')