2017-05-12 19:38:52 +00:00
|
|
|
#!/bin/bash -eu
|
|
|
|
|
|
|
|
# Author: w0rp <devw0rp@gmail.com>
|
|
|
|
#
|
|
|
|
# This script runs tests for the ALE project. The following options are
|
|
|
|
# accepted:
|
|
|
|
#
|
|
|
|
# -v Enable verbose output
|
|
|
|
# --neovim-only Run tests only for NeoVim
|
|
|
|
# --vim-only Run tests only for Vim
|
|
|
|
|
|
|
|
RED='\033[0;31m'
|
|
|
|
GREEN='\033[0;32m'
|
|
|
|
NC='\033[0m'
|
|
|
|
CURRENT_IMAGE_ID=d5a1b5915b09
|
|
|
|
IMAGE=w0rp/ale
|
|
|
|
DOCKER_FLAGS=(--rm -v "$PWD:/testplugin" -v "$PWD/test:/home" -w /testplugin "$IMAGE")
|
|
|
|
EXIT=0
|
|
|
|
|
|
|
|
tests='test/*.vader test/*/*.vader test/*/*/*.vader test/*/*/*.vader'
|
|
|
|
verbose=0
|
2017-05-20 18:02:01 +00:00
|
|
|
quiet=0
|
2017-05-12 19:38:52 +00:00
|
|
|
run_neovim_tests=1
|
|
|
|
run_vim_tests=1
|
|
|
|
run_vint=1
|
|
|
|
run_custom_checks=1
|
|
|
|
|
|
|
|
while [ $# -ne 0 ]; do
|
|
|
|
case $1 in
|
|
|
|
-v)
|
|
|
|
verbose=1
|
|
|
|
shift
|
|
|
|
;;
|
2017-05-20 18:02:01 +00:00
|
|
|
-q)
|
|
|
|
quiet=1
|
|
|
|
shift
|
|
|
|
;;
|
2017-05-12 19:38:52 +00:00
|
|
|
--neovim-only)
|
|
|
|
run_vim_tests=0
|
|
|
|
run_vint=0
|
|
|
|
run_custom_checks=0
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--vim-only)
|
|
|
|
run_neovim_tests=0
|
|
|
|
run_vint=0
|
|
|
|
run_custom_checks=0
|
2017-07-09 13:58:17 +00:00
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--no-vint)
|
|
|
|
run_vint=0
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--no-custom-checks)
|
|
|
|
run_custom_checks=0
|
|
|
|
shift
|
2017-05-12 19:38:52 +00:00
|
|
|
;;
|
2017-08-10 09:45:12 +00:00
|
|
|
--custom-checks-only)
|
|
|
|
run_vim_tests=0
|
|
|
|
run_neovim_tests=0
|
|
|
|
run_vint=0
|
|
|
|
shift
|
|
|
|
;;
|
2017-05-12 19:38:52 +00:00
|
|
|
--)
|
|
|
|
shift
|
|
|
|
break
|
|
|
|
;;
|
|
|
|
-?*)
|
|
|
|
echo "Invalid argument: $1" 1>&2
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
break
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
# Allow tests to be passed as arguments.
|
|
|
|
if [ $# -ne 0 ]; then
|
|
|
|
# This doesn't perfectly handle work splitting, but none of our files
|
|
|
|
# have spaces in the names.
|
|
|
|
tests="$*"
|
|
|
|
fi
|
|
|
|
|
|
|
|
docker images -q w0rp/ale | grep "^$CURRENT_IMAGE_ID" > /dev/null \
|
|
|
|
|| docker pull "$IMAGE"
|
|
|
|
|
2017-05-20 18:02:01 +00:00
|
|
|
function filter-vader-output() {
|
|
|
|
# When verbose mode is off, suppress output until Vader starts.
|
|
|
|
local start_output="$verbose"
|
|
|
|
local filtered_data=''
|
2017-05-12 19:38:52 +00:00
|
|
|
|
|
|
|
while read -r; do
|
2017-05-20 18:02:01 +00:00
|
|
|
if ((!start_output)); then
|
|
|
|
if [[ "$REPLY" = *'Starting Vader:'* ]]; then
|
|
|
|
start_output=1
|
|
|
|
else
|
|
|
|
continue
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ((quiet)); then
|
|
|
|
if [[ "$REPLY" = *'Starting Vader:'* ]]; then
|
|
|
|
filtered_data="$REPLY"
|
|
|
|
elif [[ "$REPLY" = *'Success/Total'* ]]; then
|
|
|
|
success="$(echo -n "$REPLY" | grep -o '[0-9]\+/' | head -n1 | cut -d/ -f1)"
|
|
|
|
total="$(echo -n "$REPLY" | grep -o '/[0-9]\+' | head -n1 | cut -d/ -f2)"
|
|
|
|
|
|
|
|
if [ "$success" -lt "$total" ]; then
|
|
|
|
echo "$filtered_data"
|
|
|
|
echo "$REPLY"
|
2017-05-12 19:38:52 +00:00
|
|
|
fi
|
2017-05-20 18:02:01 +00:00
|
|
|
|
|
|
|
filtered_data=''
|
|
|
|
else
|
|
|
|
filtered_data="$filtered_data"$'\n'"$REPLY"
|
2017-05-12 19:38:52 +00:00
|
|
|
fi
|
2017-05-20 18:02:01 +00:00
|
|
|
else
|
|
|
|
echo "$REPLY"
|
2017-05-12 19:38:52 +00:00
|
|
|
fi
|
2017-05-20 18:02:01 +00:00
|
|
|
done
|
|
|
|
}
|
2017-05-12 19:38:52 +00:00
|
|
|
|
2017-05-20 18:02:01 +00:00
|
|
|
function color-vader-output() {
|
|
|
|
while read -r; do
|
2017-05-12 19:38:52 +00:00
|
|
|
if [[ "$REPLY" = *'[EXECUTE] (X)'* ]]; then
|
|
|
|
echo -en "$RED"
|
|
|
|
elif [[ "$REPLY" = *'[EXECUTE]'* ]] || [[ "$REPLY" = *'[ GIVEN]'* ]]; then
|
|
|
|
echo -en "$NC"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ "$REPLY" = *'Success/Total'* ]]; then
|
|
|
|
success="$(echo -n "$REPLY" | grep -o '[0-9]\+/' | head -n1 | cut -d/ -f1)"
|
|
|
|
total="$(echo -n "$REPLY" | grep -o '/[0-9]\+' | head -n1 | cut -d/ -f2)"
|
|
|
|
|
|
|
|
if [ "$success" -lt "$total" ]; then
|
|
|
|
echo -en "$RED"
|
|
|
|
else
|
|
|
|
echo -en "$GREEN"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "$REPLY"
|
|
|
|
echo -en "$NC"
|
|
|
|
else
|
|
|
|
echo "$REPLY"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
echo -en "$NC"
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((run_neovim_tests)); then
|
|
|
|
for vim in $(docker run --rm "$IMAGE" ls /vim-build/bin | grep '^neovim' ); do
|
|
|
|
echo
|
|
|
|
echo '========================================'
|
|
|
|
echo "Running tests for $vim"
|
|
|
|
echo '========================================'
|
|
|
|
echo
|
|
|
|
|
|
|
|
set -o pipefail
|
|
|
|
docker run -it -e VADER_OUTPUT_FILE=/dev/stderr "${DOCKER_FLAGS[@]}" \
|
|
|
|
"/vim-build/bin/$vim" -u test/vimrc \
|
2017-05-20 18:02:01 +00:00
|
|
|
--headless "+Vader! $tests" | filter-vader-output | color-vader-output || EXIT=$?
|
2017-05-12 19:38:52 +00:00
|
|
|
set +o pipefail
|
|
|
|
done
|
|
|
|
|
|
|
|
echo
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ((run_vim_tests)); then
|
|
|
|
for vim in $(docker run --rm "$IMAGE" ls /vim-build/bin | grep '^vim' ); do
|
|
|
|
echo
|
|
|
|
echo '========================================'
|
|
|
|
echo "Running tests for $vim"
|
|
|
|
echo '========================================'
|
|
|
|
echo
|
|
|
|
|
|
|
|
set -o pipefail
|
2017-07-09 13:58:17 +00:00
|
|
|
docker run -a stderr -e VADER_OUTPUT_FILE=/dev/stderr "${DOCKER_FLAGS[@]}" \
|
2017-05-12 19:38:52 +00:00
|
|
|
"/vim-build/bin/$vim" -u test/vimrc \
|
2017-05-20 18:02:01 +00:00
|
|
|
"+Vader! $tests" 2>&1 | filter-vader-output | color-vader-output || EXIT=$?
|
2017-05-12 19:38:52 +00:00
|
|
|
set +o pipefail
|
|
|
|
done
|
|
|
|
|
|
|
|
echo
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ((run_vint)); then
|
|
|
|
echo '========================================'
|
|
|
|
echo 'Running Vint to lint our code'
|
|
|
|
echo '========================================'
|
|
|
|
echo 'Vint warnings/errors follow:'
|
|
|
|
echo
|
|
|
|
|
|
|
|
set -o pipefail
|
|
|
|
docker run -a stdout "${DOCKER_FLAGS[@]}" vint -s . || EXIT=$?
|
|
|
|
set +o pipefail
|
|
|
|
echo
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ((run_custom_checks)); then
|
|
|
|
echo '========================================'
|
|
|
|
echo 'Running custom checks'
|
|
|
|
echo '========================================'
|
|
|
|
echo 'Custom warnings/errors follow:'
|
|
|
|
echo
|
|
|
|
|
|
|
|
set -o pipefail
|
|
|
|
docker run -a stdout "${DOCKER_FLAGS[@]}" ./custom-checks . || EXIT=$?
|
|
|
|
set +o pipefail
|
|
|
|
echo
|
2017-06-29 11:55:00 +00:00
|
|
|
|
|
|
|
echo '========================================'
|
|
|
|
echo 'Checking for duplicate tags'
|
|
|
|
echo '========================================'
|
|
|
|
echo 'Duplicate tags follow:'
|
|
|
|
echo
|
|
|
|
|
|
|
|
grep --exclude=tags -roh '\*.*\*$' doc | sort | uniq -d || EXIT=$?
|
2017-08-10 09:45:12 +00:00
|
|
|
|
|
|
|
echo '========================================'
|
|
|
|
echo 'Checking for invalid tag references'
|
|
|
|
echo '========================================'
|
|
|
|
echo 'Invalid tag references tags follow:'
|
|
|
|
echo
|
|
|
|
|
|
|
|
tag_regex='[gb]\?:\?\(ale\|ALE\)[a-zA-Z_\-]\+'
|
|
|
|
|
|
|
|
# Grep for tags and references, and complain if we find a reference without
|
|
|
|
# a tag for the reference. Only our tags will be included.
|
|
|
|
diff -u \
|
|
|
|
<(grep --exclude=tags -roh "\*$tag_regex\*" doc | sort -u | sed 's/*//g') \
|
|
|
|
<(grep --exclude=tags -roh "|$tag_regex|" doc | sort -u | sed 's/|//g') \
|
|
|
|
| grep '^+[^+]' && EXIT=1
|
2017-05-12 19:38:52 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
exit $EXIT
|