2018-05-16 16:55:21 +00:00
|
|
|
set -ex
|
2018-07-28 10:14:35 +00:00
|
|
|
|
|
|
|
echo "Running clippy base tests"
|
|
|
|
|
2018-05-16 07:10:35 +00:00
|
|
|
PATH=$PATH:./node_modules/.bin
|
2018-10-12 05:59:08 +00:00
|
|
|
if [ "$TRAVIS_OS_NAME" == "linux" ]; then
|
2019-03-01 06:32:51 +00:00
|
|
|
remark -f *.md -f doc/*.md > /dev/null
|
2018-10-12 05:59:08 +00:00
|
|
|
fi
|
2018-07-28 10:14:35 +00:00
|
|
|
# build clippy in debug mode and run tests
|
2018-05-16 07:10:35 +00:00
|
|
|
cargo build --features debugging
|
|
|
|
cargo test --features debugging
|
2018-12-09 21:47:22 +00:00
|
|
|
# for faster build, share target dir between subcrates
|
|
|
|
export CARGO_TARGET_DIR=`pwd`/target/
|
2019-01-27 01:49:29 +00:00
|
|
|
(cd clippy_lints && cargo test)
|
|
|
|
(cd rustc_tools_util && cargo test)
|
|
|
|
(cd clippy_dev && cargo test)
|
2018-11-04 08:41:28 +00:00
|
|
|
|
2018-12-14 20:43:40 +00:00
|
|
|
# make sure clippy can be called via ./path/to/cargo-clippy
|
2019-01-27 01:49:29 +00:00
|
|
|
(
|
|
|
|
cd clippy_workspace_tests
|
|
|
|
../target/debug/cargo-clippy
|
|
|
|
)
|
2018-12-14 20:43:40 +00:00
|
|
|
|
2018-11-04 08:41:28 +00:00
|
|
|
# Perform various checks for lint registration
|
|
|
|
./util/dev update_lints --check
|
2018-11-27 20:11:05 +00:00
|
|
|
cargo +nightly fmt --all -- --check
|
2018-12-09 21:06:29 +00:00
|
|
|
|
2019-01-27 02:24:45 +00: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 21:06:29 +00:00
|
|
|
# make sure tests are formatted
|
|
|
|
|
|
|
|
# some lints are sensitive to formatting, exclude some files
|
2018-12-27 15:17:45 +00:00
|
|
|
tests_need_reformatting="false"
|
2018-12-27 11:16:08 +00:00
|
|
|
# switch to nightly
|
2019-02-02 19:54:18 +00:00
|
|
|
rustup override set nightly
|
2018-12-27 11:40:07 +00:00
|
|
|
# avoid loop spam and allow cmds with exit status != 0
|
|
|
|
set +ex
|
|
|
|
|
2019-04-09 18:53:38 +00: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 11:40:07 +00:00
|
|
|
rustfmt ${file} --check
|
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
echo "${file} needs reformatting!"
|
2018-12-27 15:17:45 +00:00
|
|
|
tests_need_reformatting="true"
|
2018-12-27 11:40:07 +00:00
|
|
|
fi
|
2018-12-09 21:06:29 +00:00
|
|
|
done
|
|
|
|
|
2018-12-27 11:40:07 +00:00
|
|
|
set -ex # reset
|
|
|
|
|
2018-12-27 15:17:45 +00:00
|
|
|
if [ "${tests_need_reformatting}" == "true" ] ; then
|
2018-12-10 05:27:19 +00:00
|
|
|
echo "Tests need reformatting!"
|
2018-12-09 21:06:29 +00:00
|
|
|
exit 2
|
|
|
|
fi
|
2018-12-27 11:40:07 +00:00
|
|
|
|
|
|
|
# switch back to master
|
2019-02-02 19:54:18 +00:00
|
|
|
rustup override set master
|