summaryrefslogtreecommitdiff
path: root/qpid/cpp/src/tests/vg_check
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2007-07-19 17:09:09 +0000
committerAlan Conway <aconway@apache.org>2007-07-19 17:09:09 +0000
commit75f3fcdc8f144c95e787f349a59c8f43d105e67d (patch)
treec4854e97daae90eb1256b3590a42324a9cb68eb9 /qpid/cpp/src/tests/vg_check
parent524bf4773f63f5b35e51fee8b35de4f1c9c695b3 (diff)
downloadqpid-python-75f3fcdc8f144c95e787f349a59c8f43d105e67d.tar.gz
* src/tests/start_broker, stop_broker: Use valgrind on broker.
* src/tests/run_test, vg_check: - factored valgrind check out of run_test for reuse in stop_broker. * src/tests/Makefile.am, stop_broker, README: - kill_broker renamed stop_broker. git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk@557692 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src/tests/vg_check')
-rw-r--r--qpid/cpp/src/tests/vg_check23
1 files changed, 23 insertions, 0 deletions
diff --git a/qpid/cpp/src/tests/vg_check b/qpid/cpp/src/tests/vg_check
new file mode 100644
index 0000000000..e9a691abe6
--- /dev/null
+++ b/qpid/cpp/src/tests/vg_check
@@ -0,0 +1,23 @@
+# Check for valgrind errors. Sourced by test scripts.
+
+vg_failed() {
+ cat $VG_LOG 1>&2
+ echo $1 1>&2
+ exit 1
+}
+
+vg_check()
+{
+ test -z "$1" || VG_LOG=$1
+ test -f $VG_LOG || vg_failed Valgrind log file $VG_LOG missing.
+ # Ensure there is an ERROR SUMMARY line.
+ grep -E '^==[0-9]+== ERROR SUMMARY:' $VG_LOG > /dev/null || \
+ vg_failed "No valgrind ERROR SUMMARY line in $$vg_failed."
+ # Ensure that the number of errors is 0.
+ grep -E '^==[0-9]+== ERROR SUMMARY: [^0]' $VG_LOG > /dev/null && \
+ vg_failed "Valgrind reported errors in $vg_out; see above."
+ # Check for leaks.
+ grep -E '^==[0-9]+== +.* lost: [^0]' $VG_LOG && \
+ vg_failed "Found memory leaks (see log file, $VG_LOG); see above."
+ true
+}