You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
109 lines
3.9 KiB
109 lines
3.9 KiB
2 years ago
|
#!/usr/bin/env python
|
||
|
|
||
|
# @HEADER
|
||
|
# ************************************************************************
|
||
|
#
|
||
|
# TriBITS: Tribal Build, Integrate, and Test System
|
||
|
# Copyright 2013 Sandia Corporation
|
||
|
#
|
||
|
# Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
|
||
|
# the U.S. Government retains certain rights in this software.
|
||
|
#
|
||
|
# Redistribution and use in source and binary forms, with or without
|
||
|
# modification, are permitted provided that the following conditions are
|
||
|
# met:
|
||
|
#
|
||
|
# 1. Redistributions of source code must retain the above copyright
|
||
|
# notice, this list of conditions and the following disclaimer.
|
||
|
#
|
||
|
# 2. Redistributions in binary form must reproduce the above copyright
|
||
|
# notice, this list of conditions and the following disclaimer in the
|
||
|
# documentation and/or other materials provided with the distribution.
|
||
|
#
|
||
|
# 3. Neither the name of the Corporation nor the names of the
|
||
|
# contributors may be used to endorse or promote products derived from
|
||
|
# this software without specific prior written permission.
|
||
|
#
|
||
|
# THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
|
||
|
# EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||
|
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
|
||
|
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||
|
# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||
|
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||
|
# PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||
|
# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||
|
# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||
|
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
|
#
|
||
|
# ************************************************************************
|
||
|
# @HEADER
|
||
|
|
||
|
|
||
|
#
|
||
|
# Read in the commandline arguments
|
||
|
#
|
||
|
|
||
|
usageHelp = r"""dump-package-deps-table.py [OPTIONS]
|
||
|
|
||
|
Tool that dumps an XML file that can be read by CTest/CDash to specify the
|
||
|
TriBITS project packages in a way that is independent of TriBITS. In
|
||
|
CTest/CDash terminology, a TriBITS package is a "Subproject".
|
||
|
|
||
|
By default, if you just run:
|
||
|
|
||
|
$ <thisDir>/dump-cdash-deps-xml-file.py \
|
||
|
--input-xml-deps-file=<Project>PackageDependencies.xml \
|
||
|
--output-cdash-deps-xml-file=CDashSubprojectDependencies.xml
|
||
|
|
||
|
then the XML file CDashSubprojectDependencies.xml will get written.
|
||
|
|
||
|
You can also change what XML input file is used and what XML file is written.
|
||
|
This is mainly to facilitate unit testing of this script.
|
||
|
|
||
|
NOTE: Currently this script is gutted to only list out the parent packages
|
||
|
(subprojects) and their regression email addresses. It does not currently
|
||
|
list any dependent packages. Currently CDash does not do anything very useful
|
||
|
with that information anyway and actually makes it really hard to see the
|
||
|
actually subproject-specific test results if there are a lot of upstream
|
||
|
packages (because it lists summaries of all of the dependent packages above it
|
||
|
first).
|
||
|
|
||
|
"""
|
||
|
|
||
|
from optparse import OptionParser
|
||
|
|
||
|
clp = OptionParser(usage=usageHelp)
|
||
|
|
||
|
clp.add_option(
|
||
|
"--input-xml-deps-file", dest="inputXmlDepsFile", type="string",
|
||
|
help="Input XML file giving the TriBITS Project Package dependencies.")
|
||
|
|
||
|
clp.add_option(
|
||
|
"--output-cdash-deps-xml-file", dest="outputCDashDepsXmlFile", type="string",
|
||
|
help="Output XML file giving the TriBITS project dependencies in XML form" \
|
||
|
+ " that CDash understands.")
|
||
|
|
||
|
(options, args) = clp.parse_args()
|
||
|
|
||
|
|
||
|
#
|
||
|
# Execute the commands
|
||
|
#
|
||
|
|
||
|
import os
|
||
|
import sys
|
||
|
|
||
|
ciSupportDir = os.path.join(
|
||
|
os.path.dirname(os.path.abspath(__file__)),
|
||
|
"..", "ci_support" )
|
||
|
sys.path = [ciSupportDir] + sys.path
|
||
|
|
||
|
from TribitsDependencies import getProjectDependenciesFromXmlFile
|
||
|
|
||
|
tribitsDependencies = getProjectDependenciesFromXmlFile(
|
||
|
options.inputXmlDepsFile)
|
||
|
|
||
|
tribitsDependencies.writeCDashXmlDepsFile(
|
||
|
options.outputCDashDepsXmlFile)
|