summaryrefslogtreecommitdiffstats
path: root/compiler/rustc_codegen_gcc/test.sh
diff options
context:
space:
mode:
Diffstat (limited to 'compiler/rustc_codegen_gcc/test.sh')
-rwxr-xr-xcompiler/rustc_codegen_gcc/test.sh240
1 files changed, 184 insertions, 56 deletions
diff --git a/compiler/rustc_codegen_gcc/test.sh b/compiler/rustc_codegen_gcc/test.sh
index c5ffb7636..6139892ae 100755
--- a/compiler/rustc_codegen_gcc/test.sh
+++ b/compiler/rustc_codegen_gcc/test.sh
@@ -17,17 +17,20 @@ export LIBRARY_PATH="$GCC_PATH"
flags=
gcc_master_branch=1
channel="debug"
-func=all
+funcs=()
build_only=0
+nb_parts=0
+current_part=0
while [[ $# -gt 0 ]]; do
case $1 in
--release)
codegen_channel=release
+ channel="release"
shift
;;
--release-sysroot)
- sysroot_channel=release
+ sysroot_channel="--release"
shift
;;
--no-default-features)
@@ -40,43 +43,83 @@ while [[ $# -gt 0 ]]; do
flags="$flags --features $1"
shift
;;
- --release)
- channel="release"
+ "--test-rustc")
+ funcs+=(test_rustc)
shift
;;
- "--test-rustc")
- func=test_rustc
+ "--test-successful-rustc")
+ funcs+=(test_successful_rustc)
+ shift
+ ;;
+ "--test-failing-rustc")
+ funcs+=(test_failing_rustc)
shift
;;
"--test-libcore")
- func=test_libcore
+ funcs+=(test_libcore)
shift
;;
"--clean-ui-tests")
- func=clean_ui_tests
+ funcs+=(clean_ui_tests)
+ shift
+ ;;
+ "--clean")
+ funcs+=(clean)
shift
;;
"--std-tests")
- func=std_tests
+ funcs+=(std_tests)
+ shift
+ ;;
+
+ "--asm-tests")
+ funcs+=(asm_tests)
shift
;;
"--extended-tests")
- func=extended_sysroot_tests
+ funcs+=(extended_sysroot_tests)
+ shift
+ ;;
+ "--extended-rand-tests")
+ funcs+=(extended_rand_tests)
+ shift
+ ;;
+ "--extended-regex-example-tests")
+ funcs+=(extended_regex_example_tests)
+ shift
+ ;;
+ "--extended-regex-tests")
+ funcs+=(extended_regex_tests)
+ shift
+ ;;
+
+ "--mini-tests")
+ funcs+=(mini_tests)
shift
;;
"--build-sysroot")
- func=build_sysroot
+ funcs+=(build_sysroot)
shift
;;
"--build")
build_only=1
shift
;;
+ "--nb-parts")
+ shift
+ nb_parts=$1
+ shift
+ ;;
+ "--current-part")
+ shift
+ current_part=$1
+ shift
+ ;;
*)
echo "Unknown option $1"
exit 1
@@ -87,7 +130,6 @@ done
if [[ $channel == "release" ]]; then
export CHANNEL='release'
CARGO_INCREMENTAL=1 cargo rustc --release $flags
- shift
else
echo $LD_LIBRARY_PATH
export CHANNEL='debug'
@@ -95,6 +137,7 @@ else
fi
if (( $build_only == 1 )); then
+ echo "Since it's 'build-only', exiting..."
exit
fi
@@ -119,7 +162,7 @@ function mini_tests() {
function build_sysroot() {
echo "[BUILD] sysroot"
- time ./build_sysroot/build_sysroot.sh
+ time ./build_sysroot/build_sysroot.sh $sysroot_channel
}
function std_tests() {
@@ -148,17 +191,57 @@ function std_tests() {
$RUN_WRAPPER ./target/out/std_example --target $TARGET_TRIPLE
echo "[AOT] subslice-patterns-const-eval"
- $RUSTC example/subslice-patterns-const-eval.rs --crate-type bin -Cpanic=abort --target $TARGET_TRIPLE
+ $RUSTC example/subslice-patterns-const-eval.rs --crate-type bin $TEST_FLAGS --target $TARGET_TRIPLE
$RUN_WRAPPER ./target/out/subslice-patterns-const-eval
echo "[AOT] track-caller-attribute"
- $RUSTC example/track-caller-attribute.rs --crate-type bin -Cpanic=abort --target $TARGET_TRIPLE
+ $RUSTC example/track-caller-attribute.rs --crate-type bin $TEST_FLAGS --target $TARGET_TRIPLE
$RUN_WRAPPER ./target/out/track-caller-attribute
echo "[BUILD] mod_bench"
$RUSTC example/mod_bench.rs --crate-type bin --target $TARGET_TRIPLE
}
+function setup_rustc() {
+ rust_toolchain=$(cat rust-toolchain | grep channel | sed 's/channel = "\(.*\)"/\1/')
+
+ git clone https://github.com/rust-lang/rust.git || true
+ cd rust
+ git fetch
+ git checkout $(rustc -V | cut -d' ' -f3 | tr -d '(')
+ export RUSTFLAGS=
+
+ rm config.toml || true
+
+ cat > config.toml <<EOF
+[rust]
+codegen-backends = []
+deny-warnings = false
+
+[build]
+cargo = "$(which cargo)"
+local-rebuild = true
+rustc = "$HOME/.rustup/toolchains/$rust_toolchain-$TARGET_TRIPLE/bin/rustc"
+
+[target.x86_64-unknown-linux-gnu]
+llvm-filecheck = "`which FileCheck-10 || which FileCheck-11 || which FileCheck-12 || which FileCheck-13 || which FileCheck-14`"
+
+[llvm]
+download-ci-llvm = false
+EOF
+
+ rustc -V | cut -d' ' -f3 | tr -d '('
+ git checkout $(rustc -V | cut -d' ' -f3 | tr -d '(') tests
+}
+
+function asm_tests() {
+ setup_rustc
+
+ echo "[TEST] rustc test suite"
+ RUSTC_ARGS="-Zpanic-abort-tests -Csymbol-mangling-version=v0 -Zcodegen-backend="$(pwd)"/../target/"$CHANNEL"/librustc_codegen_gcc."$dylib_ext" --sysroot "$(pwd)"/../build_sysroot/sysroot -Cpanic=abort"
+ COMPILETEST_FORCE_STAGE0=1 ./x.py test --run always --stage 0 tests/assembly/asm --rustc-args "$RUSTC_ARGS"
+}
+
# FIXME(antoyo): linker gives multiple definitions error on Linux
#echo "[BUILD] sysroot in release mode"
#./build_sysroot/build_sysroot.sh --release
@@ -187,7 +270,7 @@ function test_libcore() {
#echo "[BENCH RUN] mod_bench"
#hyperfine --runs ${RUN_RUNS:-10} ./target/out/mod_bench{,_inline} ./target/out/mod_bench_llvm_*
-function extended_sysroot_tests() {
+function extended_rand_tests() {
if (( $gcc_master_branch == 0 )); then
return
fi
@@ -197,17 +280,12 @@ function extended_sysroot_tests() {
echo "[TEST] rust-random/rand"
../cargo.sh test --workspace
popd
+}
- #pushd simple-raytracer
- #echo "[BENCH COMPILE] ebobby/simple-raytracer"
- #hyperfine --runs "${RUN_RUNS:-10}" --warmup 1 --prepare "cargo clean" \
- #"RUSTC=rustc RUSTFLAGS='' cargo build" \
- #"../cargo.sh build"
-
- #echo "[BENCH RUN] ebobby/simple-raytracer"
- #cp ./target/debug/main ./raytracer_cg_gcc
- #hyperfine --runs "${RUN_RUNS:-10}" ./raytracer_cg_llvm ./raytracer_cg_gcc
- #popd
+function extended_regex_example_tests() {
+ if (( $gcc_master_branch == 0 )); then
+ return
+ fi
pushd regex
echo "[TEST] rust-lang/regex example shootout-regex-dna"
@@ -219,41 +297,43 @@ function extended_sysroot_tests() {
| ../cargo.sh run --example shootout-regex-dna \
| grep -v "Spawned thread" > res.txt
diff -u res.txt examples/regexdna-output.txt
+ popd
+}
+
+function extended_regex_tests() {
+ if (( $gcc_master_branch == 0 )); then
+ return
+ fi
+ pushd regex
echo "[TEST] rust-lang/regex tests"
+ export CG_RUSTFLAGS="--cap-lints warn" # newer aho_corasick versions throw a deprecation warning
../cargo.sh test --tests -- --exclude-should-panic --test-threads 1 -Zunstable-options -q
popd
}
-function test_rustc() {
- echo
- echo "[TEST] rust-lang/rust"
-
- rust_toolchain=$(cat rust-toolchain | grep channel | sed 's/channel = "\(.*\)"/\1/')
-
- git clone https://github.com/rust-lang/rust.git || true
- cd rust
- git fetch
- git checkout $(rustc -V | cut -d' ' -f3 | tr -d '(')
- export RUSTFLAGS=
-
- git apply ../rustc_patches/compile_test.patch || true
+function extended_sysroot_tests() {
+ #pushd simple-raytracer
+ #echo "[BENCH COMPILE] ebobby/simple-raytracer"
+ #hyperfine --runs "${RUN_RUNS:-10}" --warmup 1 --prepare "cargo clean" \
+ #"RUSTC=rustc RUSTFLAGS='' cargo build" \
+ #"../cargo.sh build"
- rm config.toml || true
+ #echo "[BENCH RUN] ebobby/simple-raytracer"
+ #cp ./target/debug/main ./raytracer_cg_gcc
+ #hyperfine --runs "${RUN_RUNS:-10}" ./raytracer_cg_llvm ./raytracer_cg_gcc
+ #popd
- cat > config.toml <<EOF
-[rust]
-codegen-backends = []
-deny-warnings = false
+ extended_rand_tests
+ extended_regex_example_tests
+ extended_regex_tests
+}
-[build]
-cargo = "$(which cargo)"
-local-rebuild = true
-rustc = "$HOME/.rustup/toolchains/$rust_toolchain-$TARGET_TRIPLE/bin/rustc"
-EOF
+function test_rustc() {
+ echo
+ echo "[TEST] rust-lang/rust"
- rustc -V | cut -d' ' -f3 | tr -d '('
- git checkout $(rustc -V | cut -d' ' -f3 | tr -d '(') tests
+ setup_rustc
for test in $(rg -i --files-with-matches "//(\[\w+\])?~|// error-pattern:|// build-fail|// run-fail|-Cllvm-args" tests/ui); do
rm $test
@@ -261,21 +341,61 @@ EOF
git checkout -- tests/ui/issues/auxiliary/issue-3136-a.rs # contains //~ERROR, but shouldn't be removed
- rm -r tests/ui/{abi*,extern/,panic-runtime/,panics/,unsized-locals/,proc-macro/,threads-sendsync/,thinlto/,borrowck/,test*,*lto*.rs} || true
- for test in $(rg --files-with-matches "catch_unwind|should_panic|thread|lto" tests/ui); do
+ rm -r tests/ui/{abi*,extern/,unsized-locals/,proc-macro/,threads-sendsync/,thinlto/,borrowck/,chalkify/bugs/,test*,*lto*.rs,consts/const-float-bits-reject-conv.rs,consts/issue-miri-1910.rs} || true
+ rm tests/ui/mir/mir_heavy_promoted.rs # this tests is oom-killed in the CI.
+ for test in $(rg --files-with-matches "thread|lto" tests/ui); do
rm $test
done
+ git checkout tests/ui/lto/auxiliary/dylib.rs
git checkout tests/ui/type-alias-impl-trait/auxiliary/cross_crate_ice.rs
git checkout tests/ui/type-alias-impl-trait/auxiliary/cross_crate_ice2.rs
+ git checkout tests/ui/macros/rfc-2011-nicer-assert-messages/auxiliary/common.rs
+
+ RUSTC_ARGS="$TEST_FLAGS -Csymbol-mangling-version=v0 -Zcodegen-backend="$(pwd)"/../target/"$CHANNEL"/librustc_codegen_gcc."$dylib_ext" --sysroot "$(pwd)"/../build_sysroot/sysroot"
+
+ if [ $# -eq 0 ]; then
+ # No argument supplied to the function. Doing nothing.
+ echo "No argument provided. Keeping all UI tests"
+ elif [ $1 = "0" ]; then
+ # Removing the failing tests.
+ xargs -a ../failing-ui-tests.txt -d'\n' rm
+ else
+ # Removing all tests.
+ find tests/ui -type f -name '*.rs' -not -path '*/auxiliary/*' -delete
+ # Putting back only the failing ones.
+ xargs -a ../failing-ui-tests.txt -d'\n' git checkout --
+ fi
- RUSTC_ARGS="-Zpanic-abort-tests -Csymbol-mangling-version=v0 -Zcodegen-backend="$(pwd)"/../target/"$CHANNEL"/librustc_codegen_gcc."$dylib_ext" --sysroot "$(pwd)"/../build_sysroot/sysroot -Cpanic=abort"
+ if [ $nb_parts -gt 0 ]; then
+ echo "Splitting ui_test into $nb_parts parts (and running part $current_part)"
+ find tests/ui -type f -name '*.rs' -not -path "*/auxiliary/*" > ui_tests
+ # To ensure it'll be always the same sub files, we sort the content.
+ sort ui_tests -o ui_tests
+ count=$((`wc -l < ui_tests` / $nb_parts))
+ # We increment the number of tests by one because if this is an odd number, we would skip
+ # one test.
+ count=$((count + 1))
+ split -d -l $count -a 1 ui_tests ui_tests.split
+ # Removing all tests.
+ find tests/ui -type f -name '*.rs' -not -path "*/auxiliary/*" -delete
+ # Putting back only the ones we want to test.
+ xargs -a "ui_tests.split$current_part" -d'\n' git checkout --
+ fi
echo "[TEST] rustc test suite"
COMPILETEST_FORCE_STAGE0=1 ./x.py test --run always --stage 0 tests/ui/ --rustc-args "$RUSTC_ARGS"
}
+function test_failing_rustc() {
+ test_rustc "1"
+}
+
+function test_successful_rustc() {
+ test_rustc "0"
+}
+
function clean_ui_tests() {
- find rust/build/x86_64-unknown-linux-gnu/test/ui/ -name stamp -exec rm -rf {} \;
+ find rust/build/x86_64-unknown-linux-gnu/test/ui/ -name stamp -delete
}
function all() {
@@ -283,9 +403,17 @@ function all() {
mini_tests
build_sysroot
std_tests
+ #asm_tests
test_libcore
extended_sysroot_tests
test_rustc
}
-$func
+if [ ${#funcs[@]} -eq 0 ]; then
+ echo "No command passed, running '--all'..."
+ all
+else
+ for t in ${funcs[@]}; do
+ $t
+ done
+fi