# keep target around, since it's referenced in the modules' Makefiles clean-local-check: @echo if HAVE_VALGRIND # hangs spectacularly on some machines, so let's not do this by default yet check-valgrind: $(MAKE) valgrind else check-valgrind: @true endif LOOPS ?= 10 AM_TESTS_ENVIRONMENT = CK_DEFAULT_TIMEOUT=20 # run any given test by running make test.check # if the test fails, run it again at at least debug level 2 %.check: % @$(AM_TESTS_ENVIRONMENT) \ $* || \ $(AM_TESTS_ENVIRONMENT) \ GST_DEBUG=$$GST_DEBUG,*:2 \ $* # just like 'check', but don't run it again if it fails (useful for debugging) %.check-norepeat: % @$(AM_TESTS_ENVIRONMENT) \ $* # run any given test in a loop %.torture: % @for i in `seq 1 $(LOOPS)`; do \ $(AM_TESTS_ENVIRONMENT) \ $*; done # run any given test in an infinite loop %.forever: % @while true; do \ $(AM_TESTS_ENVIRONMENT) \ $* || break; done # valgrind any given test by running make test.valgrind %.valgrind: % @valgrind_log=$(subst /,-,$*-valgrind.log); \ $(AM_TESTS_ENVIRONMENT) \ CK_DEFAULT_TIMEOUT=360 \ G_SLICE=always-malloc \ $(LIBTOOL) --mode=execute \ $(VALGRIND_PATH) -q \ $(foreach s,$(SUPPRESSIONS),--suppressions=$(s)) \ --tool=memcheck --leak-check=full --trace-children=yes \ --show-possibly-lost=no \ --leak-resolution=high --num-callers=20 \ ./$* 2>&1 | tee $$valgrind_log ; \ if grep "^==" $$valgrind_log > /dev/null 2>&1; then \ rm $$valgrind_log; \ exit 1; \ fi ; \ rm $$valgrind_log # valgrind any given test and generate suppressions for it %.valgrind.gen-suppressions: % @$(AM_TESTS_ENVIRONMENT) \ CK_DEFAULT_TIMEOUT=360 \ G_SLICE=always-malloc \ $(LIBTOOL) --mode=execute \ $(VALGRIND_PATH) -q \ $(foreach s,$(SUPPRESSIONS),--suppressions=$(s)) \ --tool=memcheck --leak-check=full --trace-children=yes \ --show-possibly-lost=no \ --leak-resolution=high --num-callers=20 \ --gen-suppressions=all \ ./$* 2>&1 | tee suppressions.log # valgrind torture any given test %.valgrind-torture: % @for i in `seq 1 $(LOOPS)`; do \ $(MAKE) $*.valgrind || \ (echo "Failure after $$i runs"; exit 1) || \ exit 1; \ done @banner="All $(LOOPS) loops passed"; \ dashes=`echo "$$banner" | sed s/./=/g`; \ echo $$dashes; echo $$banner; echo $$dashes # valgrind any given test until failure by running make test.valgrind-forever %.valgrind-forever: % @while $(MAKE) $*.valgrind; do \ true; done # gdb any given test by running make test.gdb %.gdb: % @$(AM_TESTS_ENVIRONMENT) \ CK_FORK=no \ $(LIBTOOL) --mode=execute \ gdb $(GDB_ARGS) $* %.gdb-forever: % @while $(MAKE) GDB_ARGS="-ex run -ex quit" $*.gdb ; do \ sleep 1; done %.lcov-reset: $(MAKE) $*.lcov-run $(MAKE) $*.lcov-report %.lcov: % $(MAKE) $*.lcov-reset if GST_GCOV_ENABLED %.lcov-clean: $(MAKE) -C $(top_builddir) lcov-clean %.lcov-run: $(MAKE) $*.lcov-clean $(MAKE) $*.check %.lcov-report: $(MAKE) -C $(top_builddir) lcov-report else %.lcov-run: echo "Need to reconfigure with --enable-gcov" %.lcov-report: echo "Need to reconfigure with --enable-gcov" endif # torture tests torture: $(TESTS) -rm test-registry.* @echo "Torturing tests ..." @for i in `seq 1 $(LOOPS)`; do \ $(MAKE) check || \ (echo "Failure after $$i runs"; exit 1) || \ exit 1; \ done @banner="All $(LOOPS) loops passed"; \ dashes=`echo "$$banner" | sed s/./=/g`; \ echo $$dashes; echo $$banner; echo $$dashes # forever tests forever: $(TESTS) -rm test-registry.* @echo "Forever tests ..." @while true; do \ $(MAKE) check || \ (echo "Failure"; exit 1) || \ exit 1; \ done # valgrind all tests valgrind: $(TESTS) @echo "Valgrinding tests ..." @failed=0; valgrind_targets=""; \ for t in $(filter-out $(VALGRIND_TESTS_DISABLE),$(TESTS)); do \ valgrind_targets="$$valgrind_targets $$t.valgrind"; \ done; \ if ! $(MAKE) $$valgrind_targets ; then \ echo "Some tests had leaks or errors under valgrind"; \ false; \ fi # valgrind all tests until failure valgrind-forever: $(TESTS) -rm test-registry.* @echo "Forever valgrinding tests ..." @while true; do \ $(MAKE) valgrind || \ (echo "Failure"; exit 1) || \ exit 1; \ done # valgrind torture all tests valgrind-torture: $(TESTS) -rm test-registry.* @echo "Torturing and valgrinding tests ..." @for i in `seq 1 $(LOOPS)`; do \ $(MAKE) valgrind || \ (echo "Failure after $$i runs"; exit 1) || \ exit 1; \ done @banner="All $(LOOPS) loops passed"; \ dashes=`echo "$$banner" | sed s/./=/g`; \ echo $$dashes; echo $$banner; echo $$dashes # valgrind all tests and generate suppressions valgrind.gen-suppressions: $(TESTS) @echo "Valgrinding tests ..." @failed=0; \ for t in $(filter-out $(VALGRIND_TESTS_DISABLE),$(TESTS)); do \ $(MAKE) $$t.valgrind.gen-suppressions; \ if test "$$?" -ne 0; then \ echo "Valgrind error for test $$t"; \ failed=`expr $$failed + 1`; \ whicht="$$whicht $$t"; \ fi; \ done; \ if test "$$failed" -ne 0; then \ echo "$$failed tests had leaks or errors under valgrind:"; \ echo "$$whicht"; \ false; \ fi # inspect every plugin feature GST_INSPECT = $(GST_TOOLS_DIR)/gst-inspect-$(GST_API_VERSION) inspect: @echo "Inspecting features ..." @for e in `$(AM_TESTS_ENVIRONMENT) $(GST_INSPECT) | head -n -2 \ | cut -d: -f2`; \ do echo Inspecting $$e; \ $(GST_INSPECT) $$e > /dev/null 2>&1; done # build all tests build-checks: $(TESTS) help: @echo @echo "make check -- run all checks" @echo "make torture -- run all checks $(LOOPS) times" @echo "make (dir)/(test).check -- run the given check once, repeat with GST_DEBUG=*:2 if it fails" @echo "make (dir)/(test).check-norepeat -- run the given check once, but don't run it again if it fails" @echo "make (dir)/(test).forever -- run the given check forever" @echo "make (dir)/(test).torture -- run the given check $(LOOPS) times" @echo @echo "make (dir)/(test).gdb -- start up gdb for the given test" @echo @echo "make valgrind -- valgrind all tests" @echo "make valgrind-forever -- valgrind all tests forever" @echo "make valgrind-torture -- valgrind all tests $(LOOPS) times" @echo "make valgrind.gen-suppressions -- generate suppressions for all tests" @echo " and save to suppressions.log" @echo "make (dir)/(test).valgrind -- valgrind the given test" @echo "make (dir)/(test).valgrind-forever -- valgrind the given test forever" @echo "make (dir)/(test).valgrind-torture -- valgrind the given test $(LOOPS) times" @echo "make (dir)/(test).valgrind.gen-suppressions -- generate suppressions" @echo " and save to suppressions.log" @echo "make inspect -- inspect all plugin features" @echo "make build-checks -- build all checks (but don't run them)" @echo @echo @echo "Additionally, you can use the GST_CHECKS environment variable to" @echo "specify which test(s) should be run. This is useful if you are" @echo "debugging a failure in one particular test, or want to reproduce" @echo "a race condition in a single test." @echo @echo "Examples:" @echo @echo " GST_CHECKS=test_this,test_that make element/foobar.check" @echo " GST_CHECKS=test_many_threads make element/foobar.forever" @echo