fi
export BT_TESTS_PYTHON_BIN
+BT_TESTS_PYTHON_VERSION=$($BT_TESTS_PYTHON_BIN -c 'import sys; print("{}.{}".format(sys.version_info.major, sys.version_info.minor))')
+
if [ -z "${BT_TESTS_PYTHON_CONFIG_BIN:-}" ]; then
BT_TESTS_PYTHON_CONFIG_BIN="python3-config"
fi
# Remove CR characters in file "$1".
bt_remove_cr() {
- "$BT_TESTS_SED_BIN" -i 's/\r//g' "$1"
+ "$BT_TESTS_SED_BIN" -i'' -e 's/\r//g' "$1"
}
# Run the Babeltrace CLI, redirecting stdout and stderr to specified files.
local ret_stdout
local ret_stderr
- temp_stdout_output_file="$(mktemp -t actual_stdout.XXXXXX)"
- temp_stderr_output_file="$(mktemp -t actual_stderr.XXXXXX)"
+ temp_stdout_output_file="$(mktemp -t actual-stdout.XXXXXX)"
+ temp_stderr_output_file="$(mktemp -t actual-stderr.XXXXXX)"
# Run the CLI to get a detailed file.
bt_cli "$temp_stdout_output_file" "$temp_stderr_output_file" "${args[@]}"
return $ret
}
+# Run the grep binary configured for the tests.
+bt_grep() {
+ "$BT_TESTS_GREP_BIN" "$@"
+}
### Functions ###
# Execute a shell command in the appropriate environment to access the Python
# test utility modules in `tests/utils/python`.
run_python() {
- PYTHONPATH="${BT_TESTS_SRCDIR}/utils/python${PYTHONPATH:+:}${PYTHONPATH:-}" "$@"
+ local our_pythonpath="${BT_TESTS_SRCDIR}/utils/python"
+
+ if [[ $BT_TESTS_PYTHON_VERSION =~ 3.[45] ]]; then
+ # Add a local directory containing a `typing.py` to `PYTHONPATH` for
+ # Python 3.4 which doesn't offer the `typing` module.
+ our_pythonpath="$our_pythonpath:${BT_TESTS_SRCDIR}/utils/python/typing"
+ fi
+
+ PYTHONPATH="${our_pythonpath}${PYTHONPATH:+:}${PYTHONPATH:-}" "$@"
}
# Execute a shell command in the appropriate environment to have access to the
# existing ASAN_OPTIONS, such that we override the user's value if it
# contains detect_leaks=1.
if [ "${BT_TESTS_ENABLE_ASAN:-}" = "1" ]; then
- if ${BT_TESTS_CC_BIN} --version | head -n 1 | grep -q '^gcc'; then
+ if ${BT_TESTS_CC_BIN} --version | head -n 1 | bt_grep -q '^gcc'; then
lib_asan="$(${BT_TESTS_CC_BIN} -print-file-name=libasan.so)"
local -x LD_PRELOAD="${lib_asan}${LD_PRELOAD:+:}${LD_PRELOAD:-}"
fi
return $ret
}
+
+# Generate a CTF trace using `mctf.py`.
+#
+# $1: Input filename
+# $2: Base directory path for output files
+gen_mctf_trace() {
+ local input_file="$1"
+ local base_dir="$2"
+
+ diag "Running: ${BT_TESTS_PYTHON_BIN} ${BT_TESTS_SRCDIR}/utils/python/mctf.py --base-dir ${base_dir} ${input_file}"
+ run_python "${BT_TESTS_PYTHON_BIN}" "${BT_TESTS_SRCDIR}/utils/python/mctf.py" \
+ --base-dir "${base_dir}" "${input_file}"
+}