diff options
author | Richard W.M. Jones <rjones@redhat.com> | 2011-12-22 12:00:44 +0000 |
---|---|---|
committer | Richard W.M. Jones <rjones@redhat.com> | 2011-12-22 15:47:29 +0000 |
commit | c649817586e5b4df53b251d1290422f5ef046045 (patch) | |
tree | 34cd0c1ae9153478de9fa2fac6497fae7d305d47 /tests/extra | |
parent | 498758faee6be7e989869bf7feba5e1026a1bb65 (diff) | |
download | libguestfs-c649817586e5b4df53b251d1290422f5ef046045.tar.gz libguestfs-c649817586e5b4df53b251d1290422f5ef046045.tar.xz libguestfs-c649817586e5b4df53b251d1290422f5ef046045.zip |
tests: Rename extratests -> tests/extra.
Diffstat (limited to 'tests/extra')
-rw-r--r-- | tests/extra/Makefile.am | 159 | ||||
-rw-r--r-- | tests/extra/suppressions | 132 |
2 files changed, 291 insertions, 0 deletions
diff --git a/tests/extra/Makefile.am b/tests/extra/Makefile.am new file mode 100644 index 00000000..7d1cc22e --- /dev/null +++ b/tests/extra/Makefile.am @@ -0,0 +1,159 @@ +# libguestfs +# Copyright (C) 2009-2011 Red Hat Inc. +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + +# Extra tests. +# +# Requires: +# - some local libvirt guests are available +# - the disks of these guests are accessible by the current user +# (tip: add yourself to the 'disk' group) +# - valgrind +# - libtool +# +# These tests may fail for reasons which aren't necessarily real problems. +# +# XXX Not tested: +# +# ../clone/virt-sysprep +# - hard to test because it's a shell script +# +# ../edit/virt-edit +# +# Perl bindings +# ../edit/virt-edit -e +# ../tools/virt-win-reg (Perl) +# ../tools/virt-make-fs (Perl) +# - hard because Perl doesn't cooperate by freeing memory +# +# Python bindings +# - as for Perl +# +# Ruby bindings +# - these look feasible to test using valgrind +# +# Java bindings +# +# ../fuse/guestmount +# - hard to test because guestmount forks into the background, and +# if valgrind reports errors it doesn't stop the test shell script + +EXTRA_DIST = suppressions + +VG = valgrind \ + --log-file=$(abs_builddir)/valgrind.log \ + --leak-check=full \ + --error-exitcode=119 \ + --suppressions=$(abs_srcdir)/suppressions +RUN_VG = $(abs_top_builddir)/run $(VG) + +export LIBVIRT_DEFAULT_URI = \ + qemu+unix:///system?socket=/var/run/libvirt/libvirt-sock-ro + +GUESTS = $(shell virsh -c $(LIBVIRT_DEFAULT_URI) list --all | \ + head -n -1 | \ + tail -n +3 | \ + awk '{print $$2}') + +extra-tests: \ + test-prerequisites \ + test-c-api \ + test-tools-null \ + test-tools-internal \ + test-df-real \ + test-filesystems-real \ + test-inspector-real \ + test-ocaml \ + test-resize \ + test-sparsify + +test-prerequisites: + @libtool --help >/dev/null 2>&1 || { \ + echo "extra-tests: libtool is not installed"; \ + exit 1; \ + } + @valgrind --help >/dev/null 2>&1 || { \ + echo "extra-tests: valgrind is not installed"; \ + exit 1; \ + } + +# Null invocations of the basic tools shouldn't leak memory. +test-tools-null: + $(RUN_VG) ../../fish/guestfish -N part exit + $(RUN_VG) ../../align/virt-alignment-scan -a test1.img >/dev/null + rm test1.img + $(RUN_VG) ../../cat/virt-filesystems -a /dev/null >/dev/null + $(RUN_VG) ../../cat/virt-filesystems -a /dev/null --all --long -h --uuid >/dev/null + $(RUN_VG) ../../df/virt-df -a /dev/null >/dev/null + $(RUN_VG) ../../fish/guestfish -a /dev/null run + $(RUN_VG) ../../inspector/virt-inspector -a /dev/null >/dev/null + $(RUN_VG) ../../test-tool/libguestfs-test-tool >/dev/null 2>&1 + +# Invocations of tools on internal images shouldn't leak memory. +test-tools-internal: + $(RUN_VG) ../../cat/virt-cat -a ../images/fedora.img /etc/fstab >/dev/null + $(RUN_VG) ../../cat/virt-filesystems -a ../images/fedora.img >/dev/null + $(RUN_VG) ../../cat/virt-filesystems -a ../images/fedora.img --all --long -h --uuid >/dev/null + $(RUN_VG) ../../cat/virt-ls -a ../images/fedora.img / >/dev/null + $(RUN_VG) ../../cat/virt-ls -a ../images/fedora.img -l / >/dev/null + $(RUN_VG) ../../cat/virt-ls -a ../images/fedora.img -R / >/dev/null + $(RUN_VG) ../../cat/virt-ls -a ../images/fedora.img -lR / >/dev/null + $(RUN_VG) ../../df/virt-df -a ../images/fedora.img >/dev/null + $(RUN_VG) ../../df/virt-df -a ../images/fedora.img -h >/dev/null + $(RUN_VG) ../../fish/guestfish -a ../images/fedora.img run + $(RUN_VG) ../../fish/guestfish -a ../images/fedora.img -i exit + $(RUN_VG) ../../inspector/virt-inspector -a ../images/debian.img >/dev/null + $(RUN_VG) ../../inspector/virt-inspector -a ../images/fedora.img >/dev/null + $(RUN_VG) ../../inspector/virt-inspector -a ../images/fedora-md1.img -a ../images/fedora-md2.img >/dev/null + $(RUN_VG) ../../inspector/virt-inspector -a ../images/ubuntu.img >/dev/null + $(RUN_VG) ../../inspector/virt-inspector -a ../images/windows.img >/dev/null + +# Invocations of tools on real images shouldn't leak memory. +test-df-real: + $(RUN_VG) ../../df/virt-df >/dev/null + $(RUN_VG) ../../df/virt-df -h >/dev/null + +test-filesystems-real: + @for g in $(GUESTS); do \ + echo $(RUN_VG) ../../cat/virt-filesystems -d $$g --all --long -h --uuid; \ + $(RUN_VG) ../../cat/virt-filesystems -d $$g --all --long -h --uuid > /dev/null; \ + r=$$?; \ + if [ $$r -ne 0 ]; then exit $$r; fi; \ + done + +test-inspector-real: + @for g in $(GUESTS); do \ + echo $(RUN_VG) ../../inspector/virt-inspector -d $$g; \ + $(RUN_VG) ../../inspector/virt-inspector -d $$g > /dev/null; \ + r=$$?; \ + if [ $$r -ne 0 ]; then exit $$r; fi; \ + done + +# Run virt-resize tests under valgrind. +test-resize: + $(MAKE) -C ../../resize VG="$(VG)" check + +# Run virt-sparsify tests under valgrind. +test-sparsify: + $(MAKE) -C ../../sparsify VG="$(VG)" check + +# Run c-api tests under valgrind. +test-c-api: + $(MAKE) -C ../c-api VG="$(RUN_VG)" check + +# Test OCaml bindings under valgrind. +test-ocaml: + $(MAKE) -C ../../ocaml VG="$(VG)" check diff --git a/tests/extra/suppressions b/tests/extra/suppressions new file mode 100644 index 00000000..4dc02d2f --- /dev/null +++ b/tests/extra/suppressions @@ -0,0 +1,132 @@ +# libnuma +{ + libnuma_numa_node_size64_cond + Memcheck:Cond + fun:* + fun:numa_node_size64 + fun:numa_init +} +{ + libnuma_numa_node_size64_cond_2 + Memcheck:Cond + fun:numa_node_size64 + fun:numa_init +} +{ + libnuma_numa_node_size64_cond_3 + Memcheck:Cond + fun:* + fun:numa_node_size64 + obj:/usr/lib64/libnuma.so.1 +} +{ + libnuma_numa_node_size64_cond_4 + Memcheck:Cond + fun:numa_node_size64 + obj:/usr/lib64/libnuma.so.1 +} +{ + libnuma_numa_node_size64_value8 + Memcheck:Value8 + fun:numa_node_size64 + fun:numa_init +} +{ + libnuma_numa_node_size64_value8_2 + Memcheck:Value8 + fun:numa_node_size64 + obj:/usr/lib64/libnuma.so.1 +} + +# libnl +{ + libnl_add_routing_table_name_leak + Memcheck:Leak + fun:malloc + fun:strdup + fun:add_routing_table_name +} +{ + libnl_add_routing_table_name_leak_2 + Memcheck:Leak + fun:calloc + fun:add_routing_table_name +} +{ + libnl_add_proto_name_leak + Memcheck:Leak + fun:malloc + fun:strdup + fun:add_proto_name +} +{ + libnl_add_proto_name_leak_2 + Memcheck:Leak + fun:calloc + fun:add_proto_name +} +{ + libnl1_malloc_leak + Memcheck:Leak + fun:malloc + fun:strdup + obj:/usr/lib/libnl.so.1.1 +} +{ + libnl1_malloc_leak_2 + Memcheck:Leak + fun:malloc + fun:strdup + obj:/lib64/libnl.so.1.1 +} +{ + libnl1_calloc_leak + Memcheck:Leak + fun:calloc + obj:/usr/lib/libnl.so.1.1 +} +{ + libnl1_calloc_leak_2 + Memcheck:Leak + fun:calloc + obj:/lib64/libnl.so.1.1 +} + +# OCaml, by design, doesn't bother to free the major heap before +# calling exit. Ignore that leak. +{ + ocaml_heap_leak + Memcheck:Leak + ... + fun:caml_alloc_for_heap +} +# On the other hand, these seem to be a real bugs in OCaml: +{ + ocaml_heap_leak_2 + Memcheck:Leak + fun:malloc + fun:caml_thread_new_descriptor + fun:caml_thread_new +} +{ + ocaml_heap_leak_3 + Memcheck:Leak + fun:malloc + fun:caml_thread_new_descriptor + fun:caml_thread_initialize +} +{ + ocaml_heap_leak_4 + Memcheck:Leak + ... + fun:pthread_create* + ... + fun:caml_thread_new +} +{ + ocaml_heap_leak_5 + Memcheck:Leak + fun:malloc + fun:caml_stat_alloc + fun:caml_threadstatus_new +} |