149da0fa4SScott Kruger# -*- mode: makefile-gmake -*- 249da0fa4SScott Kruger 337ed16bcSStefano ZampiniCONFIGDIR := $(PETSC_DIR)/config 449da0fa4SScott Kruger 5fc46264cSScott Kruger# TESTSRCDIR is always relative to gmakefile.test 6fc46264cSScott Kruger# This must be before includes 75b5a9be8SJed Brownmkfile_path := $(abspath $(lastword $(MAKEFILE_LIST))) 85b5a9be8SJed BrownTESTSRCDIR := $(dir $(mkfile_path))src 9fc46264cSScott Kruger 104ff3c6a1SScott Krugerinclude $(PETSC_DIR)/$(PETSC_ARCH)/lib/petsc/conf/petscvariables 114ff3c6a1SScott Krugerinclude $(PETSC_DIR)/lib/petsc/conf/variables 1249da0fa4SScott Kruger 138e69c5ecSJed BrownTESTDIR ?= ./$(PETSC_ARCH)/tests 144ff3c6a1SScott KrugerMODDIR := $(PETSC_DIR)/$(PETSC_ARCH)/include 156e5deea7SScott KrugerTESTLOGTAPFILE ?= $(TESTDIR)/test_tap.log 166e5deea7SScott KrugerTESTLOGERRFILE ?= $(TESTDIR)/test_err.log 1794666443SJed BrownEXAMPLESDIR := $(TESTSRCDIR) 1849da0fa4SScott Kruger 1949da0fa4SScott Krugerpkgs := sys vec mat dm ksp snes ts tao 2049da0fa4SScott Kruger 214ff3c6a1SScott Krugerpetscconf := $(PETSC_DIR)/$(PETSC_ARCH)/include/petscconf.h 224ff3c6a1SScott Krugerpetscvariables := $(PETSC_DIR)/$(PETSC_ARCH)/lib/petsc/conf/petscvariables 238e69c5ecSJed Browngeneratedtest := $(TESTDIR)/testfiles 2449da0fa4SScott Kruger 2549da0fa4SScott Kruger.SECONDEXPANSION: # to expand $$(@D)/.DIR 2649da0fa4SScott Kruger 2749da0fa4SScott KrugerTESTFLAGS := # Initialize as simple variable 2849da0fa4SScott Kruger 2949da0fa4SScott Kruger#workarround old cygwin versions 3049da0fa4SScott Krugerifeq ($(PETSC_CYGWIN_BROKEN_PIPE),1) 3149da0fa4SScott Krugerifeq ($(shell basename $(AR)),ar) 3249da0fa4SScott Kruger V ?=1 3349da0fa4SScott Krugerendif 3449da0fa4SScott Krugerendif 3549da0fa4SScott KrugerV ?= $(if $(findstring s,$(MAKEFLAGS)),0) 3649da0fa4SScott Krugerifeq ($(V),) # Default 3749da0fa4SScott Kruger quiet_HELP := "Use \"$(MAKE) V=1\" to see verbose compile lines, \"$(MAKE) V=0\" to suppress.\n" 3849da0fa4SScott Kruger quiet = @printf $(quiet_HELP)$(eval quiet_HELP:=)" %10s %s\n" "$1$2" "$@"; $($1) 3949da0fa4SScott Kruger quiettest = @printf " %10s %s\n" "TEST" "$(@:$(TESTDIR)/counts/%.counts=%)"; 4049da0fa4SScott Krugerelse ifeq ($(V),0) # Suppress entire command 4149da0fa4SScott Kruger quiet = @$($1) 4249da0fa4SScott Kruger quiettest = @ 435e361860SScott Kruger TESTFLAGS += -o err_only 4449da0fa4SScott Krugerelse # Show the full command line 4549da0fa4SScott Kruger quiet = $($1) 4649da0fa4SScott Kruger quiettest = 4749da0fa4SScott Kruger TESTFLAGS += -v 4849da0fa4SScott Krugerendif 4949da0fa4SScott Kruger 5049da0fa4SScott Krugerifeq ($(FORCE),1) 5149da0fa4SScott Kruger TESTFLAGS += -f # force test execution 5249da0fa4SScott Krugerendif 5349da0fa4SScott Krugerifeq ($(VALGRIND),1) 5449da0fa4SScott Kruger TESTFLAGS += -V # Add valgrind to the flags 5549da0fa4SScott Krugerendif 5649da0fa4SScott Krugerifeq ($(REPLACE),1) 5749da0fa4SScott Kruger TESTFLAGS += -m # Replace results by passing -m to petscdiff 5849da0fa4SScott Krugerendif 595e361860SScott Krugerifeq ($(OUTPUT),1) 605e361860SScott Kruger TESTFLAGS += -o 'err_only' # Show only the errors on stdout 615e361860SScott Krugerendif 62f50802fbSScott Krugerifeq ($(ALT),1) 63f50802fbSScott Kruger TESTFLAGS += -M # Replace alt files by passing -M to petscdiff 64f50802fbSScott Krugerendif 6549da0fa4SScott Krugerifeq ($(DIFF_NUMBERS),1) 6649da0fa4SScott Kruger TESTFLAGS += -j # Pass -j to petscdiff to diff the actual numbers 6749da0fa4SScott Krugerendif 6849da0fa4SScott Krugerifdef OPTIONS 6949da0fa4SScott Kruger TESTFLAGS += -a '$(OPTIONS)' # override arguments 7049da0fa4SScott Krugerendif 7149da0fa4SScott Krugerifdef EXTRA_OPTIONS 7249da0fa4SScott Kruger TESTFLAGS += -e '$(EXTRA_OPTIONS)' # add extra arguments 7349da0fa4SScott Krugerendif 7449da0fa4SScott Krugerifdef NP 7549da0fa4SScott Kruger TESTFLAGS += -n $(NP) # set number of processes 7649da0fa4SScott Krugerendif 7749da0fa4SScott Kruger# Override the default timeout that may be found at the top of config/petsc_harness.sh 7849da0fa4SScott Kruger# This must be an integer. It is given in seconds. 7949da0fa4SScott Krugerifdef TIMEOUT 8049da0fa4SScott Kruger TESTFLAGS += -t $(TIMEOUT) # Override the default timeout 8149da0fa4SScott Krugerendif 8249da0fa4SScott Kruger 83fc46264cSScott Kruger$(generatedtest) : $(petscconf) $(petscvariables) $(CONFIGDIR)/gmakegentest.py $(TESTDIR)/.DIR | $$(@D)/.DIR 848e69c5ecSJed Brown $(PYTHON) $(CONFIGDIR)/gmakegentest.py --petsc-dir=$(PETSC_DIR) --petsc-arch=$(PETSC_ARCH) --testdir=$(TESTDIR) 8549da0fa4SScott Kruger 86535b694aSJed Brownifneq ($(MAKECMDGOALS:clean%=clean),clean) 8749da0fa4SScott Kruger-include $(generatedtest) 88535b694aSJed Brownendif 8949da0fa4SScott Kruger 9049da0fa4SScott Krugerifeq ($(PETSC_LANGUAGE),CXXONLY) 9149da0fa4SScott Kruger cc_name := CXX 9249da0fa4SScott Krugerelse 9349da0fa4SScott Kruger cc_name := CC 9449da0fa4SScott Krugerendif 9549da0fa4SScott Kruger 9649da0fa4SScott KrugerPETSC_COMPILE.c = $(call quiet,$(cc_name)) -c $(PCC_FLAGS) $(CFLAGS) $(CCPPFLAGS) $(C_DEPFLAGS) 9749da0fa4SScott KrugerPETSC_COMPILE.cxx = $(call quiet,CXX) -c $(CXX_FLAGS) $(CFLAGS) $(CCPPFLAGS) $(CXX_DEPFLAGS) 9849da0fa4SScott KrugerPETSC_COMPILE.cu = $(call quiet,CUDAC) -c $(CUDAC_FLAGS) --compiler-options="$(PCC_FLAGS) $(CXXFLAGS) $(CCPPFLAGS)" 9949da0fa4SScott KrugerPETSC_GENDEPS.cu = $(call quiet,CUDAC,.dep) --generate-dependencies --output-directory=$(@D) $(CUDAC_FLAGS) --compiler-options="$(PCC_FLAGS) $(CXXFLAGS) $(CCPPFLAGS)" 10049da0fa4SScott KrugerPETSC_COMPILE.F = $(call quiet,FC) -c $(FC_FLAGS) $(FFLAGS) $(FCPPFLAGS) $(FC_DEPFLAGS) 10149da0fa4SScott Kruger 10249da0fa4SScott Krugertestlangs := c cu cxx F F90 103513d7a9cSJed Brown$(foreach lang, $(testlangs), $(eval \ 104513d7a9cSJed Brown testexe.$(lang) = $(foreach pkg, $(pkgs), $(testsrcs-$(pkg).$(lang):%.$(lang)=$(TESTDIR)/%)))) 10549da0fa4SScott Krugerconcattestlang = $(foreach lang, $(2), $(testsrcs-$(1).$(lang):%.$(lang)=$(TESTDIR)/%.o)) 10649da0fa4SScott Krugertestsrcs.o := $(foreach pkg, $(pkgs), $(call concattestlang,$(pkg),$(testlangs))) 107fc46264cSScott Krugertestsrcs-rel := $(foreach pkg, $(pkgs), $(foreach lang, $(testlangs), $(testsrcs-$(pkg).$(lang)))) 108fc46264cSScott Krugertestsrcs := $(foreach sfile, $(testsrcs-rel), $(TESTSRCDIR)/$(sfile)) 10949da0fa4SScott Kruger 11049da0fa4SScott Kruger# Refresh testfiles when sources change, but don't balk if the source file is nonexistent (deleted) 11149da0fa4SScott Kruger$(generatedtest) : $(testsrcs) 11249da0fa4SScott Kruger$(testsrcs) : 11349da0fa4SScott Kruger 1144ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.c | $$(@D)/.DIR 11549da0fa4SScott Kruger $(PETSC_COMPILE.c) $(abspath $<) -o $@ 11649da0fa4SScott Kruger 1174ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.cxx | $$(@D)/.DIR 11849da0fa4SScott Kruger $(PETSC_COMPILE.cxx) $(abspath $<) -o $@ 11949da0fa4SScott Kruger 1204ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.cu | $$(@D)/.DIR 12149da0fa4SScott Kruger $(PETSC_COMPILE.cu) $(abspath $<) -o $@ # Compile first so that if there is an error, it comes from a normal compile 12249da0fa4SScott Kruger @$(PETSC_GENDEPS.cu) $(abspath $<) -o $(@:%.o=%.d) # Generate the dependencies for later 12349da0fa4SScott Kruger 124a55d2495SJed Brown# Test modules go in the same directory as the target *.o 125a55d2495SJed BrownTESTMODDIR = $(@D) 12649da0fa4SScott KrugerFCMOD = cd 1274ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.F | $$(@D)/.DIR 12849da0fa4SScott Krugerifeq ($(FC_MODULE_OUTPUT_FLAG),) 129a55d2495SJed Brown $(call quiet,FCMOD) $(TESTMODDIR) && $(FC) -c $(FC_FLAGS) $(FFLAGS) $(FCPPFLAGS) $(FC_DEPFLAGS) -I$(dir $<) $(abspath $<) -o $(abspath $@) 13049da0fa4SScott Krugerelse 131a55d2495SJed Brown $(PETSC_COMPILE.F) -I$(dir $<) $(abspath $<) -o $@ $(FC_MODULE_OUTPUT_FLAG)$(TESTMODDIR) $(FC_MODULE_FLAG)$(TESTMODDIR) 13249da0fa4SScott Krugerendif 1330266c241SJed Brown -@$(GFORTRAN_DEP_CLEANUP) 13449da0fa4SScott Kruger 1354ff3c6a1SScott Kruger$(TESTDIR)/%.o : $(EXAMPLESDIR)/%.F90 | $$(@D)/.DIR 13649da0fa4SScott Krugerifeq ($(FC_MODULE_OUTPUT_FLAG),) 137a55d2495SJed Brown $(call quiet,FCMOD) $(TESTMODDIR) && $(FC) -c $(FC_FLAGS) $(FFLAGS) $(FCPPFLAGS) $(FC_DEPFLAGS) -I$(dir $<) $(abspath $<) -o $(abspath $@) 13849da0fa4SScott Krugerelse 139a55d2495SJed Brown $(PETSC_COMPILE.F) -I$(dir $<) $(abspath $<) -o $@ $(FC_MODULE_OUTPUT_FLAG)$(TESTMODDIR) $(FC_MODULE_FLAG)$(TESTMODDIR) 14049da0fa4SScott Krugerendif 1410266c241SJed Brown -@$(GFORTRAN_DEP_CLEANUP) 1420266c241SJed Brown 143cf7d3547SScott Kruger# This is a hack to fix a broken gfortran. 1440266c241SJed Browndefine GFORTRAN_DEP_CLEANUP 1450266c241SJed Brown if test -e "$(@:%.o=%.d)" && head -1 "$(@:%.o=%.d)" | fgrep -q -v : ; then\ 1464f45eea9SScott Kruger echo "$(@): \\" > $(@:%.o=%.dtemp) ; \ 1470266c241SJed Brown tr '\n' '@' < $(@:%.o=%.d) | cut -d: -f2- | tr '@' '\n' >> $(@:%.o=%.dtemp) ; \ 1480266c241SJed Brown mv $(@:%.o=%.dtemp) $(@:%.o=%.d); \ 1494f45eea9SScott Kruger fi 1500266c241SJed Brownendef 15149da0fa4SScott Kruger 15220844ca6SSatish Balay# link line constructed differently for gmakefile vs gmakefile.test invocation 15320844ca6SSatish Balayifeq ($(libpetscall),) 15420844ca6SSatish BalayPETSC_TEST_LIB = $(PETSC_LIB) 15520844ca6SSatish Balayelse 15620844ca6SSatish BalayPETSC_TEST_LIB = $(C_SH_LIB_PATH) $(PETSC_EXTERNAL_LIB_BASIC) 15720844ca6SSatish Balayendif 15820844ca6SSatish Balay 159bde159b7SSatish Balay# manually list some some library dependencies to check for circular dependencies 160bde159b7SSatish Balay$(TESTDIR)/sys/examples/tests/ex9: PETSC_TEST_LIB = $(PETSC_SYS_LIB) 161bde159b7SSatish Balay$(TESTDIR)/vec/vec/examples/tests/ex1: PETSC_TEST_LIB = $(PETSC_VEC_LIB) 162bde159b7SSatish Balay$(TESTDIR)/mat/examples/tests/ex1: PETSC_TEST_LIB = $(PETSC_MAT_LIB) 163bde159b7SSatish Balay$(TESTDIR)/dm/examples/tests/ex1: PETSC_TEST_LIB = $(PETSC_DM_LIB) 164bde159b7SSatish Balay$(TESTDIR)/ksp/ksp/examples/tests/ex1: PETSC_TEST_LIB = $(PETSC_KSP_LIB) 165bde159b7SSatish Balay$(TESTDIR)/snes/examples/tests/ex1: PETSC_TEST_LIB = $(PETSC_SNES_LIB) 166bde159b7SSatish Balay$(TESTDIR)/ts/examples/tests/ex2: PETSC_TEST_LIB = $(PETSC_TS_LIB) 167bde159b7SSatish Balay$(TESTDIR)/tao/examples/tutorials/ex1: PETSC_TEST_LIB = $(PETSC_TAO_LIB) 168bde159b7SSatish Balay 16949da0fa4SScott Kruger# Test executables 170513d7a9cSJed Brown$(testexe.F) $(testexe.F90) : $(TESTDIR)/% : $(TESTDIR)/%.o $$^ $(libpetscall) 17120844ca6SSatish Balay $(call quiet,FLINKER) -o $@ $^ $(PETSC_TEST_LIB) 17249da0fa4SScott Kruger 173513d7a9cSJed Brown$(testexe.c) $(testexe.cu) : $(TESTDIR)/% : $(TESTDIR)/%.o $$^ $(libpetscall) 17420844ca6SSatish Balay $(call quiet,CLINKER) -o $@ $^ $(PETSC_TEST_LIB) 17549da0fa4SScott Kruger 176513d7a9cSJed Brown$(testexe.cxx) : $(TESTDIR)/% : $(TESTDIR)/%.o $$^ $(libpetscall) 1772f4326f3SSatish Balay $(call quiet,CXXLINKER) -o $@ $^ $(PETSC_TEST_LIB) 178513d7a9cSJed Brown 17949da0fa4SScott Kruger# Fortran source files need petsc*.mod, which isn't explicitly managed in the makefile. 18049da0fa4SScott Kruger$(foreach pkg, $(pkgs), $(call concattestlang,$(pkg),F F90)) : $(libpetscall) 18149da0fa4SScott Kruger 18249da0fa4SScott Kruger# Testing convenience targets 183c173c275SScott Kruger.PHONY: test pre-clean 184c173c275SScott Kruger 1855e361860SScott Krugertest: report_tests check-test-errors 186c173c275SScott Kruger 18749da0fa4SScott Krugerpre-clean: 1885e361860SScott Kruger @$(RM) -rf $(TESTDIR)/counts $(TESTLOGTAPFILE) $(TESTLOGERRFILE) 1895e361860SScott Kruger @touch $(TESTLOGTAPFILE) $(TESTLOGERRFILE) 19027d73d1fSBarry Smith @echo "Using MAKEFLAGS:" ${MAKEFLAGS} 19149da0fa4SScott Kruger 1924d9d3ee5SSatish Balaycheck-test-errors: 1935e361860SScott Kruger @grep '^not ok' $(TESTLOGTAPFILE) | grep -v 'Exceeded timeout' | tee $(TESTDIR)/allgtests-tap-err.log 1944d9d3ee5SSatish Balay @test ! -s $(TESTDIR)/allgtests-tap-err.log 1954d9d3ee5SSatish Balay 19649da0fa4SScott Kruger.PHONY: $(foreach pkg, $(pkgs), test-$(pkg) $(foreach lang, $(testlangs), test-$(pkg).$(lang) test-rm-$(pkg).$(lang))) 19749da0fa4SScott Krugertestpkgs := $(foreach pkg, $(pkgs), test-$(pkg)) 19849da0fa4SScott Kruger# Targets to run tests in test-$pkg.$lang and delete the executables, language by language 19949da0fa4SScott Kruger$(testpkgs) : test-% : $(foreach lang, $(testlangs), test-rm-%.$(lang)) 20049da0fa4SScott Kruger# List of raw test run targets 20149da0fa4SScott Krugeralltesttargets := $(foreach tp, $(testpkgs), $(foreach lang, $(testlangs), $($(tp).$(lang)))) 20249da0fa4SScott Kruger 20349da0fa4SScott Kruger# Run targets 20449da0fa4SScott Kruger$(alltesttargets) : % : $(TESTDIR)/counts/%.counts 20549da0fa4SScott Kruger.PHONY: $(alltesttargets) 20649da0fa4SScott Kruger 20749da0fa4SScott Kruger$(TESTDIR)/counts/%.counts : 20849da0fa4SScott Kruger $(quiettest) $< $(TESTFLAGS) 20949da0fa4SScott Kruger 21049da0fa4SScott Kruger# Targets to run tests and remove executables, by package-lang pairs. 21149da0fa4SScott Kruger# Run the tests in each batch using recursive invocation of make because 21249da0fa4SScott Kruger# we need all of them to complete before removing the executables. Make 21349da0fa4SScott Kruger# doesn't guarantee an exploration order for the graph. Only recursive 21449da0fa4SScott Kruger# if there is something to be done. 21549da0fa4SScott Krugeralltest-rm := $(foreach pkg, $(pkgs), $(foreach lang, $(testlangs), test-rm-$(pkg).$(lang))) 21649da0fa4SScott Kruger$(alltest-rm) : test-rm-% : test-% 21749da0fa4SScott Krugerifneq ($(NO_RM),1) 21849da0fa4SScott Kruger $(call quiet,RM) $(addprefix $(TESTDIR)/,$(basename $($(@:test-rm-%=testsrcs-%)))) 21949da0fa4SScott Krugerendif 22049da0fa4SScott Kruger 22149da0fa4SScott Kruger# Remove intermediate .o files 22249da0fa4SScott Kruger# This only removes the files at the end which is insufficient 22349da0fa4SScott Kruger#.INTERMEDIATE: $(testsrcs.o:%.o=%) 22449da0fa4SScott Kruger 22549da0fa4SScott Kruger# all sources should get recompiled when petscvariables changes (i.e when configure is rerun or when petscvariables is manually edited.) 22649da0fa4SScott Kruger$(testsrcs.o) : $(petscvariables) 22749da0fa4SScott Kruger 22849da0fa4SScott Kruger%/.DIR : 22949da0fa4SScott Kruger @mkdir -p $(@D) 23049da0fa4SScott Kruger @touch $@ 23149da0fa4SScott Kruger 23249da0fa4SScott Kruger.PRECIOUS: %/.DIR 23349da0fa4SScott Kruger 23449da0fa4SScott Kruger.SUFFIXES: # Clear .SUFFIXES because we don't use implicit rules 23549da0fa4SScott Kruger.DELETE_ON_ERROR: # Delete likely-corrupt target file if rule fails 23649da0fa4SScott Kruger 23737ed16bcSStefano Zampini.PHONY: clean cleantest all 23849da0fa4SScott Kruger 23949da0fa4SScott Krugercleantest: 24049da0fa4SScott Kruger ${RM} -r $(TESTDIR) $(generatedtest) 24149da0fa4SScott Kruger 24249da0fa4SScott Krugerclean: cleantest 24349da0fa4SScott Kruger 24449da0fa4SScott Krugeralltest.d := $(testsrcs.o:%.o=%.d) 24549da0fa4SScott Kruger# Tell make that alltest.d are all up to date. Without this, the include 24649da0fa4SScott Kruger# below has quadratic complexity, taking more than one second for a 24749da0fa4SScott Kruger# do-nothing build of PETSc (much worse for larger projects) 24849da0fa4SScott Kruger$(alltest.d) : ; 24949da0fa4SScott Kruger 25049da0fa4SScott Kruger-include $(alltest.d) 25149da0fa4SScott Kruger 25249da0fa4SScott Kruger# Tests can be generated by searching 25349da0fa4SScott Kruger# Percent is a wildcard (only one allowed): 25449da0fa4SScott Kruger# make -f gmakefile test search=sys%ex2 25549da0fa4SScott Kruger# To match internal substrings (matches *ex2*): 25649da0fa4SScott Kruger# make -f gmakefile test searchin=ex2 25749da0fa4SScott Kruger# Search and searchin can be combined: 25849da0fa4SScott Kruger# make -f gmakefile test search='sys%' searchin=ex2 25949da0fa4SScott Kruger# For args: 26049da0fa4SScott Kruger# make -f gmakefile test argsearch=cuda 26149da0fa4SScott Kruger# For general glob-style searching using python: 26249da0fa4SScott Kruger# NOTE: uses shell which is possibly slower and is possibly more brittle 26349da0fa4SScott Kruger# make -f gmakefile test globsearch='sys*ex2*' 26449da0fa4SScott Krugerifdef search 26549da0fa4SScott Kruger TESTTARGETS := $(filter $(search),$(alltesttargets)) 26649da0fa4SScott Kruger ifdef searchin 26749da0fa4SScott Kruger TESTTARGETS2 := $(foreach v,$(TESTTARGETS),$(if $(findstring $(searchin),$(v)),$(v))) 26849da0fa4SScott Kruger TESTTARGETS := $(TESTTARGETS2) 26949da0fa4SScott Kruger endif 27049da0fa4SScott Krugerelse ifdef searchin 27149da0fa4SScott Kruger TESTTARGETS := $(foreach v,$(alltesttargets),$(if $(findstring $(searchin),$(v)),$(v))) 27249da0fa4SScott Krugerelse ifdef argsearch 27349da0fa4SScott Kruger TESTTARGETS := $(foreach v,$(alltesttargets),$(if $(findstring $(argsearch),$($(v)_ARGS)),$(v))) 27449da0fa4SScott Krugerelse ifdef globsearch 2755e361860SScott Kruger TESTTARGETS := $(shell $(PYTHON) -c"import sys,fnmatch,itertools; m=[fnmatch.filter(sys.argv[2].split(),p) for p in sys.argv[1].split()]; print(' '.join(list(itertools.chain.from_iterable(m))))" '$(globsearch)' '$(alltesttargets)') 27649da0fa4SScott Krugerelse # No filter - run them all, but delete the executables as we go 27749da0fa4SScott Kruger TESTTARGETS := $(testpkgs) 27849da0fa4SScott Krugerendif 27949da0fa4SScott Kruger 28049da0fa4SScott Kruger.PHONY: report_tests print-test 28149da0fa4SScott Kruger 28249da0fa4SScott Krugerprint-test: 28349da0fa4SScott Kruger -@echo $(TESTTARGETS) 28449da0fa4SScott Kruger 2856e5deea7SScott Krugershow-fail: 286*b711b6a4SScott Kruger -@$(PYTHON) $(CONFIGDIR)/report_tests.py -d $(TESTDIR)/counts -f 287*b711b6a4SScott Kruger 2886e5deea7SScott Kruger 2896e5deea7SScott Kruger 290c01c7e64SJed Brown# Don't start running tests until starttime has completed 291c01c7e64SJed Brown$(alltesttargets:%=$(TESTDIR)/counts/%.counts) : starttime 292c01c7e64SJed Brown 293c01c7e64SJed Brown# Ensure that libpetsc (if it is a prerequisite) has been built and clean the counts/logs before starting timer 294c01c7e64SJed Brownstarttime: pre-clean $(libpetscall) 29527d73d1fSBarry Smith @$(eval STARTTIME := $(shell date +%s)) 29627d73d1fSBarry Smith 29727d73d1fSBarry Smithreport_tests: starttime $(TESTTARGETS) 29832f4009dSScott Kruger @$(eval ENDTIME := $(shell date +%s)) 29932f4009dSScott Kruger -@elapsed_time=$$(($(ENDTIME)- $(STARTTIME))) && \ 30032f4009dSScott Kruger $(PYTHON) $(CONFIGDIR)/report_tests.py -m $(MAKE) -d $(TESTDIR)/counts -t 5 -e $${elapsed_time} 30149da0fa4SScott Kruger 3025e361860SScott Krugercheck_output: 3035e361860SScott Kruger $(PYTHON) $(CONFIGDIR)/gmakegentest.py --petsc-dir=$(PETSC_DIR) --petsc-arch=$(PETSC_ARCH) --testdir=$(TESTDIR) --check-output 3045e361860SScott Kruger 30549da0fa4SScott Kruger# Do not how how to invoke test from makefile 30649da0fa4SScott KrugerHASGMAKEFILE := $(filter gmakefile,$(MAKEFILE_LIST)) 30749da0fa4SScott Krugerifeq ($(HASGMAKEFILE),gmakefile) 30849da0fa4SScott Krugerhelpdeps:=help-make help-targets 30949da0fa4SScott Krugermakefile="gmakefile" 310142b82d2SScott Krugerother_help="To see full test help: make -f gmakefile.test help" 31149da0fa4SScott Krugerelse 31249da0fa4SScott Krugerhelpdeps:=help-make help-targets help-test 31349da0fa4SScott Krugermakefile="gmakefile.test" 314142b82d2SScott Krugerother_help="" 31549da0fa4SScott Krugerendif 31649da0fa4SScott Kruger 31749da0fa4SScott Krugerhelp: ${helpdeps} 31849da0fa4SScott Kruger -@echo "Above is from: ${helpdeps}" 319142b82d2SScott Kruger -@echo "${other_help}" 32049da0fa4SScott Kruger 32149da0fa4SScott Krugerhelp-make: 32249da0fa4SScott Kruger -@echo 32349da0fa4SScott Kruger -@echo "Basic build usage:" 32449da0fa4SScott Kruger -@echo " make -f ${makefile} <options>" 32549da0fa4SScott Kruger -@echo 32649da0fa4SScott Kruger -@echo "Options:" 32749da0fa4SScott Kruger -@echo " V=0 Very quiet builds" 32849da0fa4SScott Kruger -@echo " V=1 Verbose builds" 32949da0fa4SScott Kruger -@echo 33049da0fa4SScott Kruger 33149da0fa4SScott Krugerhelp-targets: 33249da0fa4SScott Kruger -@echo "All makefile targets and their dependencies:" 33349da0fa4SScott Kruger -@grep ^[a-z] ${makefile} | grep : | grep -v = 33449da0fa4SScott Kruger -@echo 33549da0fa4SScott Kruger -@echo 33649da0fa4SScott Kruger 33749da0fa4SScott Krugerhelp-test: 33849da0fa4SScott Kruger -@echo "Basic test usage:" 33949da0fa4SScott Kruger -@echo " make -f ${makefile} test <options>" 34049da0fa4SScott Kruger -@echo 34149da0fa4SScott Kruger -@echo "Options:" 34249da0fa4SScott Kruger -@echo " NO_RM=1 Do not remove the executables after running" 343f50802fbSScott Kruger -@echo " REPLACE=1 Replace the output in PETSC_DIR source tree (-m to test scripts)" 3445e361860SScott Kruger -@echo " OUTPUT=1 Show only the errors on stdout" 345f50802fbSScott Kruger -@echo " ALT=1 Replace 'alt' output in PETSC_DIR source tree (-M to test scripts)" 34649da0fa4SScott Kruger -@echo " DIFF_NUMBERS=1 Diff the numbers in the output (-j to test scripts and petscdiff)" 34749da0fa4SScott Kruger -@echo " VALGRIND=1 Execute the tests using valgrind (-V to test scripts)" 348142b82d2SScott Kruger -@echo " NP=<num proc> Set a number of processors to pass to scripts." 349142b82d2SScott Kruger -@echo " FORCE=1 Force SKIP or TODO tests to run" 350142b82d2SScott Kruger -@echo " TIMEOUT=<time> Test timeout limit in seconds (default in config/petsc_harness.sh)" 351f50802fbSScott Kruger -@echo " TESTDIR='tests' Subdirectory where tests are run ($${PETSC_DIR}/$${PETSC_ARCH}/$${TESTDIR}" 35249da0fa4SScott Kruger -@echo " or $${PREFIX_DIR}/$${TESTDIR}" 35349da0fa4SScott Kruger -@echo " or $${PREFIX_DIR}/share/petsc/examples/$${TESTDIR})" 3544ff3c6a1SScott Kruger -@echo " TESTBASE='tests' Subdirectory where tests are run ($${PETSC_DIR}/$${PETSC_ARCH}/$${TESTDIR}" 35549da0fa4SScott Kruger -@echo " OPTIONS='<args>' Override options to scripts (-a to test scripts)" 35649da0fa4SScott Kruger -@echo " EXTRA_OPTIONS='<args>' Add options to scripts (-e to test scripts)" 35749da0fa4SScott Kruger -@echo 35849da0fa4SScott Kruger -@echo "Tests can be generated by searching:" 35949da0fa4SScott Kruger -@echo " Percent is a wildcard (only one allowed):" 36049da0fa4SScott Kruger -@echo " make -f ${makefile} test search=sys%ex2" 36149da0fa4SScott Kruger -@echo 36249da0fa4SScott Kruger -@echo " To match internal substrings (matches *ex2*):" 36349da0fa4SScott Kruger -@echo " make -f ${makefile} test searchin=ex2" 36449da0fa4SScott Kruger -@echo 36549da0fa4SScott Kruger -@echo " Search and searchin can be combined:" 36649da0fa4SScott Kruger -@echo " make -f ${makefile} test search='sys%' searchin=ex2" 36749da0fa4SScott Kruger -@echo 36849da0fa4SScott Kruger -@echo " To match patterns in the arguments:" 36949da0fa4SScott Kruger -@echo " make -f ${makefile} test argsearch=cuda" 37049da0fa4SScott Kruger -@echo 37149da0fa4SScott Kruger -@echo " For general glob-style searching using python:" 37249da0fa4SScott Kruger -@echo " NOTE: uses shell which is possibly slower and more brittle" 37349da0fa4SScott Kruger -@echo " make -f ${makefile} test globsearch='sys*ex2*'" 37449da0fa4SScott Kruger -@echo 37549da0fa4SScott Kruger -@echo " To see which targets match a given pattern (useful for doing a specific target):" 37649da0fa4SScott Kruger -@echo " make -f ${makefile} print-test search=sys%" 37749da0fa4SScott Kruger -@echo " which is equivalent to:" 37849da0fa4SScott Kruger -@echo " make -f ${makefile} print VAR=TESTTARGETS search='sys%'" 37949da0fa4SScott Kruger -@echo 38049da0fa4SScott Kruger -@echo " To build an executable, give full path to location:" 38194666443SJed Brown -@echo ' make -f ${makefile} $${PETSC_ARCH}/tests/sys/examples/tests/ex1' 38249da0fa4SScott Kruger -@echo " or make the test with NO_RM=1" 38349da0fa4SScott Kruger -@echo 384