blob: 20b36d3fb9daed867cfca7529869f23e4e7b16c5 [file] [log] [blame]
#!/bin/bash
# Copyright 2023 The TensorFlow Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ==============================================================================
# This script is responsible for running the tests and also to log out the
# time (in seconds) it took to run the test file. It is using the linux time
# command to measure the latency. Setting the TIMEFORMAT to '%R' is providing
# us the real time latency.
#
# Called with following arguments:
# 1 - Name of the test file
# 2 - Name of the test script
# <variable list of parameters for the test script>
set -e
# The TEST_SCRIPT can have a variable number of arguments. So, we remove the
# arguments that are only needed for test_latency_log.sh and pass all the
# remaining ones to the TEST_SCRIPT.
ARGS=("${@}")
TEST_FILE_NAME=${ARGS[0]}
unset ARGS[0]
TEST_SCRIPT=${ARGS[0]}
unset ARGS[0]
# Output to stdout and stderr go to their normal places:
# Here we are opening 2 file descriptor, 3 and 4. FD 3 will redirect all the
# contents to stdout and 4 will redirect all the contents to stderr. Now when
# executing the TEST_SCRIPT command, we are redirecting all the stdout output of
# the command to FD 3 which will redirect everything to FD 1 (stdout) and all
# the stderr output of the command to FD 4 which will redirect everything to FD
# 2 (stderr). The output of the time command is captured in the time_log
# variable with the redirection of FD 2 (stderr) to FD 1 (stdout). Finally we
# are closing the FD 3 and 4.
#
# For more info
# https://stackoverflow.com/questions/4617489/get-values-from-time-command-via-bash-script
exec 3>&1 4>&2
time_log=$( { TIMEFORMAT="%R"; time ${TEST_SCRIPT} "${ARGS[@]}" 1>&3 2>&4; } 2>&1 ) # Captures time output only.
exec 3>&- 4>&-
echo "Running ${TEST_FILE_NAME} took ${time_log} seconds"