2 for i in `find . -name ".libs" -type d`; do \
7 # hangs spectacularly on some machines, so let's not do this by default yet
17 # run any given test by running make test.check
18 # if the test fails, run it again at at least debug level 2
20 @$(TESTS_ENVIRONMENT) \
21 CK_DEFAULT_TIMEOUT=20 \
23 $(TESTS_ENVIRONMENT) \
24 GST_DEBUG=$$GST_DEBUG,*:2 \
25 CK_DEFAULT_TIMEOUT=20 \
28 # run any given test in a loop
30 @for i in `seq 1 $(LOOPS)`; do \
31 $(TESTS_ENVIRONMENT) \
32 CK_DEFAULT_TIMEOUT=20 \
35 # run any given test in an infinite loop
38 $(TESTS_ENVIRONMENT) \
39 CK_DEFAULT_TIMEOUT=20 \
42 # valgrind any given test by running make test.valgrind
44 $(TESTS_ENVIRONMENT) \
45 CK_DEFAULT_TIMEOUT=60 \
46 G_SLICE=always-malloc \
47 libtool --mode=execute \
48 $(VALGRIND_PATH) -q --suppressions=$(SUPPRESSIONS) \
49 --tool=memcheck --leak-check=full --trace-children=yes \
50 --leak-resolution=high --num-callers=20 \
51 $* 2>&1 | tee valgrind.log
52 @if grep "==" valgrind.log > /dev/null 2>&1; then \
58 # valgrind any given test and generate suppressions for it
59 %.valgrind.gen-suppressions: %
60 $(TESTS_ENVIRONMENT) \
61 CK_DEFAULT_TIMEOUT=60 \
62 libtool --mode=execute \
63 $(VALGRIND_PATH) -q --suppressions=$(SUPPRESSIONS) \
64 --tool=memcheck --leak-check=full --trace-children=yes \
65 --leak-resolution=high --num-callers=20 \
66 --gen-suppressions=all \
67 $* 2>&1 | tee suppressions.log
69 # valgrind any given test until failure by running make test.valgrind-forever
71 @while make $*.valgrind; do \
74 # gdb any given test by running make test.gdb
76 $(TESTS_ENVIRONMENT) \
78 libtool --mode=execute \
84 @echo "Torturing tests ..."
85 for i in `seq 1 $(LOOPS)`; do \
87 (echo "Failure after $$i runs"; exit 1) || \
90 @banner="All $(LOOPS) loops passed"; \
91 dashes=`echo "$$banner" | sed s/./=/g`; \
92 echo $$dashes; echo $$banner; echo $$dashes
97 @echo "Forever tests ..."
100 (echo "Failure"; exit 1) || \
106 @echo "Valgrinding tests ..."
108 for t in $(filter-out $(VALGRIND_TESTS_DISABLE),$(TESTS)); do \
110 if test "$$?" -ne 0; then \
111 echo "Valgrind error for test $$t"; \
112 failed=`expr $$failed + 1`; \
113 whicht="$$whicht $$t"; \
116 if test "$$failed" -ne 0; then \
117 echo "$$failed tests had leaks or errors under valgrind:"; \
123 @echo "make check -- run all checks"
124 @echo "make torture -- run all checks $(LOOPS) times"
125 @echo "make (dir)/(test).check -- run the given check once"
126 @echo "make (dir)/(test).forever -- run the given check forever"
127 @echo "make (dir)/(test).torture -- run the given check $(LOOPS) times"
129 @echo "make (dir)/(test).gdb -- start up gdb for the given test"
131 @echo "make valgrind -- valgrind all tests"
132 @echo "make (dir)/(test).valgrind -- valgrind the given test"
133 @echo "make (dir)/(test).valgrind-forever -- valgrind the given test forever"