2021-03-15 17:42:53 +00:00
|
|
|
# vim: set ts=4 sw=4 tw=100 et:
|
|
|
|
# POSIX sh test driver to reduce dependency on fish in tests
|
|
|
|
|
|
|
|
# macOS has really weird default IFS behavior that splits output in random places, and the trailing
|
|
|
|
# backspace is to prevent \n from being gobbled up by the subshell output substitution.
|
|
|
|
# Folks, this is why you should use fish!
|
|
|
|
IFS="$(printf "\n\b")"
|
|
|
|
|
|
|
|
# The first argument is the path to the script to launch; all remaining arguments are forwarded to
|
|
|
|
# the script.
|
|
|
|
fish_script="$1"
|
|
|
|
shift 1
|
|
|
|
script_args="${@}"
|
|
|
|
|
|
|
|
die() {
|
|
|
|
if test "$#" -ge 0; then
|
|
|
|
printf "%s\n" "$@" 1>&2
|
|
|
|
fi
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
# To keep things sane and to make error messages comprehensible, do not use relative paths anywhere
|
|
|
|
# in this script. Instead, make all paths relative to one of these or $homedir."
|
Make `test` a custom target again and add top-level test targets
Even though we are using CMake's ctest for testing, we still define our
own `make test` target rather than use its default for many reasons:
* CMake doesn't run tests in-proc or even add each tests as an
individual node in the ninja dependency tree, instead it just bundles
all tests into a target called `test` that always just shells out to
`ctest`, so there are no build-related benefits to not doing that
ourselves.
* CMake devs insist that it is appropriate for `make test` to never
depend on `make all`, i.e. running `make test` does not require any
of the binaries to be built before testing.
* The only way to have a test depend on a binary is to add a fake test
with a name like "build_fish" that executes CMake recursively to
build the `fish` target.
* It is not possible to set top-level CTest options/settings such as
CTEST_PARALLEL_LEVEL from within the CMake configuration file.
* Circling back to the point about individual tests not being actual
Makefile targets, CMake does not offer any way to execute a named
test via the `make`/`ninja`/whatever interface; the only way to
manually invoke test `foo` is to to manually run `ctest` and specify
a regex matching `foo` as an argument, e.g. `ctest -R ^foo$`... which
is really crazy.
With this patch, it is now possible to execute any single test by name,
by invoking the build directly, e.g. to run the `universal.fish` check:
`cmake --build build --target universal.fish` or
`ninja -C build universal.fish`. Unfortunately, this is not integrated
into the Makefile wrapper, so `make universal.fish` won't work (although
this can potentially be hacked around).
2021-08-08 23:31:50 +00:00
|
|
|
TESTS_ROOT="$(dirname "$0")"
|
|
|
|
BUILD_ROOT="${TESTS_ROOT}/.."
|
|
|
|
|
|
|
|
# macOS (still!) doesn't have `readlink -f` or `realpath`. That's OK, this is just for aesthetics.
|
|
|
|
if command -v realpath 1>/dev/null 2>/dev/null; then
|
|
|
|
TESTS_ROOT="$(realpath --no-symlinks "${TESTS_ROOT}")"
|
|
|
|
BUILD_ROOT="$(realpath --no-symlinks "${BUILD_ROOT}")"
|
|
|
|
fi
|
2021-03-15 17:42:53 +00:00
|
|
|
|
|
|
|
if ! test -z "$__fish_is_running_tests"; then
|
|
|
|
echo "Recursive test invocation detected!" 1>&2
|
|
|
|
exit 10
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Set up a test environment and re-run the original script. We do not share environments
|
|
|
|
# whatsoever between tests, so each test driver run sets up a new profile altogether.
|
|
|
|
|
2021-03-23 06:47:04 +00:00
|
|
|
# macOS 10.10 requires an explicit template for `mktemp` and will create the folder in the
|
|
|
|
# current directory unless told otherwise. Linux isn't guaranteed to have $TMPDIR set.
|
|
|
|
homedir="$(mktemp -d 2>/dev/null || mktemp -d "${TMPDIR}tmp.XXXXXXXXXX")"
|
2021-03-15 17:42:53 +00:00
|
|
|
|
|
|
|
XDG_DATA_HOME="$homedir/xdg_data_home"
|
|
|
|
export XDG_DATA_HOME
|
|
|
|
mkdir -p $XDG_DATA_HOME/fish || die
|
|
|
|
|
|
|
|
XDG_CONFIG_HOME="$homedir/xdg_config_home"
|
|
|
|
export XDG_CONFIG_HOME
|
|
|
|
mkdir -p $XDG_CONFIG_HOME/fish || die
|
|
|
|
|
|
|
|
XDG_RUNTIME_DIR="$homedir/xdg_runtime_dir"
|
|
|
|
export XDG_CONFIG_HOME
|
|
|
|
mkdir -p $XDG_RUNTIME_DIR/fish || die
|
|
|
|
|
2021-03-24 00:26:16 +00:00
|
|
|
# Create a temp/scratch directory for tests to use, if they want (tests shouldn't write to a
|
|
|
|
# shared temp folder).
|
|
|
|
TMPDIR="$homedir/temp"
|
|
|
|
mkdir ${TMPDIR}
|
|
|
|
export TMPDIR
|
|
|
|
|
2021-03-15 17:42:53 +00:00
|
|
|
# These are used read-only so it's OK to symlink instead of copy
|
|
|
|
rm -f "$XDG_CONFIG_HOME/fish/functions"
|
|
|
|
ln -s "$PWD/test_functions" "$XDG_CONFIG_HOME/fish/functions" || die "Failed to symlink"
|
|
|
|
|
|
|
|
# Set the function path at startup, referencing the default fish functions and the test-specific
|
|
|
|
# functions.
|
|
|
|
fish_init_cmd="set fish_function_path ${XDG_CONFIG_HOME}/fish/functions ${BUILD_ROOT}/share/functions"
|
|
|
|
|
|
|
|
__fish_is_running_tests="$homedir"
|
|
|
|
export __fish_is_running_tests
|
|
|
|
|
|
|
|
# Set locale information for consistent tests. Fish should work with a lot of locales but the
|
|
|
|
# tests assume an english UTF-8 locale unless they explicitly override this default. We do not
|
|
|
|
# want the users locale to affect the tests since they might, for example, change the wording of
|
|
|
|
# logged messages.
|
|
|
|
#
|
|
|
|
# TODO: set LANG to en_US.UTF-8 so we test the locale message conversions (i.e., gettext).
|
|
|
|
unset LANGUAGE
|
|
|
|
# Remove "LC_" env vars from the test environment
|
|
|
|
for key in $(env | grep -E "^LC_"| grep -oE "^[^=]+"); do
|
|
|
|
unset "$key"
|
|
|
|
done
|
|
|
|
# Set the desired lang/locale tests are hard-coded against
|
|
|
|
export LANG="C"
|
|
|
|
export LC_CTYPE="en_US.UTF-8"
|
|
|
|
|
|
|
|
# These env vars should not be inherited from the user environment because they can affect the
|
|
|
|
# behavior of the tests. So either remove them or set them to a known value.
|
|
|
|
# See also tests/interactive.fish.
|
|
|
|
export TERM=xterm
|
|
|
|
unset COLORTERM
|
|
|
|
unset INSIDE_EMACS
|
|
|
|
unset ITERM_PROFILE
|
|
|
|
unset KONSOLE_PROFILE_NAME
|
|
|
|
unset KONSOLE_VERSION
|
|
|
|
unset PANTHEON_TERMINAL_ID
|
|
|
|
unset TERM_PROGRAM
|
|
|
|
unset TERM_PROGRAM_VERSION
|
|
|
|
unset VTE_VERSION
|
|
|
|
unset WT_PROFILE_ID
|
|
|
|
unset XTERM_VERSION
|
|
|
|
|
|
|
|
# Set a marker to indicate whether colored output should be suppressed (used in `test_util.fish`)
|
|
|
|
suppress_color=""
|
|
|
|
if ! tty 0>&1 > /dev/null; then
|
|
|
|
suppress_color="yes"
|
|
|
|
fi
|
|
|
|
export suppress_color
|
|
|
|
|
|
|
|
# Source test util functions at startup
|
|
|
|
fish_init_cmd="${fish_init_cmd} && source ${TESTS_ROOT}/test_util.fish";
|
|
|
|
|
2021-07-31 00:21:36 +00:00
|
|
|
# Run the test script, but don't exec so we can do cleanup after it succeeds/fails. Each test is
|
|
|
|
# launched directly within its TMPDIR, so that the fish tests themselves do not need to refer to
|
|
|
|
# TMPDIR (to ensure their output as displayed in case of failure by littlecheck is reproducible).
|
|
|
|
(cd $TMPDIR; env HOME="$homedir" "${BUILD_ROOT}/test/root/bin/fish" \
|
2021-03-15 17:42:53 +00:00
|
|
|
--init-command "${fish_init_cmd}" \
|
2021-07-31 00:21:36 +00:00
|
|
|
"$fish_script" "$script_args")
|
2021-03-15 17:42:53 +00:00
|
|
|
test_status="$?"
|
|
|
|
|
|
|
|
rm -rf "$homedir"
|
|
|
|
exit "$test_status"
|