2018-05-16 18:55:21 +02:00
|
|
|
set -ex
|
2018-07-28 12:14:35 +02:00
|
|
|
|
|
|
|
echo "Running clippy base tests"
|
|
|
|
|
2018-05-16 09:10:35 +02:00
|
|
|
PATH=$PATH:./node_modules/.bin
|
2018-10-12 07:59:08 +02:00
|
|
|
if [ "$TRAVIS_OS_NAME" == "linux" ]; then
|
2019-03-01 07:32:51 +01:00
|
|
|
remark -f *.md -f doc/*.md > /dev/null
|
2018-10-12 07:59:08 +02:00
|
|
|
fi
|
2018-07-28 12:14:35 +02:00
|
|
|
# build clippy in debug mode and run tests
|
2018-05-16 09:10:35 +02:00
|
|
|
cargo build --features debugging
|
|
|
|
cargo test --features debugging
|
2018-12-09 22:47:22 +01:00
|
|
|
# for faster build, share target dir between subcrates
|
|
|
|
export CARGO_TARGET_DIR=`pwd`/target/
|
2019-01-27 02:49:29 +01:00
|
|
|
(cd clippy_lints && cargo test)
|
|
|
|
(cd rustc_tools_util && cargo test)
|
|
|
|
(cd clippy_dev && cargo test)
|
2018-11-04 09:41:28 +01:00
|
|
|
|
2018-12-14 21:43:40 +01:00
|
|
|
# make sure clippy can be called via ./path/to/cargo-clippy
|
2019-01-27 02:49:29 +01:00
|
|
|
(
|
|
|
|
cd clippy_workspace_tests
|
|
|
|
../target/debug/cargo-clippy
|
|
|
|
)
|
2018-12-14 21:43:40 +01:00
|
|
|
|
2018-11-04 09:41:28 +01:00
|
|
|
# Perform various checks for lint registration
|
|
|
|
./util/dev update_lints --check
|
2018-11-27 21:11:05 +01:00
|
|
|
cargo +nightly fmt --all -- --check
|
2018-12-09 22:06:29 +01:00
|
|
|
|
2019-01-27 03:24:45 +01:00
|
|
|
# Check running clippy-driver without cargo
|
|
|
|
(
|
|
|
|
export LD_LIBRARY_PATH=$(rustc --print sysroot)/lib
|
|
|
|
|
|
|
|
# Check sysroot handling
|
|
|
|
sysroot=$(./target/debug/clippy-driver --print sysroot)
|
|
|
|
test $sysroot = $(rustc --print sysroot)
|
|
|
|
|
|
|
|
sysroot=$(./target/debug/clippy-driver --sysroot /tmp --print sysroot)
|
|
|
|
test $sysroot = /tmp
|
|
|
|
|
|
|
|
sysroot=$(SYSROOT=/tmp ./target/debug/clippy-driver --print sysroot)
|
|
|
|
test $sysroot = /tmp
|
|
|
|
|
|
|
|
# Make sure this isn't set - clippy-driver should cope without it
|
|
|
|
unset CARGO_MANIFEST_DIR
|
|
|
|
|
|
|
|
# Run a lint and make sure it produces the expected output. It's also expected to exit with code 1
|
|
|
|
# XXX How to match the clippy invocation in compile-test.rs?
|
|
|
|
! ./target/debug/clippy-driver -Dwarnings -Aunused -Zui-testing --emit metadata --crate-type bin tests/ui/cstring.rs 2> cstring.stderr
|
|
|
|
diff <(sed -e 's,tests/ui,$DIR,' -e '/= help/d' cstring.stderr) tests/ui/cstring.stderr
|
|
|
|
|
|
|
|
# TODO: CLIPPY_CONF_DIR / CARGO_MANIFEST_DIR
|
|
|
|
)
|
|
|
|
|
2018-12-09 22:06:29 +01:00
|
|
|
# make sure tests are formatted
|
|
|
|
|
|
|
|
# some lints are sensitive to formatting, exclude some files
|
2018-12-27 16:17:45 +01:00
|
|
|
tests_need_reformatting="false"
|
2018-12-27 12:16:08 +01:00
|
|
|
# switch to nightly
|
2019-02-02 20:54:18 +01:00
|
|
|
rustup override set nightly
|
2018-12-27 12:40:07 +01:00
|
|
|
# avoid loop spam and allow cmds with exit status != 0
|
|
|
|
set +ex
|
|
|
|
|
2019-04-09 20:53:38 +02:00
|
|
|
# Excluding `ice-3891.rs` because the code triggers a rustc parse error which
|
|
|
|
# makes rustfmt fail.
|
|
|
|
for file in `find tests -not -path "tests/ui/crashes/ice-3891.rs" | grep "\.rs$"` ; do
|
2018-12-27 12:40:07 +01:00
|
|
|
rustfmt ${file} --check
|
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
echo "${file} needs reformatting!"
|
2018-12-27 16:17:45 +01:00
|
|
|
tests_need_reformatting="true"
|
2018-12-27 12:40:07 +01:00
|
|
|
fi
|
2018-12-09 22:06:29 +01:00
|
|
|
done
|
|
|
|
|
2018-12-27 12:40:07 +01:00
|
|
|
set -ex # reset
|
|
|
|
|
2018-12-27 16:17:45 +01:00
|
|
|
if [ "${tests_need_reformatting}" == "true" ] ; then
|
2018-12-10 06:27:19 +01:00
|
|
|
echo "Tests need reformatting!"
|
2018-12-09 22:06:29 +01:00
|
|
|
exit 2
|
|
|
|
fi
|
2018-12-27 12:40:07 +01:00
|
|
|
|
|
|
|
# switch back to master
|
2019-02-02 20:54:18 +01:00
|
|
|
rustup override set master
|