test/package_sanity.py: ported to pytest (#3474)
This commit is contained in:
parent
ee7753a597
commit
0c44dd28bb
@ -22,49 +22,48 @@
|
|||||||
# License along with this program; if not, write to the Free Software
|
# License along with this program; if not, write to the Free Software
|
||||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
##############################################################################
|
##############################################################################
|
||||||
"""\
|
"""This test does sanity checks on Spack's builtin package database."""
|
||||||
This test does sanity checks on Spack's builtin package database.
|
|
||||||
"""
|
|
||||||
import unittest
|
|
||||||
import re
|
import re
|
||||||
|
|
||||||
import spack
|
import spack
|
||||||
from spack.repository import RepoPath
|
from spack.repository import RepoPath
|
||||||
|
|
||||||
|
|
||||||
class PackageSanityTest(unittest.TestCase):
|
def check_db():
|
||||||
|
|
||||||
def check_db(self):
|
|
||||||
"""Get all packages in a DB to make sure they work."""
|
"""Get all packages in a DB to make sure they work."""
|
||||||
for name in spack.repo.all_package_names():
|
for name in spack.repo.all_package_names():
|
||||||
spack.repo.get(name)
|
spack.repo.get(name)
|
||||||
|
|
||||||
def test_get_all_packages(self):
|
|
||||||
"""Get all packages once and make sure that works."""
|
|
||||||
self.check_db()
|
|
||||||
|
|
||||||
def test_get_all_mock_packages(self):
|
def test_get_all_packages():
|
||||||
|
"""Get all packages once and make sure that works."""
|
||||||
|
check_db()
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_all_mock_packages():
|
||||||
"""Get the mock packages once each too."""
|
"""Get the mock packages once each too."""
|
||||||
db = RepoPath(spack.mock_packages_path)
|
db = RepoPath(spack.mock_packages_path)
|
||||||
spack.repo.swap(db)
|
spack.repo.swap(db)
|
||||||
self.check_db()
|
check_db()
|
||||||
spack.repo.swap(db)
|
spack.repo.swap(db)
|
||||||
|
|
||||||
def test_url_versions(self):
|
|
||||||
|
def test_url_versions():
|
||||||
"""Check URLs for regular packages, if they are explicitly defined."""
|
"""Check URLs for regular packages, if they are explicitly defined."""
|
||||||
for pkg in spack.repo.all_packages():
|
for pkg in spack.repo.all_packages():
|
||||||
for v, vattrs in pkg.versions.items():
|
for v, vattrs in pkg.versions.items():
|
||||||
if 'url' in vattrs:
|
if 'url' in vattrs:
|
||||||
# If there is a url for the version check it.
|
# If there is a url for the version check it.
|
||||||
v_url = pkg.url_for_version(v)
|
v_url = pkg.url_for_version(v)
|
||||||
self.assertEqual(vattrs['url'], v_url)
|
assert vattrs['url'] == v_url
|
||||||
|
|
||||||
def test_all_versions_are_lowercase(self):
|
|
||||||
"""Spack package names must be lowercase, and use `-` instead of `_`.
|
def test_all_versions_are_lowercase():
|
||||||
"""
|
"""Spack package names must be lowercase, and use `-` instead of `_`."""
|
||||||
errors = []
|
errors = []
|
||||||
for name in spack.repo.all_package_names():
|
for name in spack.repo.all_package_names():
|
||||||
if re.search(r'[_A-Z]', name):
|
if re.search(r'[_A-Z]', name):
|
||||||
errors.append(name)
|
errors.append(name)
|
||||||
|
|
||||||
self.assertEqual([], errors)
|
assert len(errors) == 0
|
||||||
|
Loading…
Reference in New Issue
Block a user