CMakePackage, AutotoolsPackage : added default behavior on check

This commit is contained in:
alalazo 2016-10-23 19:02:46 +02:00
parent ebbbed166e
commit fa3f07c092
4 changed files with 33 additions and 10 deletions

View File

@ -1055,6 +1055,27 @@ def do_fake_install(self):
mkdirp(self.prefix.lib)
mkdirp(self.prefix.man1)
def _if_make_target_execute(self, target):
try:
# Check if we have a makefile
file = [x for x in ('Makefile', 'makefile') if os.path.exists(x)]
file = file.pop()
except IndexError:
tty.msg('No Makefile found in the build directory')
return
# Check if 'target' is in the makefile
regex = re.compile('^' + target + ':')
with open(file, 'r') as f:
matches = [line for line in f.readlines() if regex.match(line)]
if not matches:
tty.msg('Target \'' + target + ':\' not found in Makefile')
return
# Execute target
inspect.getmodule(self).make(target)
def _get_needed_resources(self):
resources = []
# Select the resources that are needed for this build
@ -1747,6 +1768,10 @@ def _run_default_function(self):
except AttributeError:
tty.msg('Skipping default sanity checks [method `check` not implemented]') # NOQA: ignore=E501
def check(self):
self._if_make_target_execute('test')
self._if_make_target_execute('check')
# This will be used as a registration decorator in user
# packages, if need be
PackageBase.sanity_check('install')(PackageBase.sanity_check_prefix)
@ -1814,10 +1839,14 @@ def install(self, spec, prefix):
def _run_default_function(self):
try:
fn = getattr(self, 'check')
tty.msg('Trying default sanity checks [check]')
tty.msg('Trying default build sanity checks [check]')
fn()
except AttributeError:
tty.msg('Skipping default sanity checks [method `check` not implemented]') # NOQA: ignore=E501
tty.msg('Skipping default build sanity checks [method `check` not implemented]') # NOQA: ignore=E501
def check(self):
with working_dir(self.build_directory()):
self._if_make_target_execute('test')
PackageBase.sanity_check('install')(PackageBase.sanity_check_prefix)

View File

@ -144,7 +144,8 @@ def configure_args(self):
return ["--with-zlib=%s" % spec['zlib'].prefix] + extra_args
def check(self):
"Build and run a small program to test the installed HDF5 library"
super(Hdf5, self).check()
# Build and run a small program to test the installed HDF5 library
spec = self.spec
print("Checking HDF5 installation...")
checkdir = "spack-check"

View File

@ -42,7 +42,3 @@ def configure_args(self):
'--disable-dependency-tracking',
'--enable-shared'
]
def check(self):
make('check')
make('test')

View File

@ -44,6 +44,3 @@ class Qhull(CMakePackage):
url="http://www.qhull.org/download/qhull-2012.1-src.tgz")
depends_on('cmake@2.6:', type='build')
def check(self):
make('test')