149da0fa4SScott Kruger# -*- mode: makefile-gmake -*- 2fca490e6SSatish Balay-include petscdir.mk 349da0fa4SScott Kruger 4*c0558f20SBarry Smith.SUFFIXES: .F .F90 .f90 ${SUFFIXES} .PETSc .C .cc .cpp .cxx .r .rm .so .html .ad .m .tex .mtex .make .fig .svg .eps .pdf .jpg .png .dvi .ps .F95 .f95 .fiat .cu .kokkos.cxx 5*c0558f20SBarry Smith 637ed16bcSStefano ZampiniCONFIGDIR := $(PETSC_DIR)/config 749da0fa4SScott Kruger 8fc46264cSScott Kruger# TESTSRCDIR is always relative to gmakefile.test 9fc46264cSScott Kruger# This must be before includes 105b5a9be8SJed Brownmkfile_path := $(abspath $(lastword $(MAKEFILE_LIST))) 115b5a9be8SJed BrownTESTSRCDIR := $(dir $(mkfile_path))src 12fc46264cSScott Kruger 130e03b746SBarry Smith-include $(PETSC_DIR)/$(PETSC_ARCH)/lib/petsc/conf/petscvariables 140e03b746SBarry Smith-include $(PETSC_DIR)/lib/petsc/conf/variables 1549da0fa4SScott Kruger 168e69c5ecSJed BrownTESTDIR ?= ./$(PETSC_ARCH)/tests 174ff3c6a1SScott KrugerMODDIR := $(PETSC_DIR)/$(PETSC_ARCH)/include 18e73aa2c6SSatish BalayTESTLOGTAPFILE ?= $(TESTDIR)/test_$(PETSC_ARCH)_tap.log 19e73aa2c6SSatish BalayTESTLOGERRFILE ?= $(TESTDIR)/test_$(PETSC_ARCH)_err.log 2094666443SJed BrownEXAMPLESDIR := $(TESTSRCDIR) 2149da0fa4SScott Kruger 2249da0fa4SScott Krugerpkgs := sys vec mat dm ksp snes ts tao 2349da0fa4SScott Kruger 244ff3c6a1SScott Krugerpetscconf := $(PETSC_DIR)/$(PETSC_ARCH)/include/petscconf.h 254ff3c6a1SScott Krugerpetscvariables := $(PETSC_DIR)/$(PETSC_ARCH)/lib/petsc/conf/petscvariables 268e69c5ecSJed Browngeneratedtest := $(TESTDIR)/testfiles 2749da0fa4SScott Kruger 2849da0fa4SScott Kruger.SECONDEXPANSION: # to expand $$(@D)/.DIR 2949da0fa4SScott Kruger 3049da0fa4SScott KrugerTESTFLAGS := # Initialize as simple variable 3149da0fa4SScott Kruger 3249da0fa4SScott Kruger#workarround old cygwin versions 3349da0fa4SScott Krugerifeq ($(PETSC_CYGWIN_BROKEN_PIPE),1) 3449da0fa4SScott Krugerifeq ($(shell basename $(AR)),ar) 3549da0fa4SScott Kruger V ?=1 3649da0fa4SScott Krugerendif 3749da0fa4SScott Krugerendif 3849da0fa4SScott KrugerV ?= $(if $(findstring s,$(MAKEFLAGS)),0) 3949da0fa4SScott Krugerifeq ($(V),) # Default 4049da0fa4SScott Kruger quiet_HELP := "Use \"$(MAKE) V=1\" to see verbose compile lines, \"$(MAKE) V=0\" to suppress.\n" 4149da0fa4SScott Kruger quiet = @printf $(quiet_HELP)$(eval quiet_HELP:=)" %10s %s\n" "$1$2" "$@"; $($1) 4249da0fa4SScott Kruger quiettest = @printf " %10s %s\n" "TEST" "$(@:$(TESTDIR)/counts/%.counts=%)"; 4349da0fa4SScott Krugerelse ifeq ($(V),0) # Suppress entire command 4449da0fa4SScott Kruger quiet = @$($1) 4549da0fa4SScott Kruger quiettest = @ 465e361860SScott Kruger TESTFLAGS += -o err_only 4749da0fa4SScott Krugerelse # Show the full command line 4849da0fa4SScott Kruger quiet = $($1) 4949da0fa4SScott Kruger quiettest = 5049da0fa4SScott Kruger TESTFLAGS += -v 5149da0fa4SScott Krugerendif 5249da0fa4SScott Kruger 5349da0fa4SScott Krugerifeq ($(FORCE),1) 5449da0fa4SScott Kruger TESTFLAGS += -f # force test execution 5549da0fa4SScott Krugerendif 5649da0fa4SScott Krugerifeq ($(VALGRIND),1) 5749da0fa4SScott Kruger TESTFLAGS += -V # Add valgrind to the flags 5849da0fa4SScott Krugerendif 5949da0fa4SScott Krugerifeq ($(REPLACE),1) 6049da0fa4SScott Kruger TESTFLAGS += -m # Replace results by passing -m to petscdiff 6149da0fa4SScott Krugerendif 625e361860SScott Krugerifeq ($(OUTPUT),1) 635e361860SScott Kruger TESTFLAGS += -o 'err_only' # Show only the errors on stdout 645e361860SScott Krugerendif 65f50802fbSScott Krugerifeq ($(ALT),1) 66f50802fbSScott Kruger TESTFLAGS += -M # Replace alt files by passing -M to petscdiff 67f50802fbSScott Krugerendif 68e6bdf5b1SSatish BalayPRINTONLY ?= 0 69a6f3f80dSScott Krugerifeq ($(PRINTONLY),1) 70a6f3f80dSScott Kruger TESTFLAGS += -p # Pass -p to petscdiff to print only command 71a6f3f80dSScott Krugerendif 7249da0fa4SScott Krugerifeq ($(DIFF_NUMBERS),1) 7349da0fa4SScott Kruger TESTFLAGS += -j # Pass -j to petscdiff to diff the actual numbers 7449da0fa4SScott Krugerendif 7549da0fa4SScott Krugerifdef OPTIONS 7649da0fa4SScott Kruger TESTFLAGS += -a '$(OPTIONS)' # override arguments 7749da0fa4SScott Krugerendif 7849da0fa4SScott Krugerifdef EXTRA_OPTIONS 7949da0fa4SScott Kruger TESTFLAGS += -e '$(EXTRA_OPTIONS)' # add extra arguments 8049da0fa4SScott Krugerendif 8149da0fa4SScott Krugerifdef NP 8249da0fa4SScott Kruger TESTFLAGS += -n $(NP) # set number of processes 8349da0fa4SScott Krugerendif 8449da0fa4SScott Kruger# Override the default timeout that may be found at the top of config/petsc_harness.sh 8549da0fa4SScott Kruger# This must be an integer. It is given in seconds. 8649da0fa4SScott Krugerifdef TIMEOUT 8749da0fa4SScott Kruger TESTFLAGS += -t $(TIMEOUT) # Override the default timeout 8849da0fa4SScott Krugerendif 8949da0fa4SScott Kruger 90fc46264cSScott Kruger$(generatedtest) : $(petscconf) $(petscvariables) $(CONFIGDIR)/gmakegentest.py $(TESTDIR)/.DIR | $$(@D)/.DIR 918e69c5ecSJed Brown $(PYTHON) $(CONFIGDIR)/gmakegentest.py --petsc-dir=$(PETSC_DIR) --petsc-arch=$(PETSC_ARCH) --testdir=$(TESTDIR) 9249da0fa4SScott Kruger 93fca490e6SSatish Balayifneq ($(filter-out clean check,$(MAKECMDGOALS:clean%=clean)),) 94336d78f1SSatish Balayinclude $(generatedtest) 95535b694aSJed Brownendif 9649da0fa4SScott Kruger 9749da0fa4SScott Krugerifeq ($(PETSC_LANGUAGE),CXXONLY) 9849da0fa4SScott Kruger cc_name := CXX 9949da0fa4SScott Krugerelse 10049da0fa4SScott Kruger cc_name := CC 10149da0fa4SScott Krugerendif 10249da0fa4SScott Kruger 1030b119762SSatish BalayPETSC_COMPILE.c = $(call quiet,$(cc_name)) -c $(PCC_FLAGS) $(PFLAGS) $(CCPPFLAGS) $(C_DEPFLAGS) 1040b119762SSatish BalayPETSC_COMPILE.cxx = $(call quiet,CXX) -c $(CXX_FLAGS) $(CXXFLAGS) $(CXXCPPFLAGS) $(CXX_DEPFLAGS) 105*c0558f20SBarry Smithifneq ($(KOKKOS_BIN),) 106*c0558f20SBarry Smith# Kokkos requires nvcc to be in PATH and the C++ compiler to be given in an environmental variable 107*c0558f20SBarry SmithPETSC_COMPILE.kokkos.cxx = PATH=$(PATH):`dirname $(CUDAC)` NVCC_WRAPPER_DEFAULT_COMPILER=$(CXX_LINKER) $(KOKKOS_BIN)/nvcc_wrapper --expt-extended-lambda -c $(CXX_FLAGS) $(CXXFLAGS) $(CXXCPPFLAGS) 108*c0558f20SBarry SmithPETSC_LINK.kokkos.cxx = PATH=$(PATH):`dirname $(CUDAC)` NVCC_WRAPPER_DEFAULT_COMPILER=$(CXX_LINKER) $(KOKKOS_BIN)/nvcc_wrapper --expt-extended-lambda $(CXX_LINKER_FLAGS) $(PETSC_CCPPFLAGS) $(CPPFLAGS) $(LDFLAGS) 109*c0558f20SBarry Smithelse 110*c0558f20SBarry SmithPETSC_COMPILE.kokkos.cxx = $(call quiet,CXX) -c $(CXX_FLAGS) $(CXXFLAGS) $(CXXCPPFLAGS) $(CXX_DEPFLAGS) 111*c0558f20SBarry SmithPETSC_LINK.kokkos.cxx = $(CXXLINKER) $(CXX_LINKER_FLAGS) $(CXXFLAGS) $(PETSC_CCPPFLAGS) $(CPPFLAGS) $(LDFLAGS) 112*c0558f20SBarry Smithendif 11382707f21SStefano ZampiniPETSC_COMPILE.cu = $(call quiet,CUDAC) -c $(CUDAC_FLAGS) $(CUFLAGS) --compiler-options="$(PCC_FLAGS) $(CXXFLAGS) $(CCPPFLAGS)" 11428f796eaSScott KrugerPETSC_COMPILE.hip.cpp = $(call quiet,HIPCC) -c $(HIPCC_FLAGS) $(HIPCCFLAGS) $(HIPCCPPFLAGS) $(HIPCC_DEPFLAGS) 11528f796eaSScott KrugerPETSC_COMPILE.sycl.cpp = $(call quiet,SYCLCPP) -c $(SYCLCPP_FLAGS) $(SYCLCPPFLAGS) $(SYCLCPPCPPFLAGS) $(SYCLCPP_DEPFLAGS) 11682707f21SStefano ZampiniPETSC_GENDEPS.cu = $(call quiet,CUDAC,.dep) --generate-dependencies --output-directory=$(@D) $(CUDAC_FLAGS) $(CUFLAGS) --compiler-options="$(PCC_FLAGS) $(CXXFLAGS) $(CCPPFLAGS)" 11749da0fa4SScott KrugerPETSC_COMPILE.F = $(call quiet,FC) -c $(FC_FLAGS) $(FFLAGS) $(FCPPFLAGS) $(FC_DEPFLAGS) 11849da0fa4SScott Kruger 119*c0558f20SBarry Smithtestlangs := c cu cxx F F90 kokkos.cxx hip.cpp sycl.cpp 120513d7a9cSJed Brown$(foreach lang, $(testlangs), $(eval \ 121513d7a9cSJed Brown testexe.$(lang) = $(foreach pkg, $(pkgs), $(testsrcs-$(pkg).$(lang):%.$(lang)=$(TESTDIR)/%)))) 12249da0fa4SScott Krugerconcattestlang = $(foreach lang, $(2), $(testsrcs-$(1).$(lang):%.$(lang)=$(TESTDIR)/%.o)) 12349da0fa4SScott Krugertestsrcs.o := $(foreach pkg, $(pkgs), $(call concattestlang,$(pkg),$(testlangs))) 124fc46264cSScott Krugertestsrcs-rel := $(foreach pkg, $(pkgs), $(foreach lang, $(testlangs), $(testsrcs-$(pkg).$(lang)))) 125fc46264cSScott Krugertestsrcs := $(foreach sfile, $(testsrcs-rel), $(TESTSRCDIR)/$(sfile)) 12649da0fa4SScott Kruger 12706fe1a63SSatish Balay# workaround win32fe failure 12806fe1a63SSatish Balayifneq (,$(findstring win32fe,$(call quiet,$(cc_name)))) 12906fe1a63SSatish Balay$(TESTDIR)/ts/tutorials/multirate/ex6: | $(TESTDIR)/ts/tutorials/multirate/ex5 13006fe1a63SSatish Balay$(TESTDIR)/ts/tutorials/multirate/ex8: | $(TESTDIR)/ts/tutorials/multirate/ex6 13106fe1a63SSatish Balayendif 13206fe1a63SSatish Balay 13349da0fa4SScott Kruger# Refresh testfiles when sources change, but don't balk if the source file is nonexistent (deleted) 13449da0fa4SScott Kruger$(generatedtest) : $(testsrcs) 13549da0fa4SScott Kruger$(testsrcs) : 13649da0fa4SScott Kruger 1374ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.c | $$(@D)/.DIR 13849da0fa4SScott Kruger $(PETSC_COMPILE.c) $(abspath $<) -o $@ 13949da0fa4SScott Kruger 140*c0558f20SBarry Smith$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.kokkos.cxx | $$(@D)/.DIR 141*c0558f20SBarry Smith $(PETSC_COMPILE.kokkos.cxx) $(abspath $<) -o $@ 142*c0558f20SBarry Smith 1434ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.cxx | $$(@D)/.DIR 14449da0fa4SScott Kruger $(PETSC_COMPILE.cxx) $(abspath $<) -o $@ 14549da0fa4SScott Kruger 1464ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.cu | $$(@D)/.DIR 14749da0fa4SScott Kruger $(PETSC_COMPILE.cu) $(abspath $<) -o $@ # Compile first so that if there is an error, it comes from a normal compile 14849da0fa4SScott Kruger @$(PETSC_GENDEPS.cu) $(abspath $<) -o $(@:%.o=%.d) # Generate the dependencies for later 14949da0fa4SScott Kruger 150a55d2495SJed Brown# Test modules go in the same directory as the target *.o 151a55d2495SJed BrownTESTMODDIR = $(@D) 15249da0fa4SScott KrugerFCMOD = cd 1534ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.F | $$(@D)/.DIR 15449da0fa4SScott Krugerifeq ($(FC_MODULE_OUTPUT_FLAG),) 155a55d2495SJed Brown $(call quiet,FCMOD) $(TESTMODDIR) && $(FC) -c $(FC_FLAGS) $(FFLAGS) $(FCPPFLAGS) $(FC_DEPFLAGS) -I$(dir $<) $(abspath $<) -o $(abspath $@) 15649da0fa4SScott Krugerelse 157a55d2495SJed Brown $(PETSC_COMPILE.F) -I$(dir $<) $(abspath $<) -o $@ $(FC_MODULE_OUTPUT_FLAG)$(TESTMODDIR) $(FC_MODULE_FLAG)$(TESTMODDIR) 15849da0fa4SScott Krugerendif 1590266c241SJed Brown -@$(GFORTRAN_DEP_CLEANUP) 16049da0fa4SScott Kruger 1614ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.F90 | $$(@D)/.DIR 16249da0fa4SScott Krugerifeq ($(FC_MODULE_OUTPUT_FLAG),) 163a55d2495SJed Brown $(call quiet,FCMOD) $(TESTMODDIR) && $(FC) -c $(FC_FLAGS) $(FFLAGS) $(FCPPFLAGS) $(FC_DEPFLAGS) -I$(dir $<) $(abspath $<) -o $(abspath $@) 16449da0fa4SScott Krugerelse 165a55d2495SJed Brown $(PETSC_COMPILE.F) -I$(dir $<) $(abspath $<) -o $@ $(FC_MODULE_OUTPUT_FLAG)$(TESTMODDIR) $(FC_MODULE_FLAG)$(TESTMODDIR) 16649da0fa4SScott Krugerendif 1670266c241SJed Brown -@$(GFORTRAN_DEP_CLEANUP) 1680266c241SJed Brown 169cf7d3547SScott Kruger# This is a hack to fix a broken gfortran. 1700266c241SJed Browndefine GFORTRAN_DEP_CLEANUP 1710266c241SJed Brown if test -e "$(@:%.o=%.d)" && head -1 "$(@:%.o=%.d)" | fgrep -q -v : ; then\ 1724f45eea9SScott Kruger echo "$(@): \\" > $(@:%.o=%.dtemp) ; \ 1730266c241SJed Brown tr '\n' '@' < $(@:%.o=%.d) | cut -d: -f2- | tr '@' '\n' >> $(@:%.o=%.dtemp) ; \ 1740266c241SJed Brown mv $(@:%.o=%.dtemp) $(@:%.o=%.d); \ 1754f45eea9SScott Kruger fi 1760266c241SJed Brownendef 17749da0fa4SScott Kruger 17820844ca6SSatish Balay# link line constructed differently for gmakefile vs gmakefile.test invocation 17920844ca6SSatish Balayifeq ($(libpetscall),) 18020844ca6SSatish BalayPETSC_TEST_LIB = $(PETSC_LIB) 18120844ca6SSatish Balayelse 18220844ca6SSatish BalayPETSC_TEST_LIB = $(C_SH_LIB_PATH) $(PETSC_EXTERNAL_LIB_BASIC) 18320844ca6SSatish Balayendif 18420844ca6SSatish Balay 185bde159b7SSatish Balay# manually list some some library dependencies to check for circular dependencies 186c4762a1bSJed Brown$(TESTDIR)/sys/tests/ex9: PETSC_TEST_LIB = $(PETSC_SYS_LIB) 187c4762a1bSJed Brown$(TESTDIR)/vec/vec/tests/ex1: PETSC_TEST_LIB = $(PETSC_VEC_LIB) 188c4762a1bSJed Brown$(TESTDIR)/mat/tests/ex1: PETSC_TEST_LIB = $(PETSC_MAT_LIB) 189c4762a1bSJed Brown$(TESTDIR)/dm/tests/ex1: PETSC_TEST_LIB = $(PETSC_DM_LIB) 190c4762a1bSJed Brown$(TESTDIR)/ksp/ksp/tests/ex1: PETSC_TEST_LIB = $(PETSC_KSP_LIB) 191c4762a1bSJed Brown$(TESTDIR)/snes/tests/ex1: PETSC_TEST_LIB = $(PETSC_SNES_LIB) 192c4762a1bSJed Brown$(TESTDIR)/ts/tests/ex2: PETSC_TEST_LIB = $(PETSC_TS_LIB) 193c4762a1bSJed Brown$(TESTDIR)/tao/tutorials/ex1: PETSC_TEST_LIB = $(PETSC_TAO_LIB) 194bde159b7SSatish Balay 19549da0fa4SScott Kruger# Test executables 196513d7a9cSJed Brown$(testexe.F) $(testexe.F90) : $(TESTDIR)/% : $(TESTDIR)/%.o $$^ $(libpetscall) 19720844ca6SSatish Balay $(call quiet,FLINKER) -o $@ $^ $(PETSC_TEST_LIB) 19849da0fa4SScott Kruger 199513d7a9cSJed Brown$(testexe.c) $(testexe.cu) : $(TESTDIR)/% : $(TESTDIR)/%.o $$^ $(libpetscall) 20020844ca6SSatish Balay $(call quiet,CLINKER) -o $@ $^ $(PETSC_TEST_LIB) 20149da0fa4SScott Kruger 202*c0558f20SBarry Smith$(testexe.kokkos.cxx) : $(TESTDIR)/% : $(TESTDIR)/%.o $$^ $(libpetscall) 203*c0558f20SBarry Smith $(call quiet,PETSC_LINK.kokkos.cxx) -o $@ $^ $(PETSC_TEST_LIB) 204*c0558f20SBarry Smith 205513d7a9cSJed Brown$(testexe.cxx) : $(TESTDIR)/% : $(TESTDIR)/%.o $$^ $(libpetscall) 2062f4326f3SSatish Balay $(call quiet,CXXLINKER) -o $@ $^ $(PETSC_TEST_LIB) 207513d7a9cSJed Brown 20849da0fa4SScott Kruger# Fortran source files need petsc*.mod, which isn't explicitly managed in the makefile. 20949da0fa4SScott Kruger$(foreach pkg, $(pkgs), $(call concattestlang,$(pkg),F F90)) : $(libpetscall) 21049da0fa4SScott Kruger 21149da0fa4SScott Kruger# Testing convenience targets 212c173c275SScott Kruger.PHONY: test pre-clean 213c173c275SScott Kruger 214ff7b3809SScott Krugertest: report_tests 215c173c275SScott Kruger 21649da0fa4SScott Krugerpre-clean: 2175e361860SScott Kruger @$(RM) -rf $(TESTDIR)/counts $(TESTLOGTAPFILE) $(TESTLOGERRFILE) 2185e361860SScott Kruger @touch $(TESTLOGTAPFILE) $(TESTLOGERRFILE) 21927d73d1fSBarry Smith @echo "Using MAKEFLAGS:" ${MAKEFLAGS} 22049da0fa4SScott Kruger 2214d9d3ee5SSatish Balaycheck-test-errors: 2225e361860SScott Kruger @grep '^not ok' $(TESTLOGTAPFILE) | grep -v 'Exceeded timeout' | tee $(TESTDIR)/allgtests-tap-err.log 2234d9d3ee5SSatish Balay @test ! -s $(TESTDIR)/allgtests-tap-err.log 2244d9d3ee5SSatish Balay 22549da0fa4SScott Kruger.PHONY: $(foreach pkg, $(pkgs), test-$(pkg) $(foreach lang, $(testlangs), test-$(pkg).$(lang) test-rm-$(pkg).$(lang))) 22649da0fa4SScott Krugertestpkgs := $(foreach pkg, $(pkgs), test-$(pkg)) 22749da0fa4SScott Kruger# Targets to run tests in test-$pkg.$lang and delete the executables, language by language 22849da0fa4SScott Kruger$(testpkgs) : test-% : $(foreach lang, $(testlangs), test-rm-%.$(lang)) 22949da0fa4SScott Kruger# List of raw test run targets 23049da0fa4SScott Krugeralltesttargets := $(foreach tp, $(testpkgs), $(foreach lang, $(testlangs), $($(tp).$(lang)))) 23149da0fa4SScott Kruger 23249da0fa4SScott Kruger# Run targets 23349da0fa4SScott Kruger$(alltesttargets) : % : $(TESTDIR)/counts/%.counts 23449da0fa4SScott Kruger.PHONY: $(alltesttargets) 23549da0fa4SScott Kruger 23649da0fa4SScott Kruger$(TESTDIR)/counts/%.counts : 23749da0fa4SScott Kruger $(quiettest) $< $(TESTFLAGS) 23849da0fa4SScott Kruger 23949da0fa4SScott Kruger# Targets to run tests and remove executables, by package-lang pairs. 24049da0fa4SScott Kruger# Run the tests in each batch using recursive invocation of make because 24149da0fa4SScott Kruger# we need all of them to complete before removing the executables. Make 24249da0fa4SScott Kruger# doesn't guarantee an exploration order for the graph. Only recursive 24349da0fa4SScott Kruger# if there is something to be done. 24449da0fa4SScott Krugeralltest-rm := $(foreach pkg, $(pkgs), $(foreach lang, $(testlangs), test-rm-$(pkg).$(lang))) 24549da0fa4SScott Kruger$(alltest-rm) : test-rm-% : test-% 24649da0fa4SScott Krugerifneq ($(NO_RM),1) 24749da0fa4SScott Kruger $(call quiet,RM) $(addprefix $(TESTDIR)/,$(basename $($(@:test-rm-%=testsrcs-%)))) 24849da0fa4SScott Krugerendif 24949da0fa4SScott Kruger 25049da0fa4SScott Kruger# Remove intermediate .o files 25149da0fa4SScott Kruger# This only removes the files at the end which is insufficient 25249da0fa4SScott Kruger#.INTERMEDIATE: $(testsrcs.o:%.o=%) 25349da0fa4SScott Kruger 25449da0fa4SScott Kruger# all sources should get recompiled when petscvariables changes (i.e when configure is rerun or when petscvariables is manually edited.) 25549da0fa4SScott Kruger$(testsrcs.o) : $(petscvariables) 25649da0fa4SScott Kruger 25749da0fa4SScott Kruger%/.DIR : 25849da0fa4SScott Kruger @mkdir -p $(@D) 25949da0fa4SScott Kruger @touch $@ 26049da0fa4SScott Kruger 26149da0fa4SScott Kruger.PRECIOUS: %/.DIR 26249da0fa4SScott Kruger 26349da0fa4SScott Kruger.SUFFIXES: # Clear .SUFFIXES because we don't use implicit rules 26449da0fa4SScott Kruger.DELETE_ON_ERROR: # Delete likely-corrupt target file if rule fails 26549da0fa4SScott Kruger 26637ed16bcSStefano Zampini.PHONY: clean cleantest all 26749da0fa4SScott Kruger 26849da0fa4SScott Krugercleantest: 26949da0fa4SScott Kruger ${RM} -r $(TESTDIR) $(generatedtest) 27049da0fa4SScott Kruger 27149da0fa4SScott Krugerclean: cleantest 27249da0fa4SScott Kruger 27349da0fa4SScott Krugeralltest.d := $(testsrcs.o:%.o=%.d) 27449da0fa4SScott Kruger# Tell make that alltest.d are all up to date. Without this, the include 27549da0fa4SScott Kruger# below has quadratic complexity, taking more than one second for a 27649da0fa4SScott Kruger# do-nothing build of PETSc (much worse for larger projects) 27749da0fa4SScott Kruger$(alltest.d) : ; 27849da0fa4SScott Kruger 27949da0fa4SScott Kruger-include $(alltest.d) 28049da0fa4SScott Kruger 28149da0fa4SScott Kruger# Tests can be generated by searching 28249da0fa4SScott Kruger# Percent is a wildcard (only one allowed): 28349da0fa4SScott Kruger# make -f gmakefile test search=sys%ex2 28449da0fa4SScott Kruger# To match internal substrings (matches *ex2*): 28549da0fa4SScott Kruger# make -f gmakefile test searchin=ex2 28649da0fa4SScott Kruger# Search and searchin can be combined: 28749da0fa4SScott Kruger# make -f gmakefile test search='sys%' searchin=ex2 28849da0fa4SScott Kruger# For args: 28949da0fa4SScott Kruger# make -f gmakefile test argsearch=cuda 29049da0fa4SScott Kruger# For general glob-style searching using python: 29149da0fa4SScott Kruger# NOTE: uses shell which is possibly slower and is possibly more brittle 29249da0fa4SScott Kruger# make -f gmakefile test globsearch='sys*ex2*' 29349da0fa4SScott Krugerifdef search 29449da0fa4SScott Kruger TESTTARGETS := $(filter $(search),$(alltesttargets)) 29549da0fa4SScott Kruger ifdef searchin 29649da0fa4SScott Kruger TESTTARGETS2 := $(foreach v,$(TESTTARGETS),$(if $(findstring $(searchin),$(v)),$(v))) 29749da0fa4SScott Kruger TESTTARGETS := $(TESTTARGETS2) 29849da0fa4SScott Kruger endif 29949da0fa4SScott Krugerelse ifdef searchin 30049da0fa4SScott Kruger TESTTARGETS := $(foreach v,$(alltesttargets),$(if $(findstring $(searchin),$(v)),$(v))) 30149da0fa4SScott Krugerelse ifdef argsearch 30249da0fa4SScott Kruger TESTTARGETS := $(foreach v,$(alltesttargets),$(if $(findstring $(argsearch),$($(v)_ARGS)),$(v))) 30349da0fa4SScott Krugerelse ifdef globsearch 3045b6dee57SScott Kruger TESTTARGETS := $(shell $(PYTHON) config/query_tests.py 'name' '$(globsearch)') 305feeaa4f6SScott Krugerelse ifdef test-fail 306feeaa4f6SScott Kruger TESTTARGETS := $(shell $(PETSC_ARCH)/tests/echofailures.sh) 3076f5e9bd5SScott Krugerelse ifdef query 3086f5e9bd5SScott Kruger TESTTARGETS := $(shell $(PYTHON) config/query_tests.py '$(query)' '$(queryval)') 30949da0fa4SScott Krugerelse # No filter - run them all, but delete the executables as we go 31049da0fa4SScott Kruger TESTTARGETS := $(testpkgs) 31149da0fa4SScott Krugerendif 31249da0fa4SScott Kruger 31349da0fa4SScott Kruger.PHONY: report_tests print-test 31449da0fa4SScott Kruger 31549da0fa4SScott Krugerprint-test: 3165b6dee57SScott Kruger $(info $(TESTTARGETS)) 3175b6dee57SScott Kruger @true 31849da0fa4SScott Kruger 3196e5deea7SScott Krugershow-fail: 320b711b6a4SScott Kruger -@$(PYTHON) $(CONFIGDIR)/report_tests.py -d $(TESTDIR)/counts -f 321b711b6a4SScott Kruger 3226e5deea7SScott Kruger 3236e5deea7SScott Kruger 324c01c7e64SJed Brown# Don't start running tests until starttime has completed 325c01c7e64SJed Brown$(alltesttargets:%=$(TESTDIR)/counts/%.counts) : starttime 326c01c7e64SJed Brown 327c01c7e64SJed Brown# Ensure that libpetsc (if it is a prerequisite) has been built and clean the counts/logs before starting timer 328c01c7e64SJed Brownstarttime: pre-clean $(libpetscall) 32927d73d1fSBarry Smith @$(eval STARTTIME := $(shell date +%s)) 33027d73d1fSBarry Smith 33127d73d1fSBarry Smithreport_tests: starttime $(TESTTARGETS) 33232f4009dSScott Kruger @$(eval ENDTIME := $(shell date +%s)) 333a6f3f80dSScott Kruger -@if test ${PRINTONLY} -ne 1; then elapsed_time=$$(($(ENDTIME)- $(STARTTIME))) && \ 334a6f3f80dSScott Kruger $(PYTHON) $(CONFIGDIR)/report_tests.py -m $(MAKE) -d $(TESTDIR)/counts -t 5 -e $${elapsed_time};\ 335a6f3f80dSScott Kruger fi 33649da0fa4SScott Kruger 3375e361860SScott Krugercheck_output: 3385e361860SScott Kruger $(PYTHON) $(CONFIGDIR)/gmakegentest.py --petsc-dir=$(PETSC_DIR) --petsc-arch=$(PETSC_ARCH) --testdir=$(TESTDIR) --check-output 3395e361860SScott Kruger 34049da0fa4SScott Kruger# Do not how how to invoke test from makefile 34149da0fa4SScott KrugerHASGMAKEFILE := $(filter gmakefile,$(MAKEFILE_LIST)) 34249da0fa4SScott Krugerifeq ($(HASGMAKEFILE),gmakefile) 34349da0fa4SScott Krugerhelpdeps:=help-make help-targets 34449da0fa4SScott Krugermakefile="gmakefile" 345142b82d2SScott Krugerother_help="To see full test help: make -f gmakefile.test help" 34649da0fa4SScott Krugerelse 34749da0fa4SScott Krugerhelpdeps:=help-make help-targets help-test 34849da0fa4SScott Krugermakefile="gmakefile.test" 349142b82d2SScott Krugerother_help="" 35049da0fa4SScott Krugerendif 35149da0fa4SScott Kruger 35249da0fa4SScott Krugerhelp: ${helpdeps} 35349da0fa4SScott Kruger -@echo "Above is from: ${helpdeps}" 354142b82d2SScott Kruger -@echo "${other_help}" 35549da0fa4SScott Kruger 35649da0fa4SScott Krugerhelp-make: 35749da0fa4SScott Kruger -@echo 35849da0fa4SScott Kruger -@echo "Basic build usage:" 35949da0fa4SScott Kruger -@echo " make -f ${makefile} <options>" 36049da0fa4SScott Kruger -@echo 36149da0fa4SScott Kruger -@echo "Options:" 36249da0fa4SScott Kruger -@echo " V=0 Very quiet builds" 36349da0fa4SScott Kruger -@echo " V=1 Verbose builds" 36449da0fa4SScott Kruger -@echo 36549da0fa4SScott Kruger 36649da0fa4SScott Krugerhelp-targets: 36749da0fa4SScott Kruger -@echo "All makefile targets and their dependencies:" 36849da0fa4SScott Kruger -@grep ^[a-z] ${makefile} | grep : | grep -v = 36949da0fa4SScott Kruger -@echo 37049da0fa4SScott Kruger -@echo 37149da0fa4SScott Kruger 37249da0fa4SScott Krugerhelp-test: 37349da0fa4SScott Kruger -@echo "Basic test usage:" 37449da0fa4SScott Kruger -@echo " make -f ${makefile} test <options>" 37549da0fa4SScott Kruger -@echo 37649da0fa4SScott Kruger -@echo "Options:" 37749da0fa4SScott Kruger -@echo " NO_RM=1 Do not remove the executables after running" 378f50802fbSScott Kruger -@echo " REPLACE=1 Replace the output in PETSC_DIR source tree (-m to test scripts)" 3795e361860SScott Kruger -@echo " OUTPUT=1 Show only the errors on stdout" 380f50802fbSScott Kruger -@echo " ALT=1 Replace 'alt' output in PETSC_DIR source tree (-M to test scripts)" 38149da0fa4SScott Kruger -@echo " DIFF_NUMBERS=1 Diff the numbers in the output (-j to test scripts and petscdiff)" 38249da0fa4SScott Kruger -@echo " VALGRIND=1 Execute the tests using valgrind (-V to test scripts)" 383142b82d2SScott Kruger -@echo " NP=<num proc> Set a number of processors to pass to scripts." 384142b82d2SScott Kruger -@echo " FORCE=1 Force SKIP or TODO tests to run" 385a6f3f80dSScott Kruger -@echo " PRINTONLY=1 Print the command, but do not run. For loops print first command" 386142b82d2SScott Kruger -@echo " TIMEOUT=<time> Test timeout limit in seconds (default in config/petsc_harness.sh)" 387f50802fbSScott Kruger -@echo " TESTDIR='tests' Subdirectory where tests are run ($${PETSC_DIR}/$${PETSC_ARCH}/$${TESTDIR}" 38849da0fa4SScott Kruger -@echo " or $${PREFIX_DIR}/$${TESTDIR}" 38949da0fa4SScott Kruger -@echo " or $${PREFIX_DIR}/share/petsc/examples/$${TESTDIR})" 3904ff3c6a1SScott Kruger -@echo " TESTBASE='tests' Subdirectory where tests are run ($${PETSC_DIR}/$${PETSC_ARCH}/$${TESTDIR}" 39149da0fa4SScott Kruger -@echo " OPTIONS='<args>' Override options to scripts (-a to test scripts)" 39249da0fa4SScott Kruger -@echo " EXTRA_OPTIONS='<args>' Add options to scripts (-e to test scripts)" 39349da0fa4SScott Kruger -@echo 39449da0fa4SScott Kruger -@echo "Tests can be generated by searching:" 39549da0fa4SScott Kruger -@echo " Percent is a wildcard (only one allowed):" 39649da0fa4SScott Kruger -@echo " make -f ${makefile} test search=sys%ex2" 39749da0fa4SScott Kruger -@echo 39849da0fa4SScott Kruger -@echo " To match internal substrings (matches *ex2*):" 39949da0fa4SScott Kruger -@echo " make -f ${makefile} test searchin=ex2" 40049da0fa4SScott Kruger -@echo 40149da0fa4SScott Kruger -@echo " Search and searchin can be combined:" 40249da0fa4SScott Kruger -@echo " make -f ${makefile} test search='sys%' searchin=ex2" 40349da0fa4SScott Kruger -@echo 40449da0fa4SScott Kruger -@echo " To match patterns in the arguments:" 40549da0fa4SScott Kruger -@echo " make -f ${makefile} test argsearch=cuda" 40649da0fa4SScott Kruger -@echo 40749da0fa4SScott Kruger -@echo " For general glob-style searching using python:" 40849da0fa4SScott Kruger -@echo " NOTE: uses shell which is possibly slower and more brittle" 40949da0fa4SScott Kruger -@echo " make -f ${makefile} test globsearch='sys*ex2*'" 41049da0fa4SScott Kruger -@echo 411feeaa4f6SScott Kruger -@echo " To re-run the last tests which failed:" 412feeaa4f6SScott Kruger -@echo " make -f ${makefile} test test-fail='1'" 413feeaa4f6SScott Kruger -@echo 4146f5e9bd5SScott Kruger -@echo " To search for fields from the original test definitions:" 4156f5e9bd5SScott Kruger -@echo " make -f ${makefile} test query='requires' queryval='*MPI_PROCESS_SHARED_MEMORY*'" 4166f5e9bd5SScott Kruger -@echo 41749da0fa4SScott Kruger -@echo " To see which targets match a given pattern (useful for doing a specific target):" 41849da0fa4SScott Kruger -@echo " make -f ${makefile} print-test search=sys%" 41949da0fa4SScott Kruger -@echo " which is equivalent to:" 42049da0fa4SScott Kruger -@echo " make -f ${makefile} print VAR=TESTTARGETS search='sys%'" 42149da0fa4SScott Kruger -@echo 42249da0fa4SScott Kruger -@echo " To build an executable, give full path to location:" 423c4762a1bSJed Brown -@echo ' make -f ${makefile} $${PETSC_ARCH}/tests/sys/tests/ex1' 42449da0fa4SScott Kruger -@echo " or make the test with NO_RM=1" 42549da0fa4SScott Kruger -@echo 426