Cloned SEACAS for EXODUS library with extra build files for internal package management.
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.

152 lines
5.6 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
#
# Usage: mockprogram.py [any arguments]
#
# Mock program that takes input arguments and produces stdout by reading from
# a file .mockprogram_inout.txt in the current directory or the file specified
# by the env var MOCKPROGRAM_INOUT_FILE_OVERRIDE (which can be in any
# directory). This script is used to take the place of real commands during a
# test that involves calling commands on the commandline.
#
# The file .mockprogram_inout.txt (or pointed to by
# MOCKPROGRAM_INOUT_FILE_OVERRIDE) is of the form:
#
# MOCK_PROGRAM_INPUT: <args_1>
# MOCK_PROGRAM_RETURN: <rtn>
# MOCK_PROGRAM_OUTPUT: <outline_1_line_1>
# <outline_1_line_2>
# ...
# MOCK_PROGRAM_INPUT: <args_2>
#
# The program reads in the blocks starting at the time and removes the block
# from the file after it runs. After all of the blocks are read in, if run
# again it will error out with error code 2.
#
# This program can be used, for example, to simulate git command. For
# example, a couple of git commits might be simulated like:
#
# MOCK_PROGRAM_INPUT: log -1
# MOCK_PROGRAM_RETURN: 0
# MOCK_PROGRAM_OUTPUT: This is the summary line
#
# The is the body of the commit msg
# MOCK_PROGRAM_INPUT: diff --name-only HEAD --not @{u}
# MOCK_PROGRAM_RETURN: 0
# MOCK_PROGRAM_OUTPUT: file_name_1.txt
# file_name_2.txt
# file_name_3.txt
#
import sys
import os
inputArgs = ' '.join(sys.argv[1:])
#print("inputArgs = '" + inputArgs + "'"
if os.environ.get("MOCKPROGRAM_INOUT_FILE_OVERRIDE"):
mockProgramInOutFilePath=os.environ.get("MOCKPROGRAM_INOUT_FILE_OVERRIDE")
else:
mockProgramInOutFilePath='.mockprogram_inout.txt'
if not os.path.exists(mockProgramInOutFilePath):
print("Error: "+mockProgramInOutFilePath+" is missing!")
sys.exit(1)
mockprogramInout = open(mockProgramInOutFilePath, 'r').read()
mockprogramInoutArray = mockprogramInout.splitlines()
if len(mockprogramInoutArray) and mockprogramInoutArray[-1] == "":
mockprogramInoutArray = mockprogramInoutArray[:-1]
if len(mockprogramInoutArray) < 3:
print("Error: "+mockProgramInOutFilePath+" has less than three lines:\n"
"-------------\n" + mockprogramInout + "-------------")
sys.exit(2)
# Assert input
expectedInputLine = mockprogramInoutArray[0]
if expectedInputLine.find("MOCK_PROGRAM_INPUT:") != 0:
print("Error, first line = '" + expectedInputLine + "', does not match "
"^MOCK_PROGRAM_INPUT:")
sys.exit(3)
expectedInput = expectedInputLine.replace("MOCK_PROGRAM_INPUT:", "").strip()
if inputArgs != expectedInput:
print("Error, input args='" + inputArgs + "' does not match expected='" +
expectedInput + "'")
sys.exit(4)
# Get return code
returnCodeLine = mockprogramInoutArray[1]
if returnCodeLine.find("MOCK_PROGRAM_RETURN:") != 0:
print("Error, second line = '" + returnCodeLine + "', does not match "
"^MOCK_PROGRAM_RETURN:")
sys.exit(5)
returnCode = returnCodeLine.replace("MOCK_PROGRAM_RETURN:", "").strip()
# Get output (can be multi-line)
outputLine = mockprogramInoutArray[2]
if outputLine.find("MOCK_PROGRAM_OUTPUT:") != 0:
print("Error, third line = '" + outputLine + "', does not match "
"^MOCK_PROGRAM_OUTPUT:")
sys.exit(6)
outputStr = outputLine.replace("MOCK_PROGRAM_OUTPUT: ", "")
numLinesOuput = 1
if len(mockprogramInoutArray) > 3:
for line in mockprogramInoutArray[3:]:
if line.find("MOCK_PROGRAM_INPUT:") == 0:
break
outputStr = outputStr+"\n"+line
numLinesOuput = numLinesOuput + 1
print(outputStr)
# Write the remaining lines back into the file
lineLineIndex = 2 + numLinesOuput
if len(mockprogramInoutArray) > lineLineIndex:
open(mockProgramInOutFilePath, 'w').write(
('\n'.join(mockprogramInoutArray[lineLineIndex:]))+"\n" )
else:
open(mockProgramInOutFilePath, 'w').write("")
# Return exit code
sys.exit(int(returnCode))