2020-02-07 21:24:41 +00:00
|
|
|
#!/bin/bash
|
2020-01-26 14:13:14 +00:00
|
|
|
|
|
|
|
set -ex
|
|
|
|
|
|
|
|
# Check sysroot handling
|
|
|
|
sysroot=$(./target/debug/clippy-driver --print sysroot)
|
|
|
|
test "$sysroot" = "$(rustc --print sysroot)"
|
|
|
|
|
|
|
|
if [[ ${OS} == "Windows" ]]; then
|
2020-10-28 22:36:07 +00:00
|
|
|
desired_sysroot=C:/tmp
|
2020-01-26 14:13:14 +00:00
|
|
|
else
|
2020-10-28 22:36:07 +00:00
|
|
|
desired_sysroot=/tmp
|
2020-01-26 14:13:14 +00:00
|
|
|
fi
|
2024-01-26 00:08:43 +00:00
|
|
|
# Set --sysroot in command line
|
2020-01-26 14:13:14 +00:00
|
|
|
sysroot=$(./target/debug/clippy-driver --sysroot $desired_sysroot --print sysroot)
|
|
|
|
test "$sysroot" = $desired_sysroot
|
|
|
|
|
2024-01-26 00:08:43 +00:00
|
|
|
# Set --sysroot in arg_file.txt and pass @arg_file.txt to command line
|
|
|
|
echo "--sysroot=$desired_sysroot" > arg_file.txt
|
|
|
|
sysroot=$(./target/debug/clippy-driver @arg_file.txt --print sysroot)
|
|
|
|
test "$sysroot" = $desired_sysroot
|
|
|
|
|
|
|
|
# Setting SYSROOT in command line
|
2020-01-26 14:13:14 +00:00
|
|
|
sysroot=$(SYSROOT=$desired_sysroot ./target/debug/clippy-driver --print sysroot)
|
|
|
|
test "$sysroot" = $desired_sysroot
|
|
|
|
|
2023-01-12 18:48:13 +00:00
|
|
|
# Check that the --sysroot argument is only passed once (SYSROOT is ignored)
|
|
|
|
(
|
|
|
|
cd rustc_tools_util
|
|
|
|
touch src/lib.rs
|
|
|
|
SYSROOT=/tmp RUSTFLAGS="--sysroot=$(rustc --print sysroot)" ../target/debug/cargo-clippy clippy --verbose
|
|
|
|
)
|
|
|
|
|
2024-01-26 00:08:43 +00:00
|
|
|
# Check that the --sysroot argument is only passed once via arg_file.txt (SYSROOT is ignored)
|
|
|
|
(
|
|
|
|
echo "fn main() {}" > target/driver_test.rs
|
|
|
|
echo "--sysroot="$(./target/debug/clippy-driver --print sysroot)"" > arg_file.txt
|
|
|
|
echo "--verbose" >> arg_file.txt
|
|
|
|
SYSROOT=/tmp ./target/debug/clippy-driver @arg_file.txt ./target/driver_test.rs
|
|
|
|
)
|
|
|
|
|
2020-01-26 14:13:14 +00:00
|
|
|
# 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
|
|
|
|
# FIXME: How to match the clippy invocation in compile-test.rs?
|
2020-10-28 22:36:07 +00:00
|
|
|
./target/debug/clippy-driver -Dwarnings -Aunused -Zui-testing --emit metadata --crate-type bin tests/ui/double_neg.rs 2>double_neg.stderr && exit 1
|
2023-09-07 20:12:40 +00:00
|
|
|
sed -e "s,tests/ui,\$DIR," -e "/= help: for/d" double_neg.stderr > normalized.stderr
|
2020-11-05 13:29:48 +00:00
|
|
|
diff -u normalized.stderr tests/ui/double_neg.stderr
|
2020-06-23 15:05:22 +00:00
|
|
|
|
|
|
|
# make sure "clippy-driver --rustc --arg" and "rustc --arg" behave the same
|
2020-10-28 22:36:07 +00:00
|
|
|
SYSROOT=$(rustc --print sysroot)
|
2020-11-05 13:29:48 +00:00
|
|
|
diff -u <(LD_LIBRARY_PATH=${SYSROOT}/lib ./target/debug/clippy-driver --rustc --version --verbose) <(rustc --version --verbose)
|
2020-06-23 15:05:22 +00:00
|
|
|
|
2020-10-28 22:36:07 +00:00
|
|
|
echo "fn main() {}" >target/driver_test.rs
|
2020-06-23 15:05:22 +00:00
|
|
|
# we can't run 2 rustcs on the same file at the same time
|
2020-10-28 22:36:07 +00:00
|
|
|
CLIPPY=$(LD_LIBRARY_PATH=${SYSROOT}/lib ./target/debug/clippy-driver ./target/driver_test.rs --rustc)
|
|
|
|
RUSTC=$(rustc ./target/driver_test.rs)
|
2020-11-05 13:29:48 +00:00
|
|
|
diff -u <($CLIPPY) <($RUSTC)
|
2020-06-23 15:05:22 +00:00
|
|
|
|
2020-01-26 14:13:14 +00:00
|
|
|
# TODO: CLIPPY_CONF_DIR / CARGO_MANIFEST_DIR
|