diff --git a/mk/tests.mk b/mk/tests.mk index 67b2a26c3af44..37ce99f4e6e8c 100644 --- a/mk/tests.mk +++ b/mk/tests.mk @@ -476,7 +476,7 @@ RFAIL_RC := $(wildcard $(S)src/test/run-fail/*.rc) RFAIL_RS := $(wildcard $(S)src/test/run-fail/*.rs) CFAIL_RC := $(wildcard $(S)src/test/compile-fail/*.rc) CFAIL_RS := $(wildcard $(S)src/test/compile-fail/*.rs) -BENCH_RS := $(wildcard $(S)src/test/bench/*.rs) +BENCH_RS := $(wildcard $(S)src/test/bench/rt/*.rs $(S)src/test/bench/shootout/*.rs $(S)src/test/bench/std/*.rs $(S)src/test/bench/*.rs) PRETTY_RS := $(wildcard $(S)src/test/pretty/*.rs) DEBUGINFO_RS := $(wildcard $(S)src/test/debug-info/*.rs) CODEGEN_RS := $(wildcard $(S)src/test/codegen/*.rs) @@ -484,7 +484,7 @@ CODEGEN_CC := $(wildcard $(S)src/test/codegen/*.cc) # perf tests are the same as bench tests only they run under # a performance monitor. -PERF_RS := $(wildcard $(S)src/test/bench/*.rs) +PERF_RS := $(BENCH_RS) RPASS_TESTS := $(RPASS_RC) $(RPASS_RS) RPASS_FULL_TESTS := $(RPASS_FULL_RC) $(RPASS_FULL_RS) @@ -516,7 +516,7 @@ CTEST_BUILD_BASE_cfail = compile-fail CTEST_MODE_cfail = compile-fail CTEST_RUNTOOL_cfail = $(CTEST_RUNTOOL) -CTEST_SRC_BASE_bench = bench +CTEST_SRC_BASE_bench = bench bench/rt bench/shootout bench/std CTEST_BUILD_BASE_bench = bench CTEST_MODE_bench = run-pass CTEST_RUNTOOL_bench = $(CTEST_RUNTOOL) @@ -610,7 +610,8 @@ define DEF_RUN_COMPILETEST CTEST_ARGS$(1)-T-$(2)-H-$(3)-$(4) := \ $$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \ - --src-base $$(S)src/test/$$(CTEST_SRC_BASE_$(4))/ \ + $(foreach base,$$(CTEST_SRC_BASE_$(4)), \ + --src-base $$(S)src/test/$$(base))/ \ --build-base $(3)/test/$$(CTEST_BUILD_BASE_$(4))/ \ --ratchet-metrics $(call TEST_RATCHET_FILE,$(1),$(2),$(3),$(4)) \ --mode $$(CTEST_MODE_$(4)) \ diff --git a/src/compiletest/common.rs b/src/compiletest/common.rs index 3ae3600cf88c6..bbe8026030f43 100644 --- a/src/compiletest/common.rs +++ b/src/compiletest/common.rs @@ -36,7 +36,7 @@ pub struct config { llvm_bin_path: Option, // The directory containing the tests to run - src_base: Path, + src_base: ~[Path], // The directory where programs should be built build_base: Path, diff --git a/src/compiletest/compiletest.rs b/src/compiletest/compiletest.rs index 8de79749b54f3..a186714fd703b 100644 --- a/src/compiletest/compiletest.rs +++ b/src/compiletest/compiletest.rs @@ -19,7 +19,7 @@ use std::os; use std::f64; use extra::getopts; -use extra::getopts::groups::{optopt, optflag, reqopt}; +use extra::getopts::groups::{optopt, optflag, reqopt, optmulti}; use extra::test; use common::config; @@ -49,19 +49,19 @@ pub fn main() { pub fn parse_config(args: ~[~str]) -> config { let groups : ~[getopts::groups::OptGroup] = - ~[reqopt("", "compile-lib-path", "path to host shared libraries", "PATH"), - reqopt("", "run-lib-path", "path to target shared libraries", "PATH"), - reqopt("", "rustc-path", "path to rustc to use for compiling", "PATH"), - optopt("", "clang-path", "path to executable for codegen tests", "PATH"), - optopt("", "llvm-bin-path", "path to directory holding llvm binaries", "DIR"), - reqopt("", "src-base", "directory to scan for test files", "PATH"), - reqopt("", "build-base", "directory to deposit test outputs", "PATH"), - reqopt("", "aux-base", "directory to find auxiliary test files", "PATH"), - reqopt("", "stage-id", "the target-stage identifier", "stageN-TARGET"), - reqopt("", "mode", "which sort of compile tests to run", - "(compile-fail|run-fail|run-pass|pretty|debug-info)"), - optflag("", "ignored", "run tests marked as ignored / xfailed"), - optopt("", "runtool", "supervisor program to run tests under \ + ~[reqopt ("", "compile-lib-path", "path to host shared libraries", "PATH"), + reqopt ("", "run-lib-path", "path to target shared libraries", "PATH"), + reqopt ("", "rustc-path", "path to rustc to use for compiling", "PATH"), + optopt ("", "clang-path", "path to executable for codegen tests", "PATH"), + optopt ("", "llvm-bin-path", "path to directory holding llvm binaries", "DIR"), + optmulti ("", "src-base", "directory to scan for test files", "PATH"), + reqopt ("", "build-base", "directory to deposit test outputs", "PATH"), + reqopt ("", "aux-base", "directory to find auxiliary test files", "PATH"), + reqopt ("", "stage-id", "the target-stage identifier", "stageN-TARGET"), + reqopt ("", "mode", "which sort of compile tests to run", + " (compile-fail|run-fail|run-pass|pretty|debug-info)"), + optflag ("", "ignored", "run tests marked as ignored / xfailed"), + optopt ("", "runtool", "supervisor program to run tests under \ (eg. emulator, valgrind)", "PROGRAM"), optopt("", "rustcflags", "flags to pass to rustc", "FLAGS"), optflag("", "verbose", "run tests verbosely, showing all output"), @@ -106,13 +106,15 @@ pub fn parse_config(args: ~[~str]) -> config { Path(getopts::opt_str(m, nm)) } + let src_base = getopts::opt_strs(matches, "src-base"); + config { compile_lib_path: getopts::opt_str(matches, "compile-lib-path"), run_lib_path: getopts::opt_str(matches, "run-lib-path"), rustc_path: opt_path(matches, "rustc-path"), clang_path: getopts::opt_maybe_str(matches, "clang-path").map_move(|s| Path(s)), llvm_bin_path: getopts::opt_maybe_str(matches, "llvm-bin-path").map_move(|s| Path(s)), - src_base: opt_path(matches, "src-base"), + src_base: src_base.iter().map(|x| Path(x.clone())).collect(), build_base: opt_path(matches, "build-base"), aux_base: opt_path(matches, "aux-base"), stage_id: getopts::opt_str(matches, "stage-id"), @@ -248,7 +250,7 @@ pub fn make_tests(config: &config) -> ~[test::TestDescAndFn] { debug!("making tests from %s", config.src_base.to_str()); let mut tests = ~[]; - let dirs = os::list_dir_path(&config.src_base); + let dirs = config.src_base.iter().flat_map(|x| os::list_dir_path(x).move_iter()).to_owned_vec(); for file in dirs.iter() { let file = file.clone(); debug!("inspecting file %s", file.to_str()); diff --git a/src/test/bench/msgsend-pipes-shared.rs b/src/test/bench/rt/msgsend-pipes-shared.rs similarity index 100% rename from src/test/bench/msgsend-pipes-shared.rs rename to src/test/bench/rt/msgsend-pipes-shared.rs diff --git a/src/test/bench/msgsend-pipes.rs b/src/test/bench/rt/msgsend-pipes.rs similarity index 100% rename from src/test/bench/msgsend-pipes.rs rename to src/test/bench/rt/msgsend-pipes.rs diff --git a/src/test/bench/msgsend-ring-mutex-arcs.rs b/src/test/bench/rt/msgsend-ring-mutex-arcs.rs similarity index 100% rename from src/test/bench/msgsend-ring-mutex-arcs.rs rename to src/test/bench/rt/msgsend-ring-mutex-arcs.rs diff --git a/src/test/bench/msgsend-ring-rw-arcs.rs b/src/test/bench/rt/msgsend-ring-rw-arcs.rs similarity index 100% rename from src/test/bench/msgsend-ring-rw-arcs.rs rename to src/test/bench/rt/msgsend-ring-rw-arcs.rs diff --git a/src/test/bench/rt-messaging-ping-pong.rs b/src/test/bench/rt/rt-messaging-ping-pong.rs similarity index 100% rename from src/test/bench/rt-messaging-ping-pong.rs rename to src/test/bench/rt/rt-messaging-ping-pong.rs diff --git a/src/test/bench/rt-parfib.rs b/src/test/bench/rt/rt-parfib.rs similarity index 100% rename from src/test/bench/rt-parfib.rs rename to src/test/bench/rt/rt-parfib.rs diff --git a/src/test/bench/rt-spawn-rate.rs b/src/test/bench/rt/rt-spawn-rate.rs similarity index 100% rename from src/test/bench/rt-spawn-rate.rs rename to src/test/bench/rt/rt-spawn-rate.rs diff --git a/src/test/bench/task-perf-alloc-unwind.rs b/src/test/bench/rt/task-perf-alloc-unwind.rs similarity index 100% rename from src/test/bench/task-perf-alloc-unwind.rs rename to src/test/bench/rt/task-perf-alloc-unwind.rs diff --git a/src/test/bench/task-perf-jargon-metal-smoke.rs b/src/test/bench/rt/task-perf-jargon-metal-smoke.rs similarity index 100% rename from src/test/bench/task-perf-jargon-metal-smoke.rs rename to src/test/bench/rt/task-perf-jargon-metal-smoke.rs diff --git a/src/test/bench/task-perf-linked-failure.rs b/src/test/bench/rt/task-perf-linked-failure.rs similarity index 100% rename from src/test/bench/task-perf-linked-failure.rs rename to src/test/bench/rt/task-perf-linked-failure.rs diff --git a/src/test/bench/task-perf-one-million.rs b/src/test/bench/rt/task-perf-one-million.rs similarity index 100% rename from src/test/bench/task-perf-one-million.rs rename to src/test/bench/rt/task-perf-one-million.rs diff --git a/src/test/bench/task-perf-spawnalot.rs b/src/test/bench/rt/task-perf-spawnalot.rs similarity index 100% rename from src/test/bench/task-perf-spawnalot.rs rename to src/test/bench/rt/task-perf-spawnalot.rs diff --git a/src/test/bench/shootout-ackermann.rs b/src/test/bench/shootout/shootout-ackermann.rs similarity index 100% rename from src/test/bench/shootout-ackermann.rs rename to src/test/bench/shootout/shootout-ackermann.rs diff --git a/src/test/bench/shootout-binarytrees.rs b/src/test/bench/shootout/shootout-binarytrees.rs similarity index 100% rename from src/test/bench/shootout-binarytrees.rs rename to src/test/bench/shootout/shootout-binarytrees.rs diff --git a/src/test/bench/shootout-chameneos-redux.rs b/src/test/bench/shootout/shootout-chameneos-redux.rs similarity index 100% rename from src/test/bench/shootout-chameneos-redux.rs rename to src/test/bench/shootout/shootout-chameneos-redux.rs diff --git a/src/test/bench/shootout-fannkuch-redux.rs b/src/test/bench/shootout/shootout-fannkuch-redux.rs similarity index 100% rename from src/test/bench/shootout-fannkuch-redux.rs rename to src/test/bench/shootout/shootout-fannkuch-redux.rs diff --git a/src/test/bench/shootout-fasta-redux.rs b/src/test/bench/shootout/shootout-fasta-redux.rs similarity index 100% rename from src/test/bench/shootout-fasta-redux.rs rename to src/test/bench/shootout/shootout-fasta-redux.rs diff --git a/src/test/bench/shootout-fasta.rs b/src/test/bench/shootout/shootout-fasta.rs similarity index 100% rename from src/test/bench/shootout-fasta.rs rename to src/test/bench/shootout/shootout-fasta.rs diff --git a/src/test/bench/shootout-fibo.rs b/src/test/bench/shootout/shootout-fibo.rs similarity index 100% rename from src/test/bench/shootout-fibo.rs rename to src/test/bench/shootout/shootout-fibo.rs diff --git a/src/test/bench/shootout-k-nucleotide-pipes.rs b/src/test/bench/shootout/shootout-k-nucleotide-pipes.rs similarity index 100% rename from src/test/bench/shootout-k-nucleotide-pipes.rs rename to src/test/bench/shootout/shootout-k-nucleotide-pipes.rs diff --git a/src/test/bench/shootout-k-nucleotide.data b/src/test/bench/shootout/shootout-k-nucleotide.data similarity index 100% rename from src/test/bench/shootout-k-nucleotide.data rename to src/test/bench/shootout/shootout-k-nucleotide.data diff --git a/src/test/bench/shootout-k-nucleotide.rs b/src/test/bench/shootout/shootout-k-nucleotide.rs similarity index 100% rename from src/test/bench/shootout-k-nucleotide.rs rename to src/test/bench/shootout/shootout-k-nucleotide.rs diff --git a/src/test/bench/shootout-mandelbrot.rs b/src/test/bench/shootout/shootout-mandelbrot.rs similarity index 100% rename from src/test/bench/shootout-mandelbrot.rs rename to src/test/bench/shootout/shootout-mandelbrot.rs diff --git a/src/test/bench/shootout-nbody.rs b/src/test/bench/shootout/shootout-nbody.rs similarity index 100% rename from src/test/bench/shootout-nbody.rs rename to src/test/bench/shootout/shootout-nbody.rs diff --git a/src/test/bench/shootout-pfib.rs b/src/test/bench/shootout/shootout-pfib.rs similarity index 100% rename from src/test/bench/shootout-pfib.rs rename to src/test/bench/shootout/shootout-pfib.rs diff --git a/src/test/bench/shootout-pidigits.rs b/src/test/bench/shootout/shootout-pidigits.rs similarity index 100% rename from src/test/bench/shootout-pidigits.rs rename to src/test/bench/shootout/shootout-pidigits.rs diff --git a/src/test/bench/shootout-reverse-complement.rs b/src/test/bench/shootout/shootout-reverse-complement.rs similarity index 100% rename from src/test/bench/shootout-reverse-complement.rs rename to src/test/bench/shootout/shootout-reverse-complement.rs diff --git a/src/test/bench/shootout-spectralnorm.rs b/src/test/bench/shootout/shootout-spectralnorm.rs similarity index 100% rename from src/test/bench/shootout-spectralnorm.rs rename to src/test/bench/shootout/shootout-spectralnorm.rs diff --git a/src/test/bench/shootout-threadring.rs b/src/test/bench/shootout/shootout-threadring.rs similarity index 100% rename from src/test/bench/shootout-threadring.rs rename to src/test/bench/shootout/shootout-threadring.rs diff --git a/src/test/bench/core-map.rs b/src/test/bench/std/core-map.rs similarity index 100% rename from src/test/bench/core-map.rs rename to src/test/bench/std/core-map.rs diff --git a/src/test/bench/core-set.rs b/src/test/bench/std/core-set.rs similarity index 100% rename from src/test/bench/core-set.rs rename to src/test/bench/std/core-set.rs diff --git a/src/test/bench/core-std.rs b/src/test/bench/std/core-std.rs similarity index 100% rename from src/test/bench/core-std.rs rename to src/test/bench/std/core-std.rs diff --git a/src/test/bench/core-uint-to-str.rs b/src/test/bench/std/core-uint-to-str.rs similarity index 100% rename from src/test/bench/core-uint-to-str.rs rename to src/test/bench/std/core-uint-to-str.rs diff --git a/src/test/bench/std-smallintmap.rs b/src/test/bench/std/std-smallintmap.rs similarity index 100% rename from src/test/bench/std-smallintmap.rs rename to src/test/bench/std/std-smallintmap.rs