1 # Copyright 2012 The Rust Project Developers. See the COPYRIGHT
2 # file at the top-level directory of this distribution and at
3 # http://rust-lang.org/COPYRIGHT.
5 # Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6 # http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7 # <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8 # option. This file may not be copied, modified, or distributed
9 # except according to those terms.
12 ######################################################################
14 ######################################################################
16 # The names of crates that must be tested
17 TEST_TARGET_CRATES = $(TARGET_CRATES)
18 TEST_DOC_CRATES = $(DOC_CRATES)
19 TEST_HOST_CRATES = $(HOST_CRATES)
20 TEST_CRATES = $(TEST_TARGET_CRATES) $(TEST_HOST_CRATES)
22 ######################################################################
23 # Environment configuration
24 ######################################################################
26 # The arguments to all test runners
28 TESTARGS += $(TESTNAME)
37 # Arguments to the cfail/rfail/rpass/bench tests
39 CTEST_RUNTOOL = --runtool "$(CFG_VALGRIND)"
47 # Arguments to the perf tests
49 CTEST_PERF_RUNTOOL = --runtool "$(CFG_PERF_TOOL)"
52 CTEST_TESTARGS := $(TESTARGS)
55 CTEST_TESTARGS += --verbose
58 # If we're running perf then set this environment variable
59 # to put the benchmarks into 'hard mode'
60 ifeq ($(MAKECMDGOALS),perf)
65 TEST_LOG_FILE=tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4).log
66 TEST_OK_FILE=tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4).ok
68 TEST_RATCHET_FILE=tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4)-metrics.json
69 TEST_RATCHET_NOISE_PERCENT=10.0
71 # Whether to ratchet or merely save benchmarks
72 ifdef CFG_RATCHET_BENCH
73 CRATE_TEST_EXTRA_ARGS=\
74 --test $(TEST_BENCH) \
75 --ratchet-metrics $(call TEST_RATCHET_FILE,$(1),$(2),$(3),$(4)) \
76 --ratchet-noise-percent $(TEST_RATCHET_NOISE_PERCENT)
78 CRATE_TEST_EXTRA_ARGS=\
79 --test $(TEST_BENCH) \
80 --save-metrics $(call TEST_RATCHET_FILE,$(1),$(2),$(3),$(4))
83 # If we're sharding the testsuite between parallel testers,
84 # pass this argument along to the compiletest and crate test
87 CTEST_TESTARGS += --test-shard=$(TEST_SHARD)
88 CRATE_TEST_EXTRA_ARGS += --test-shard=$(TEST_SHARD)
91 define DEF_TARGET_COMMANDS
94 CFG_RUN_TEST_$(1)=$$(call CFG_RUN_$(1),,$$(CFG_VALGRIND) $$(1))
97 ifdef CFG_WINDOWSY_$(1)
98 CFG_TESTLIB_$(1)=$$(CFG_BUILD_DIR)$$(2)/$$(strip \
99 $$(if $$(findstring stage0,$$(1)), \
100 stage0/$$(CFG_LIBDIR_RELATIVE), \
101 $$(if $$(findstring stage1,$$(1)), \
102 stage1/$$(CFG_LIBDIR_RELATIVE), \
103 $$(if $$(findstring stage2,$$(1)), \
104 stage2/$$(CFG_LIBDIR_RELATIVE), \
105 $$(if $$(findstring stage3,$$(1)), \
106 stage3/$$(CFG_LIBDIR_RELATIVE), \
107 )))))/rustlib/$$(CFG_BUILD)/lib
108 CFG_RUN_TEST_$(1)=$$(call CFG_RUN_$(1),$$(call CFG_TESTLIB_$(1),$$(1),$$(3)),$$(1))
111 # Run the compiletest runner itself under valgrind
113 CFG_RUN_CTEST_$(1)=$$(RPATH_VAR$$(1)_T_$$(3)_H_$$(3)) \
114 $$(call CFG_RUN_TEST_$$(CFG_BUILD),$$(2),$$(3))
116 CFG_RUN_CTEST_$(1)=$$(RPATH_VAR$$(1)_T_$$(3)_H_$$(3)) \
117 $$(call CFG_RUN_$$(CFG_BUILD),$$(TLIB$$(1)_T_$$(3)_H_$$(3)),$$(2))
122 $(foreach target,$(CFG_TARGET), \
123 $(eval $(call DEF_TARGET_COMMANDS,$(target))))
125 # Target platform specific variables
126 # for arm-linux-androidabi
127 define DEF_ADB_DEVICE_STATUS
128 CFG_ADB_DEVICE_STATUS=$(1)
131 $(foreach target,$(CFG_TARGET), \
132 $(if $(findstring $(target),"arm-linux-androideabi"), \
133 $(if $(findstring adb,$(CFG_ADB)), \
134 $(if $(findstring device,$(shell $(CFG_ADB) devices 2>/dev/null | grep -E '^[:_A-Za-z0-9-]+[[:blank:]]+device')), \
135 $(info check: android device attached) \
136 $(eval $(call DEF_ADB_DEVICE_STATUS, true)), \
137 $(info check: android device not attached) \
138 $(eval $(call DEF_ADB_DEVICE_STATUS, false)) \
140 $(info check: adb not found) \
141 $(eval $(call DEF_ADB_DEVICE_STATUS, false)) \
146 ifeq ($(CFG_ADB_DEVICE_STATUS),true)
147 CFG_ADB_TEST_DIR=/data/tmp
149 $(info check: android device test dir $(CFG_ADB_TEST_DIR) ready \
150 $(shell $(CFG_ADB) remount 1>/dev/null) \
151 $(shell $(CFG_ADB) shell rm -r $(CFG_ADB_TEST_DIR) >/dev/null) \
152 $(shell $(CFG_ADB) shell mkdir $(CFG_ADB_TEST_DIR)) \
153 $(shell $(CFG_ADB) shell mkdir $(CFG_ADB_TEST_DIR)/tmp) \
154 $(shell $(CFG_ADB) push $(S)src/etc/adb_run_wrapper.sh $(CFG_ADB_TEST_DIR) 1>/dev/null) \
155 $(foreach crate,$(TARGET_CRATES),\
156 $(shell $(CFG_ADB) push $(TLIB2_T_arm-linux-androideabi_H_$(CFG_BUILD))/$(call CFG_LIB_GLOB_arm-linux-androideabi,$(crate)) \
157 $(CFG_ADB_TEST_DIR)))\
164 ######################################################################
166 ######################################################################
168 check: cleantmptestlogs cleantestlibs tidy check-notidy
170 check-notidy: cleantmptestlogs cleantestlibs all check-stage2
171 $(Q)$(CFG_PYTHON) $(S)src/etc/check-summary.py tmp/*.log
173 check-lite: cleantestlibs cleantmptestlogs \
174 $(foreach crate,$(TARGET_CRATES),check-stage2-$(crate)) \
176 check-stage2-rfail check-stage2-cfail check-stage2-rmake
177 $(Q)$(CFG_PYTHON) $(S)src/etc/check-summary.py tmp/*.log
179 check-ref: cleantestlibs cleantmptestlogs check-stage2-rpass \
180 check-stage2-rfail check-stage2-cfail check-stage2-rmake
181 $(Q)$(CFG_PYTHON) $(S)src/etc/check-summary.py tmp/*.log
183 check-docs: cleantestlibs cleantmptestlogs check-stage2-docs
184 $(Q)$(CFG_PYTHON) $(S)src/etc/check-summary.py tmp/*.log
186 # NOTE: Remove after reprogramming windows bots
187 check-fast: check-lite
189 .PHONY: cleantmptestlogs cleantestlibs
195 $(Q)find $(CFG_BUILD)/test \
196 -name '*.[odasS]' -o \
203 -name '*.libaux' -o \
206 -name '*.debugger.script' \
210 ######################################################################
212 ######################################################################
218 ALL_CS := $(wildcard $(S)src/rt/*.cpp \
220 $(S)src/rt/*/*/*.cpp \
221 $(S)src/rustllvm/*.cpp)
222 ALL_CS := $(filter-out $(S)src/rt/miniz.cpp \
223 $(wildcard $(S)src/rt/hoedown/src/*.c) \
224 $(wildcard $(S)src/rt/hoedown/bin/*.c) \
226 ALL_HS := $(wildcard $(S)src/rt/*.h \
229 $(S)src/rustllvm/*.h)
230 ALL_HS := $(filter-out $(S)src/rt/valgrind/valgrind.h \
231 $(S)src/rt/valgrind/memcheck.h \
232 $(S)src/rt/msvc/typeof.h \
233 $(S)src/rt/msvc/stdint.h \
234 $(S)src/rt/msvc/inttypes.h \
235 $(wildcard $(S)src/rt/hoedown/src/*.h) \
236 $(wildcard $(S)src/rt/hoedown/bin/*.h) \
239 # Run the tidy script in multiple parts to avoid huge 'echo' commands
241 @$(call E, check: formatting)
242 $(Q)find $(S)src -name '*.r[sc]' \
243 | grep '^$(S)src/jemalloc' -v \
244 | grep '^$(S)src/libuv' -v \
245 | grep '^$(S)src/llvm' -v \
246 | grep '^$(S)src/gyp' -v \
247 | grep '^$(S)src/libbacktrace' -v \
248 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
249 $(Q)find $(S)src/etc -name '*.py' \
250 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
251 $(Q)find $(S)src/doc -name '*.js' \
252 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
253 $(Q)find $(S)src/etc -name '*.sh' \
254 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
255 $(Q)find $(S)src/etc -name '*.pl' \
256 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
257 $(Q)find $(S)src/etc -name '*.c' \
258 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
259 $(Q)find $(S)src/etc -name '*.h' \
260 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
262 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
264 | xargs -n 10 $(CFG_PYTHON) $(S)src/etc/tidy.py
265 $(Q)find $(S)src -type f -perm +111 \
266 -not -name '*.rs' -and -not -name '*.py' \
267 -and -not -name '*.sh' \
268 | grep '^$(S)src/jemalloc' -v \
269 | grep '^$(S)src/libuv' -v \
270 | grep '^$(S)src/llvm' -v \
271 | grep '^$(S)src/rt/hoedown' -v \
272 | grep '^$(S)src/gyp' -v \
273 | grep '^$(S)src/etc' -v \
274 | grep '^$(S)src/doc' -v \
275 | grep '^$(S)src/compiler-rt' -v \
276 | grep '^$(S)src/libbacktrace' -v \
277 | xargs $(CFG_PYTHON) $(S)src/etc/check-binaries.py
282 ######################################################################
284 ######################################################################
288 check-stage$(1)-T-$(2)-H-$(3)-exec: \
289 check-stage$(1)-T-$(2)-H-$(3)-rpass-exec \
290 check-stage$(1)-T-$(2)-H-$(3)-rfail-exec \
291 check-stage$(1)-T-$(2)-H-$(3)-cfail-exec \
292 check-stage$(1)-T-$(2)-H-$(3)-rpass-full-exec \
293 check-stage$(1)-T-$(2)-H-$(3)-cfail-full-exec \
294 check-stage$(1)-T-$(2)-H-$(3)-rmake-exec \
295 check-stage$(1)-T-$(2)-H-$(3)-crates-exec \
296 check-stage$(1)-T-$(2)-H-$(3)-doc-crates-exec \
297 check-stage$(1)-T-$(2)-H-$(3)-bench-exec \
298 check-stage$(1)-T-$(2)-H-$(3)-debuginfo-gdb-exec \
299 check-stage$(1)-T-$(2)-H-$(3)-debuginfo-lldb-exec \
300 check-stage$(1)-T-$(2)-H-$(3)-codegen-exec \
301 check-stage$(1)-T-$(2)-H-$(3)-doc-exec \
302 check-stage$(1)-T-$(2)-H-$(3)-pretty-exec
304 # Only test the compiler-dependent crates when the target is
305 # able to build a compiler (when the target triple is in the set of host triples)
306 ifneq ($$(findstring $(2),$$(CFG_HOST)),)
308 check-stage$(1)-T-$(2)-H-$(3)-crates-exec: \
309 $$(foreach crate,$$(TEST_CRATES), \
310 check-stage$(1)-T-$(2)-H-$(3)-$$(crate)-exec)
314 check-stage$(1)-T-$(2)-H-$(3)-crates-exec: \
315 $$(foreach crate,$$(TEST_TARGET_CRATES), \
316 check-stage$(1)-T-$(2)-H-$(3)-$$(crate)-exec)
320 check-stage$(1)-T-$(2)-H-$(3)-doc-crates-exec: \
321 $$(foreach crate,$$(TEST_DOC_CRATES), \
322 check-stage$(1)-T-$(2)-H-$(3)-doc-crate-$$(crate)-exec)
324 check-stage$(1)-T-$(2)-H-$(3)-doc-exec: \
325 $$(foreach docname,$$(DOCS), \
326 check-stage$(1)-T-$(2)-H-$(3)-doc-$$(docname)-exec)
328 check-stage$(1)-T-$(2)-H-$(3)-pretty-exec: \
329 check-stage$(1)-T-$(2)-H-$(3)-pretty-rpass-exec \
330 check-stage$(1)-T-$(2)-H-$(3)-pretty-rpass-full-exec \
331 check-stage$(1)-T-$(2)-H-$(3)-pretty-rfail-exec \
332 check-stage$(1)-T-$(2)-H-$(3)-pretty-bench-exec \
333 check-stage$(1)-T-$(2)-H-$(3)-pretty-pretty-exec
337 $(foreach host,$(CFG_HOST), \
338 $(foreach target,$(CFG_TARGET), \
339 $(foreach stage,$(STAGES), \
340 $(eval $(call DEF_TEST_SETS,$(stage),$(target),$(host))))))
343 ######################################################################
345 ######################################################################
349 # If NO_REBUILD is set then break the dependencies on everything but
350 # the source files so we can test crates without rebuilding any of the
352 ifeq ($(NO_REBUILD),)
353 TESTDEP_$(1)_$(2)_$(3)_$(4) = $$(SREQ$(1)_T_$(2)_H_$(3)) \
354 $$(foreach crate,$$(TARGET_CRATES),\
355 $$(TLIB$(1)_T_$(2)_H_$(3))/stamp.$$(crate)) \
356 $$(CRATE_FULLDEPS_$(1)_T_$(2)_H_$(3)_$(4))
358 # The regex crate depends on the regex_macros crate during testing, but it
359 # notably depend on the *host* regex_macros crate, not the target version.
360 # Additionally, this is not a dependency in stage1, only in stage2.
363 TESTDEP_$(1)_$(2)_$(3)_$(4) += $$(TLIB$(1)_T_$(3)_H_$(3))/stamp.regex_macros
368 TESTDEP_$(1)_$(2)_$(3)_$(4) = $$(RSINPUTS_$(4))
371 $(3)/stage$(1)/test/$(4)test-$(2)$$(X_$(2)): CFG_COMPILER_HOST_TRIPLE = $(2)
372 $(3)/stage$(1)/test/$(4)test-$(2)$$(X_$(2)): \
374 $$(TESTDEP_$(1)_$(2)_$(3)_$(4))
375 @$$(call E, oxidize: $$@)
376 $$(STAGE$(1)_T_$(2)_H_$(3)) -o $$@ $$< --test \
377 -L "$$(RT_OUTPUT_DIR_$(2))" \
378 -L "$$(LLVM_LIBDIR_$(2))"
382 $(foreach host,$(CFG_HOST), \
383 $(eval $(foreach target,$(CFG_TARGET), \
384 $(eval $(foreach stage,$(STAGES), \
385 $(eval $(foreach crate,$(TEST_CRATES), \
386 $(eval $(call TEST_RUNNER,$(stage),$(target),$(host),$(crate))))))))))
388 define DEF_TEST_CRATE_RULES
389 check-stage$(1)-T-$(2)-H-$(3)-$(4)-exec: $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4))
391 $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4)): \
392 $(3)/stage$(1)/test/$(4)test-$(2)$$(X_$(2))
393 @$$(call E, run: $$<)
394 $$(Q)$$(call CFG_RUN_TEST_$(2),$$<,$(2),$(3)) $$(TESTARGS) \
395 --logfile $$(call TEST_LOG_FILE,$(1),$(2),$(3),$(4)) \
396 $$(call CRATE_TEST_EXTRA_ARGS,$(1),$(2),$(3),$(4)) \
400 define DEF_TEST_CRATE_RULES_arm-linux-androideabi
401 check-stage$(1)-T-$(2)-H-$(3)-$(4)-exec: $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4))
403 $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4)): \
404 $(3)/stage$(1)/test/$(4)test-$(2)$$(X_$(2))
405 @$$(call E, run: $$< via adb)
406 $$(Q)$(CFG_ADB) push $$< $(CFG_ADB_TEST_DIR)
407 $$(Q)$(CFG_ADB) shell '(cd $(CFG_ADB_TEST_DIR); LD_LIBRARY_PATH=. \
409 --logfile $(CFG_ADB_TEST_DIR)/check-stage$(1)-T-$(2)-H-$(3)-$(4).log \
410 $$(call CRATE_TEST_EXTRA_ARGS,$(1),$(2),$(3),$(4)) $(TESTARGS))' \
411 > tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4).tmp
412 $$(Q)cat tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4).tmp
413 $$(Q)touch tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4).log
414 $$(Q)$(CFG_ADB) pull $(CFG_ADB_TEST_DIR)/check-stage$(1)-T-$(2)-H-$(3)-$(4).log tmp/
415 $$(Q)$(CFG_ADB) shell rm $(CFG_ADB_TEST_DIR)/check-stage$(1)-T-$(2)-H-$(3)-$(4).log
416 $$(Q)$(CFG_ADB) pull $(CFG_ADB_TEST_DIR)/$$(call TEST_RATCHET_FILE,$(1),$(2),$(3),$(4)) tmp/
417 @if grep -q "result: ok" tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4).tmp; \
419 rm tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4).tmp; \
422 rm tmp/check-stage$(1)-T-$(2)-H-$(3)-$(4).tmp; \
427 define DEF_TEST_CRATE_RULES_null
428 check-stage$(1)-T-$(2)-H-$(3)-$(4)-exec: $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4))
430 $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4)): \
431 $(3)/stage$(1)/test/$(4)test-$(2)$$(X_$(2))
432 @$$(call E, failing: no device for $$< )
436 $(foreach host,$(CFG_HOST), \
437 $(foreach target,$(CFG_TARGET), \
438 $(foreach stage,$(STAGES), \
439 $(foreach crate, $(TEST_CRATES), \
440 $(if $(findstring $(target),$(CFG_BUILD)), \
441 $(eval $(call DEF_TEST_CRATE_RULES,$(stage),$(target),$(host),$(crate))), \
442 $(if $(findstring $(target),"arm-linux-androideabi"), \
443 $(if $(findstring $(CFG_ADB_DEVICE_STATUS),"true"), \
444 $(eval $(call DEF_TEST_CRATE_RULES_arm-linux-androideabi,$(stage),$(target),$(host),$(crate))), \
445 $(eval $(call DEF_TEST_CRATE_RULES_null,$(stage),$(target),$(host),$(crate))) \
447 $(eval $(call DEF_TEST_CRATE_RULES,$(stage),$(target),$(host),$(crate))) \
450 ######################################################################
451 # Rules for the compiletest tests (rpass, rfail, etc.)
452 ######################################################################
454 RPASS_RC := $(wildcard $(S)src/test/run-pass/*.rc)
455 RPASS_RS := $(wildcard $(S)src/test/run-pass/*.rs)
456 RPASS_FULL_RC := $(wildcard $(S)src/test/run-pass-fulldeps/*.rc)
457 RPASS_FULL_RS := $(wildcard $(S)src/test/run-pass-fulldeps/*.rs)
458 CFAIL_FULL_RC := $(wildcard $(S)src/test/compile-fail-fulldeps/*.rc)
459 CFAIL_FULL_RS := $(wildcard $(S)src/test/compile-fail-fulldeps/*.rs)
460 RFAIL_RC := $(wildcard $(S)src/test/run-fail/*.rc)
461 RFAIL_RS := $(wildcard $(S)src/test/run-fail/*.rs)
462 CFAIL_RC := $(wildcard $(S)src/test/compile-fail/*.rc)
463 CFAIL_RS := $(wildcard $(S)src/test/compile-fail/*.rs)
464 BENCH_RS := $(wildcard $(S)src/test/bench/*.rs)
465 PRETTY_RS := $(wildcard $(S)src/test/pretty/*.rs)
466 DEBUGINFO_GDB_RS := $(wildcard $(S)src/test/debuginfo/*.rs)
467 DEBUGINFO_LLDB_RS := $(wildcard $(S)src/test/debuginfo/*.rs)
468 CODEGEN_RS := $(wildcard $(S)src/test/codegen/*.rs)
469 CODEGEN_CC := $(wildcard $(S)src/test/codegen/*.cc)
471 # perf tests are the same as bench tests only they run under
472 # a performance monitor.
473 PERF_RS := $(wildcard $(S)src/test/bench/*.rs)
475 RPASS_TESTS := $(RPASS_RC) $(RPASS_RS)
476 RPASS_FULL_TESTS := $(RPASS_FULL_RC) $(RPASS_FULL_RS)
477 CFAIL_FULL_TESTS := $(CFAIL_FULL_RC) $(CFAIL_FULL_RS)
478 RFAIL_TESTS := $(RFAIL_RC) $(RFAIL_RS)
479 CFAIL_TESTS := $(CFAIL_RC) $(CFAIL_RS)
480 BENCH_TESTS := $(BENCH_RS)
481 PERF_TESTS := $(PERF_RS)
482 PRETTY_TESTS := $(PRETTY_RS)
483 DEBUGINFO_GDB_TESTS := $(DEBUGINFO_GDB_RS)
484 DEBUGINFO_LLDB_TESTS := $(DEBUGINFO_LLDB_RS)
485 CODEGEN_TESTS := $(CODEGEN_RS) $(CODEGEN_CC)
487 CTEST_SRC_BASE_rpass = run-pass
488 CTEST_BUILD_BASE_rpass = run-pass
489 CTEST_MODE_rpass = run-pass
490 CTEST_RUNTOOL_rpass = $(CTEST_RUNTOOL)
492 CTEST_SRC_BASE_rpass-full = run-pass-fulldeps
493 CTEST_BUILD_BASE_rpass-full = run-pass-fulldeps
494 CTEST_MODE_rpass-full = run-pass
495 CTEST_RUNTOOL_rpass-full = $(CTEST_RUNTOOL)
497 CTEST_SRC_BASE_cfail-full = compile-fail-fulldeps
498 CTEST_BUILD_BASE_cfail-full = compile-fail-fulldeps
499 CTEST_MODE_cfail-full = compile-fail
500 CTEST_RUNTOOL_cfail-full = $(CTEST_RUNTOOL)
502 CTEST_SRC_BASE_rfail = run-fail
503 CTEST_BUILD_BASE_rfail = run-fail
504 CTEST_MODE_rfail = run-fail
505 CTEST_RUNTOOL_rfail = $(CTEST_RUNTOOL)
507 CTEST_SRC_BASE_cfail = compile-fail
508 CTEST_BUILD_BASE_cfail = compile-fail
509 CTEST_MODE_cfail = compile-fail
510 CTEST_RUNTOOL_cfail = $(CTEST_RUNTOOL)
512 CTEST_SRC_BASE_bench = bench
513 CTEST_BUILD_BASE_bench = bench
514 CTEST_MODE_bench = run-pass
515 CTEST_RUNTOOL_bench = $(CTEST_RUNTOOL)
517 CTEST_SRC_BASE_perf = bench
518 CTEST_BUILD_BASE_perf = perf
519 CTEST_MODE_perf = run-pass
520 CTEST_RUNTOOL_perf = $(CTEST_PERF_RUNTOOL)
522 CTEST_SRC_BASE_debuginfo-gdb = debuginfo
523 CTEST_BUILD_BASE_debuginfo-gdb = debuginfo-gdb
524 CTEST_MODE_debuginfo-gdb = debuginfo-gdb
525 CTEST_RUNTOOL_debuginfo-gdb = $(CTEST_RUNTOOL)
527 CTEST_SRC_BASE_debuginfo-lldb = debuginfo
528 CTEST_BUILD_BASE_debuginfo-lldb = debuginfo-lldb
529 CTEST_MODE_debuginfo-lldb = debuginfo-lldb
530 CTEST_RUNTOOL_debuginfo-lldb = $(CTEST_RUNTOOL)
532 CTEST_SRC_BASE_codegen = codegen
533 CTEST_BUILD_BASE_codegen = codegen
534 CTEST_MODE_codegen = codegen
535 CTEST_RUNTOOL_codegen = $(CTEST_RUNTOOL)
537 # CTEST_DISABLE_$(TEST_GROUP), if set, will cause the test group to be
538 # disabled and the associated message to be printed as a warning
539 # during attempts to run those tests.
542 CTEST_DISABLE_debuginfo-gdb = "no gdb found"
546 CTEST_DISABLE_debuginfo-lldb = "no lldb found"
549 # Completely disable LLDB tests for now
550 CTEST_DISABLE_debuginfo-lldb = "LLDB tests are not enabled yet"
553 CTEST_DISABLE_codegen = "no clang found"
556 ifeq ($(CFG_OSTYPE),apple-darwin)
557 CTEST_DISABLE_debuginfo-gdb = "gdb on darwing needs root"
560 # CTEST_DISABLE_NONSELFHOST_$(TEST_GROUP), if set, will cause that
561 # test group to be disabled *unless* the target is able to build a
562 # compiler (i.e. when the target triple is in the set of of host
563 # triples). The associated message will be printed as a warning
564 # during attempts to run those tests.
566 define DEF_CTEST_VARS
568 # All the per-stage build rules you might want to call from the
571 # $(1) is the stage number
572 # $(2) is the target triple to test
573 # $(3) is the host triple to test
575 # Prerequisites for compiletest tests
576 TEST_SREQ$(1)_T_$(2)_H_$(3) = \
577 $$(HBIN$(1)_H_$(3))/compiletest$$(X_$(3)) \
578 $$(SREQ$(1)_T_$(2)_H_$(3))
580 # Rules for the cfail/rfail/rpass/bench/perf test runner
582 # The tests select when to use debug configuration on their own;
583 # remove directive, if present, from CFG_RUSTC_FLAGS (issue #7898).
584 CTEST_RUSTC_FLAGS := $$(subst --cfg ndebug,,$$(CFG_RUSTC_FLAGS))
586 # The tests can not be optimized while the rest of the compiler is optimized, so
587 # filter out the optimization (if any) from rustc and then figure out if we need
589 CTEST_RUSTC_FLAGS := $$(subst -O,,$$(CTEST_RUSTC_FLAGS))
590 ifndef CFG_DISABLE_OPTIMIZE_TESTS
591 CTEST_RUSTC_FLAGS += -O
594 CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3) := \
595 --compile-lib-path $$(HLIB$(1)_H_$(3)) \
596 --run-lib-path $$(TLIB$(1)_T_$(2)_H_$(3)) \
597 --rustc-path $$(HBIN$(1)_H_$(3))/rustc$$(X_$(3)) \
598 --clang-path $(if $(CFG_CLANG),$(CFG_CLANG),clang) \
599 --llvm-bin-path $(CFG_LLVM_INST_DIR_$(CFG_BUILD))/bin \
600 --aux-base $$(S)src/test/auxiliary/ \
601 --stage-id stage$(1)-$(2) \
604 --android-cross-path=$(CFG_ANDROID_CROSS_PATH) \
605 --adb-path=$(CFG_ADB) \
606 --adb-test-dir=$(CFG_ADB_TEST_DIR) \
607 --host-rustcflags "$(RUSTC_FLAGS_$(3)) $$(CTEST_RUSTC_FLAGS) -L $$(RT_OUTPUT_DIR_$(3))" \
608 --lldb-python-dir=$(CFG_LLDB_PYTHON_DIR) \
609 --target-rustcflags "$(RUSTC_FLAGS_$(2)) $$(CTEST_RUSTC_FLAGS) -L $$(RT_OUTPUT_DIR_$(2))" \
612 CTEST_DEPS_rpass_$(1)-T-$(2)-H-$(3) = $$(RPASS_TESTS)
613 CTEST_DEPS_rpass-full_$(1)-T-$(2)-H-$(3) = $$(RPASS_FULL_TESTS) $$(CSREQ$(1)_T_$(3)_H_$(3)) $$(SREQ$(1)_T_$(2)_H_$(3))
614 CTEST_DEPS_cfail-full_$(1)-T-$(2)-H-$(3) = $$(CFAIL_FULL_TESTS) $$(CSREQ$(1)_T_$(3)_H_$(3)) $$(SREQ$(1)_T_$(2)_H_$(3))
615 CTEST_DEPS_rfail_$(1)-T-$(2)-H-$(3) = $$(RFAIL_TESTS)
616 CTEST_DEPS_cfail_$(1)-T-$(2)-H-$(3) = $$(CFAIL_TESTS)
617 CTEST_DEPS_bench_$(1)-T-$(2)-H-$(3) = $$(BENCH_TESTS)
618 CTEST_DEPS_perf_$(1)-T-$(2)-H-$(3) = $$(PERF_TESTS)
619 CTEST_DEPS_debuginfo-gdb_$(1)-T-$(2)-H-$(3) = $$(DEBUGINFO_GDB_TESTS)
620 CTEST_DEPS_debuginfo-lldb_$(1)-T-$(2)-H-$(3) = $$(DEBUGINFO_LLDB_TESTS)
621 CTEST_DEPS_codegen_$(1)-T-$(2)-H-$(3) = $$(CODEGEN_TESTS)
625 $(foreach host,$(CFG_HOST), \
626 $(eval $(foreach target,$(CFG_TARGET), \
627 $(eval $(foreach stage,$(STAGES), \
628 $(eval $(call DEF_CTEST_VARS,$(stage),$(target),$(host))))))))
630 define DEF_RUN_COMPILETEST
632 CTEST_ARGS$(1)-T-$(2)-H-$(3)-$(4) := \
633 $$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
634 --src-base $$(S)src/test/$$(CTEST_SRC_BASE_$(4))/ \
635 --build-base $(3)/test/$$(CTEST_BUILD_BASE_$(4))/ \
636 --ratchet-metrics $(call TEST_RATCHET_FILE,$(1),$(2),$(3),$(4)) \
637 --mode $$(CTEST_MODE_$(4)) \
638 $$(CTEST_RUNTOOL_$(4))
640 check-stage$(1)-T-$(2)-H-$(3)-$(4)-exec: $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4))
642 # CTEST_DONT_RUN_$(1)-T-$(2)-H-$(3)-$(4)
643 # Goal: leave this variable as empty string if we should run the test.
644 # Otherwise, set it to the reason we are not running the test.
645 # (Encoded as a separate variable because GNU make does not have a
646 # good way to express OR on ifeq commands)
648 ifneq ($$(CTEST_DISABLE_$(4)),)
649 # Test suite is disabled for all configured targets.
650 CTEST_DONT_RUN_$(1)-T-$(2)-H-$(3)-$(4) := $$(CTEST_DISABLE_$(4))
652 # else, check if non-self-hosted target (i.e. target not-in hosts) ...
653 ifeq ($$(findstring $(2),$$(CFG_HOST)),)
654 # ... if so, then check if this test suite is disabled for non-selfhosts.
655 ifneq ($$(CTEST_DISABLE_NONSELFHOST_$(4)),)
656 # Test suite is disabled for this target.
657 CTEST_DONT_RUN_$(1)-T-$(2)-H-$(3)-$(4) := $$(CTEST_DISABLE_NONSELFHOST_$(4))
660 # Neither DISABLE nor DISABLE_NONSELFHOST is set ==> okay, run the test.
663 ifeq ($$(CTEST_DONT_RUN_$(1)-T-$(2)-H-$(3)-$(4)),)
664 $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4)): \
665 $$(TEST_SREQ$(1)_T_$(2)_H_$(3)) \
666 $$(CTEST_DEPS_$(4)_$(1)-T-$(2)-H-$(3))
667 @$$(call E, run $(4) [$(2)]: $$<)
668 $$(Q)$$(call CFG_RUN_CTEST_$(2),$(1),$$<,$(3)) \
669 $$(CTEST_ARGS$(1)-T-$(2)-H-$(3)-$(4)) \
670 --logfile $$(call TEST_LOG_FILE,$(1),$(2),$(3),$(4)) \
675 $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4)):
676 @$$(call E, run $(4) [$(2)]: $$<)
677 @$$(call E, warning: tests disabled: $$(CTEST_DONT_RUN_$(1)-T-$(2)-H-$(3)-$(4)))
684 CTEST_NAMES = rpass rpass-full cfail-full rfail cfail bench perf debuginfo-gdb debuginfo-lldb codegen
686 $(foreach host,$(CFG_HOST), \
687 $(eval $(foreach target,$(CFG_TARGET), \
688 $(eval $(foreach stage,$(STAGES), \
689 $(eval $(foreach name,$(CTEST_NAMES), \
690 $(eval $(call DEF_RUN_COMPILETEST,$(stage),$(target),$(host),$(name))))))))))
692 PRETTY_NAMES = pretty-rpass pretty-rpass-full pretty-rfail pretty-bench pretty-pretty
693 PRETTY_DEPS_pretty-rpass = $(RPASS_TESTS)
694 PRETTY_DEPS_pretty-rpass-full = $(RPASS_FULL_TESTS)
695 PRETTY_DEPS_pretty-rfail = $(RFAIL_TESTS)
696 PRETTY_DEPS_pretty-bench = $(BENCH_TESTS)
697 PRETTY_DEPS_pretty-pretty = $(PRETTY_TESTS)
698 PRETTY_DIRNAME_pretty-rpass = run-pass
699 PRETTY_DIRNAME_pretty-rpass-full = run-pass-fulldeps
700 PRETTY_DIRNAME_pretty-rfail = run-fail
701 PRETTY_DIRNAME_pretty-bench = bench
702 PRETTY_DIRNAME_pretty-pretty = pretty
704 define DEF_RUN_PRETTY_TEST
706 PRETTY_ARGS$(1)-T-$(2)-H-$(3)-$(4) := \
707 $$(CTEST_COMMON_ARGS$(1)-T-$(2)-H-$(3)) \
708 --src-base $$(S)src/test/$$(PRETTY_DIRNAME_$(4))/ \
709 --build-base $(3)/test/$$(PRETTY_DIRNAME_$(4))/ \
712 check-stage$(1)-T-$(2)-H-$(3)-$(4)-exec: $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4))
714 $$(call TEST_OK_FILE,$(1),$(2),$(3),$(4)): \
715 $$(TEST_SREQ$(1)_T_$(2)_H_$(3)) \
717 @$$(call E, run pretty-rpass [$(2)]: $$<)
718 $$(Q)$$(call CFG_RUN_CTEST_$(2),$(1),$$<,$(3)) \
719 $$(PRETTY_ARGS$(1)-T-$(2)-H-$(3)-$(4)) \
720 --logfile $$(call TEST_LOG_FILE,$(1),$(2),$(3),$(4)) \
725 $(foreach host,$(CFG_HOST), \
726 $(foreach target,$(CFG_TARGET), \
727 $(foreach stage,$(STAGES), \
728 $(foreach pretty-name,$(PRETTY_NAMES), \
729 $(eval $(call DEF_RUN_PRETTY_TEST,$(stage),$(target),$(host),$(pretty-name)))))))
732 ######################################################################
733 # Crate & freestanding documentation tests
734 ######################################################################
737 RUSTDOC_EXE_$(1)_T_$(2)_H_$(3) := $$(HBIN$(1)_H_$(3))/rustdoc$$(X_$(3))
738 RUSTDOC_$(1)_T_$(2)_H_$(3) := $$(RPATH_VAR$(1)_T_$(2)_H_$(3)) $$(RUSTDOC_EXE_$(1)_T_$(2)_H_$(3))
741 $(foreach host,$(CFG_HOST), \
742 $(foreach target,$(CFG_TARGET), \
743 $(foreach stage,$(STAGES), \
744 $(eval $(call DEF_RUSTDOC,$(stage),$(target),$(host))))))
750 check-stage$(1)-T-$(2)-H-$(3)-doc-$(4)-exec: $$(call TEST_OK_FILE,$(1),$(2),$(3),doc-$(4))
752 # If NO_REBUILD is set then break the dependencies on everything but
753 # the source files so we can test documentation without rebuilding
755 ifeq ($(NO_REBUILD),)
756 DOCTESTDEP_$(1)_$(2)_$(3)_$(4) = \
758 $$(TEST_SREQ$(1)_T_$(2)_H_$(3)) \
759 $$(RUSTDOC_EXE_$(1)_T_$(2)_H_$(3))
761 DOCTESTDEP_$(1)_$(2)_$(3)_$(4) = $$(D)/$(4).md
764 ifeq ($(2),$$(CFG_BUILD))
765 $$(call TEST_OK_FILE,$(1),$(2),$(3),doc-$(4)): $$(DOCTESTDEP_$(1)_$(2)_$(3)_$(4))
766 @$$(call E, run doc-$(4) [$(2)])
767 $$(Q)$$(RUSTDOC_$(1)_T_$(2)_H_$(3)) --cfg dox --test $$< --test-args "$$(TESTARGS)" && touch $$@
769 $$(call TEST_OK_FILE,$(1),$(2),$(3),doc-$(4)):
774 $(foreach host,$(CFG_HOST), \
775 $(foreach target,$(CFG_TARGET), \
776 $(foreach stage,$(STAGES), \
777 $(foreach docname,$(DOCS), \
778 $(eval $(call DEF_DOC_TEST,$(stage),$(target),$(host),$(docname)))))))
782 define DEF_CRATE_DOC_TEST
784 # If NO_REBUILD is set then break the dependencies on everything but
785 # the source files so we can test crate documentation without
786 # rebuilding any of the parent crates.
787 ifeq ($(NO_REBUILD),)
788 CRATEDOCTESTDEP_$(1)_$(2)_$(3)_$(4) = \
789 $$(TEST_SREQ$(1)_T_$(2)_H_$(3)) \
790 $$(CRATE_FULLDEPS_$(1)_T_$(2)_H_$(3)_$(4)) \
791 $$(RUSTDOC_EXE_$(1)_T_$(2)_H_$(3))
793 CRATEDOCTESTDEP_$(1)_$(2)_$(3)_$(4) = $$(RSINPUTS_$(4))
796 check-stage$(1)-T-$(2)-H-$(3)-doc-crate-$(4)-exec: \
797 $$(call TEST_OK_FILE,$(1),$(2),$(3),doc-crate-$(4))
799 ifeq ($(2),$$(CFG_BUILD))
800 $$(call TEST_OK_FILE,$(1),$(2),$(3),doc-crate-$(4)): $$(CRATEDOCTESTDEP_$(1)_$(2)_$(3)_$(4))
801 @$$(call E, run doc-crate-$(4) [$(2)])
802 $$(Q)$$(RUSTDOC_$(1)_T_$(2)_H_$(3)) --test \
803 $$(CRATEFILE_$(4)) --test-args "$$(TESTARGS)" && touch $$@
805 $$(call TEST_OK_FILE,$(1),$(2),$(3),doc-crate-$(4)):
811 $(foreach host,$(CFG_HOST), \
812 $(foreach target,$(CFG_TARGET), \
813 $(foreach stage,$(STAGES), \
814 $(foreach crate,$(TEST_DOC_CRATES), \
815 $(eval $(call DEF_CRATE_DOC_TEST,$(stage),$(target),$(host),$(crate)))))))
817 ######################################################################
819 ######################################################################
823 $(foreach crate,$(TEST_CRATES),$(crate)) \
824 $(foreach crate,$(TEST_DOC_CRATES),doc-crate-$(crate)) \
837 $(foreach docname,$(DOCS),doc-$(docname)) \
846 define DEF_CHECK_FOR_STAGE_AND_TARGET_AND_HOST
847 check-stage$(1)-T-$(2)-H-$(3): check-stage$(1)-T-$(2)-H-$(3)-exec
850 $(foreach stage,$(STAGES), \
851 $(foreach target,$(CFG_TARGET), \
852 $(foreach host,$(CFG_HOST), \
853 $(eval $(call DEF_CHECK_FOR_STAGE_AND_TARGET_AND_HOST,$(stage),$(target),$(host))))))
855 define DEF_CHECK_FOR_STAGE_AND_TARGET_AND_HOST_AND_GROUP
856 check-stage$(1)-T-$(2)-H-$(3)-$(4): check-stage$(1)-T-$(2)-H-$(3)-$(4)-exec
859 $(foreach stage,$(STAGES), \
860 $(foreach target,$(CFG_TARGET), \
861 $(foreach host,$(CFG_HOST), \
862 $(foreach group,$(TEST_GROUPS), \
863 $(eval $(call DEF_CHECK_FOR_STAGE_AND_TARGET_AND_HOST_AND_GROUP,$(stage),$(target),$(host),$(group)))))))
865 define DEF_CHECK_FOR_STAGE
866 check-stage$(1): check-stage$(1)-H-$$(CFG_BUILD)
867 check-stage$(1)-H-all: $$(foreach target,$$(CFG_TARGET), \
868 check-stage$(1)-H-$$(target))
871 $(foreach stage,$(STAGES), \
872 $(eval $(call DEF_CHECK_FOR_STAGE,$(stage))))
874 define DEF_CHECK_FOR_STAGE_AND_GROUP
875 check-stage$(1)-$(2): check-stage$(1)-H-$$(CFG_BUILD)-$(2)
876 check-stage$(1)-H-all-$(2): $$(foreach target,$$(CFG_TARGET), \
877 check-stage$(1)-H-$$(target)-$(2))
880 $(foreach stage,$(STAGES), \
881 $(foreach group,$(TEST_GROUPS), \
882 $(eval $(call DEF_CHECK_FOR_STAGE_AND_GROUP,$(stage),$(group)))))
885 define DEF_CHECK_FOR_STAGE_AND_HOSTS
886 check-stage$(1)-H-$(2): $$(foreach target,$$(CFG_TARGET), \
887 check-stage$(1)-T-$$(target)-H-$(2))
890 $(foreach stage,$(STAGES), \
891 $(foreach host,$(CFG_HOST), \
892 $(eval $(call DEF_CHECK_FOR_STAGE_AND_HOSTS,$(stage),$(host)))))
894 define DEF_CHECK_FOR_STAGE_AND_HOSTS_AND_GROUP
895 check-stage$(1)-H-$(2)-$(3): $$(foreach target,$$(CFG_TARGET), \
896 check-stage$(1)-T-$$(target)-H-$(2)-$(3))
899 $(foreach stage,$(STAGES), \
900 $(foreach host,$(CFG_HOST), \
901 $(foreach group,$(TEST_GROUPS), \
902 $(eval $(call DEF_CHECK_FOR_STAGE_AND_HOSTS_AND_GROUP,$(stage),$(host),$(group))))))
904 define DEF_CHECK_DOC_FOR_STAGE
905 check-stage$(1)-docs: $$(foreach docname,$$(DOCS),\
906 check-stage$(1)-T-$$(CFG_BUILD)-H-$$(CFG_BUILD)-doc-$$(docname)) \
907 $$(foreach crate,$$(TEST_DOC_CRATES),\
908 check-stage$(1)-T-$$(CFG_BUILD)-H-$$(CFG_BUILD)-doc-crate-$$(crate))
911 $(foreach stage,$(STAGES), \
912 $(eval $(call DEF_CHECK_DOC_FOR_STAGE,$(stage))))
914 define DEF_CHECK_CRATE
915 check-$(1): check-stage2-T-$$(CFG_BUILD)-H-$$(CFG_BUILD)-$(1)-exec
918 $(foreach crate,$(TEST_CRATES), \
919 $(eval $(call DEF_CHECK_CRATE,$(crate))))
921 ######################################################################
923 ######################################################################
925 RMAKE_TESTS := $(shell ls -d $(S)src/test/run-make/*/)
926 RMAKE_TESTS := $(RMAKE_TESTS:$(S)src/test/run-make/%/=%)
928 define DEF_RMAKE_FOR_T_H
934 ifeq ($(2)$(3),$$(CFG_BUILD)$$(CFG_BUILD))
935 check-stage$(1)-T-$(2)-H-$(3)-rmake-exec: \
936 $$(call TEST_OK_FILE,$(1),$(2),$(3),rmake)
938 $$(call TEST_OK_FILE,$(1),$(2),$(3),rmake): \
939 $$(RMAKE_TESTS:%=$(3)/test/run-make/%-$(1)-T-$(2)-H-$(3).ok)
942 $(3)/test/run-make/%-$(1)-T-$(2)-H-$(3).ok: \
943 $(S)src/test/run-make/%/Makefile \
944 $$(CSREQ$(1)_T_$(2)_H_$(3))
945 @rm -rf $(3)/test/run-make/$$*
946 @mkdir -p $(3)/test/run-make/$$*
947 $$(Q)$$(CFG_PYTHON) $(S)src/etc/maketest.py $$(dir $$<) \
949 $$(HBIN$(1)_H_$(3))/rustc$$(X_$(3)) \
950 $(3)/test/run-make/$$* \
951 "$$(CC_$(3)) $$(CFG_GCCISH_CFLAGS_$(3))" \
952 $$(HBIN$(1)_H_$(3))/rustdoc$$(X_$(3)) \
954 "$$(RPATH_VAR$(1)_T_$(2)_H_$(3))"
957 # FIXME #11094 - The above rule doesn't work right for multiple targets
958 check-stage$(1)-T-$(2)-H-$(3)-rmake-exec:
966 $(foreach stage,$(STAGES), \
967 $(foreach target,$(CFG_TARGET), \
968 $(foreach host,$(CFG_HOST), \
969 $(eval $(call DEF_RMAKE_FOR_T_H,$(stage),$(target),$(host))))))