#*****************************************************************************
#
# Copyright (c) 2000 - 2018, Lawrence Livermore National Security, LLC
# Produced at the Lawrence Livermore National Laboratory
# LLNL-CODE-442911
# All rights reserved.
#
# This file is part of VisIt. For details, see https://visit.llnl.gov/. The
# full copyright notice is contained in the file COPYRIGHT located at the root
# of the VisIt distribution or at http://www.llnl.gov/visit/copyright.html.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# - Redistributions of source code must retain the above copyright notice,
# this list of conditions and the disclaimer below.
# - Redistributions in binary form must reproduce the above copyright notice,
# this list of conditions and the disclaimer (as noted below) in the
# documentation and/or other materials provided with the distribution.
# - Neither the name of the LLNS/LLNL nor the names of its contributors may
# be used to endorse or promote products derived from this software without
# specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 LAWRENCE LIVERMORE NATIONAL SECURITY,
# LLC, THE U.S. DEPARTMENT OF ENERGY OR 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.
#*****************************************************************************
# ----------------------------------------------------------------------------
# Method: ctestReport
# Diff -- reports the image error and diff type, start the sub test, always
# DiffImages -- reports images for a failed ctest, only failed test
# MissingBaseline -- reports missing baseline
# ReportWallTime -- report wall time for the sub test, always
# ReportCPUTime -- report CPU time for sub test, always
#
# Programmer: Burlen Loring
# Date: 2014-01-30 18:27:03
#
# Modifications:
#
# Burlen Loring, Fri Oct 2 09:56:26 PDT 2015
# Make ctest output for each subtest. I added methods to track
# the elapsed time spent in each subtest
#
# ----------------------------------------------------------------------------
import time
def ctestReportDiff(imdiff, imtype=-1, oss=None):
"""write ctest tag for image difference value"""
tag = ' %f \n'%(imdiff)
if (imtype <= 0):
tag += 'Standard'
else:
tag += ' %d '%(imtype)
if oss is not None:
oss.write(tag)
return tag
def ctestReportDiffImages(testImage, diffImage, validImage, oss=None):
"""write ctest tags for images of a failed test"""
tag = ' %s \n'%(testImage)
tag += ' %s \n'%(diffImage)
tag += ' %s '%(validImage)
if oss is not None:
oss.write(tag)
return tag
def ctestReportMissingBaseline(validImage, oss=None):
"""write ctest tags for test failed because of missing baseline"""
tag = ' %s '%(validImage)
if oss is not None:
oss.write(tag)
return tag
def ctestReportWallTime(wallTime, oss=None):
"""write ctest tag for timing"""
tag = ' %f '%(wallTime)
if oss is not None:
oss.write(tag)
return tag
def ctestReportCPUTime(cpuTime, oss=None):
"""write ctest tag for timing"""
tag = ' %f '%(cpuTime)
if oss is not None:
oss.write(tag)
return tag
visit_cur_time = time.time()
def ctestInitTestTimer():
"""
Initialize the base time for elapsed time function
"""
global visit_cur_time
visit_cur_time = time.time()
return
def ctestGetElapsedTime():
"""
Get the time elapsed since the last call
"""
global visit_cur_time
new_time = time.time()
elapsed_time = new_time - visit_cur_time
visit_cur_time = new_time
return elapsed_time