Adding command testinstall. See "spack testinstall -h" for documentation.

Still need to add output formatting (in a commonly parse-able format like Junit
or TAP). May want to adjust how the build log is accessed in case of a build
failure.
This commit is contained in:
Peter Scheibel 2015-10-12 19:09:11 -07:00
parent 58c5373890
commit b7249d66b3

View File

@ -0,0 +1,129 @@
##############################################################################
# Copyright (c) 2013, Lawrence Livermore National Security, LLC.
# Produced at the Lawrence Livermore National Laboratory.
#
# This file is part of Spack.
# Written by Todd Gamblin, tgamblin@llnl.gov, All rights reserved.
# LLNL-CODE-647188
#
# For details, see https://scalability-llnl.github.io/spack
# Please also see the LICENSE file for our notice and the LGPL.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License (as published by
# the Free Software Foundation) version 2.1 dated February 1999.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY OF
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the terms and
# conditions of the GNU General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program; if not, write to the Free Software Foundation,
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
##############################################################################
from external import argparse
import xml.etree.ElementTree as ET
import llnl.util.tty as tty
from llnl.util.filesystem import *
import spack
import spack.cmd
description = "Build and install packages"
def setup_parser(subparser):
#subparser.add_argument(
# '-i', '--ignore-dependencies', action='store_true', dest='ignore_deps',
# help="Do not try to install dependencies of requested packages.")
subparser.add_argument(
'-j', '--jobs', action='store', type=int,
help="Explicitly set number of make jobs. Default is #cpus.")
#always false for test
#subparser.add_argument(
# '--keep-prefix', action='store_true', dest='keep_prefix',
# help="Don't remove the install prefix if installation fails.")
#always true for test
#subparser.add_argument(
# '--keep-stage', action='store_true', dest='keep_stage',
# help="Don't remove the build stage if installation succeeds.")
subparser.add_argument(
'-n', '--no-checksum', action='store_true', dest='no_checksum',
help="Do not check packages against checksum")
subparser.add_argument(
'-v', '--verbose', action='store_true', dest='verbose',
help="Display verbose build output while installing.")
#subparser.add_argument(
# '--fake', action='store_true', dest='fake',
# help="Fake install. Just remove the prefix and touch a fake file in it.")
subparser.add_argument(
'outputdir', help="test output goes in this directory, 1 file per package")
subparser.add_argument(
'packages', nargs=argparse.REMAINDER, help="specs of packages to install")
class JunitTestResult(object):
def __init__(self):
self.root = Element('testsuite')
self.tests = []
def addTest(self, identifier, passed=True, output=None):
self.tests.append((identifier, passed, output))
def output(self):
self.root.set('tests', '{0}'.format(len(self.tests)))
def testinstall(parser, args):
if not args.packages:
tty.die("install requires at least one package argument")
if args.jobs is not None:
if args.jobs <= 0:
tty.die("The -j option must be a positive integer!")
if args.no_checksum:
spack.do_checksum = False # TODO: remove this global.
print "Output to:", args.outputdir
specs = spack.cmd.parse_specs(args.packages, concretize=True)
try:
for spec in specs:
#import pdb; pdb.set_trace()
package = spack.db.get(spec)
package.do_install(
keep_prefix=False,
keep_stage=False,
ignore_deps=False,
make_jobs=args.jobs,
verbose=args.verbose,
fake=False)
finally:
for spec in specs:
package = spack.db.get(spec)
#import pdb; pdb.set_trace()
print spec.name
print spec.version
print spec.dag_hash()
if package.installed:
installLog = spack.install_layout.build_log_path(spec)
else:
#TODO: search recursively under stage.path instead of only within
# stage.source_path
installLog = join_path(package.stage.source_path, 'spack-build.out')
with open(installLog, 'rb') as F:
for line in F.readlines()[:10]:
print "\t{0}".format(line.strip())