mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-18 10:04:20 +03:00
4937df4aed
Add limit for buffer so if the test is running in some loop and generating lots of output, the output log gets too large for browser to display (at least Firefox is quite confused to display 300MB logs). For now limit max output of one test to 32MB. If there is need to see full log set LVM_TEST_UNLIMITED to disable interruption of test. harness now also prints max memory used during test, it user and system time and amount of read/write operations.
153 lines
5.0 KiB
Makefile
153 lines
5.0 KiB
Makefile
# Copyright (C) 2007-2013 Red Hat, Inc. All rights reserved.
|
|
#
|
|
# This file is part of LVM2.
|
|
#
|
|
# This copyrighted material is made available to anyone wishing to use,
|
|
# modify, copy, or redistribute it subject to the terms and conditions
|
|
# of the GNU General Public License v.2.
|
|
#
|
|
# 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
#TEST_OPTS=--verbose --debug
|
|
SHELL_PATH ?= $(SHELL)
|
|
RM ?= rm -f
|
|
|
|
subdir = $(shell pwd|sed 's,.*/,,')
|
|
|
|
srcdir = @srcdir@
|
|
top_srcdir = @top_srcdir@
|
|
top_builddir = @top_builddir@
|
|
abs_srcdir = "@abs_srcdir@"
|
|
abs_builddir = "@abs_builddir@"
|
|
abs_top_builddir = "@abs_top_builddir@"
|
|
abs_top_srcdir = "@abs_top_srcdir@"
|
|
|
|
LVM_TEST_RESULTS ?= results
|
|
SUBDIRS = api unit
|
|
SOURCES = lib/not.c lib/harness.c
|
|
|
|
include $(top_builddir)/make.tmpl
|
|
|
|
T ?= .
|
|
S ?= @ # never match anything by default
|
|
VERBOSE ?= 0
|
|
ALL = $(shell find $(srcdir) \( -path \*/shell/\*.sh -or -path \*/api/\*.sh \) | sort)
|
|
RUN = $(shell find $(srcdir) -regextype posix-egrep \( -path \*/shell/\*.sh -or -path \*/api/\*.sh \) -and -regex "$(srcdir)/.*($(T)).*" -and -not -regex "$(srcdir)/.*($(S)).*" | sort)
|
|
RUN_BASE = $(subst $(srcdir)/,,$(RUN))
|
|
|
|
# Shell quote;
|
|
SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
|
|
|
|
ifeq ("@UDEV_SYNC@", "yes")
|
|
dm_udev_synchronisation = 1
|
|
endif
|
|
|
|
all: check
|
|
|
|
help:
|
|
@echo -e "\nAvailable targets:"
|
|
@echo " all Default target, run check."
|
|
@echo " check Run all tests."
|
|
@echo " check_local Run tests without clvmd and lvmetad."
|
|
@echo " check_cluster Run tests with cluster daemon."
|
|
@echo " check_lvmetad Run tests with lvmetad daemon."
|
|
@echo " clean Clean dir."
|
|
@echo " help Display callable targets."
|
|
@echo -e "\nSupported variables:"
|
|
@echo " LVM_TEST_DEVDIR Set to '/dev' to run on real /dev."
|
|
@echo " LVM_TEST_DIR Where to create test files [TMPDIR]."
|
|
@echo " LVM_TEST_LOCKING Normal (1), Cluster (3)."
|
|
@echo " LVM_TEST_LVMETAD Start lvmetad (1)."
|
|
@echo " LVM_TEST_NODEBUG Do not debug lvm commands."
|
|
@echo " LVM_TEST_PARALLEL May skip agresive wipe of LVMTEST resources."
|
|
@echo " LVM_TEST_RESULTS Where to create result files [results]."
|
|
@echo " LVM_TEST_UNLIMITED Set to get unlimited test log (>32MB)"
|
|
@echo " LVM_VERIFY_UDEV Default verify state for lvm.conf."
|
|
@echo " S Skip given test (regex)."
|
|
@echo " T Run given test (regex)."
|
|
@echo " VERBOSE Verbose output (1), timing (2)."
|
|
|
|
check: .tests-stamp
|
|
VERBOSE=$(VEROSE) \
|
|
cluster_LVM_TEST_LOCKING=3 \
|
|
lvmetad_LVM_TEST_LVMETAD=1 \
|
|
./lib/harness $(patsubst %,normal:%,$(RUN_BASE)) \
|
|
$(patsubst %,cluster:%,$(RUN_BASE)) \
|
|
$(patsubst %,lvmetad:%,$(RUN_BASE))
|
|
|
|
check_cluster: .tests-stamp
|
|
@echo Testing with locking_type 3
|
|
VERBOSE=$(VERBOSE) LVM_TEST_LOCKING=3 ./lib/harness $(RUN_BASE)
|
|
|
|
check_local: .tests-stamp
|
|
@echo Testing with locking_type 1
|
|
VERBOSE=$(VERBOSE) LVM_TEST_LOCKING=1 ./lib/harness $(RUN_BASE)
|
|
|
|
check_lvmetad: .tests-stamp
|
|
@echo Testing with lvmetad on
|
|
VERBOSE=$(VERBOSE) LVM_TEST_LVMETAD=1 ./lib/harness $(RUN_BASE)
|
|
|
|
lib/should: lib/not
|
|
ln -sf not lib/should
|
|
|
|
lib/%: lib/%.o .lib-dir-stamp
|
|
$(CC) $(LDFLAGS) -o $@ $<
|
|
|
|
lib/%: $(srcdir)/lib/%.sh .lib-dir-stamp
|
|
cp $< $@
|
|
chmod +x $@
|
|
|
|
lib/paths: $(srcdir)/Makefile.in .lib-dir-stamp
|
|
$(RM) $@-t
|
|
echo 'top_srcdir=$(top_srcdir)' >> $@-t
|
|
echo 'abs_top_builddir=$(abs_top_builddir)' >> $@-t
|
|
echo 'abs_top_srcdir=$(abs_top_srcdir)' >> $@-t
|
|
echo 'abs_srcdir=$(abs_srcdir)' >> $@-t
|
|
echo 'abs_builddir=$(abs_builddir)' >> $@-t
|
|
echo 'export DM_UDEV_SYNCHRONISATION=$(dm_udev_synchronisation)' >> $@-t
|
|
echo 'export THIN=@THIN@' >> $@-t
|
|
echo 'export LVMETAD_PIDFILE=@LVMETAD_PIDFILE@' >> $@-t
|
|
mv $@-t $@
|
|
|
|
LIB = lib/not lib/should lib/harness \
|
|
lib/check lib/aux lib/test lib/utils lib/get lib/lvm-wrapper \
|
|
lib/paths
|
|
|
|
CMDS = lvm $(shell cat $(top_builddir)/tools/.commands)
|
|
|
|
.tests-stamp: $(ALL) $(LIB) $(SUBDIRS)
|
|
@if test "$(srcdir)" != . ; then \
|
|
echo "Linking tests to builddir."; \
|
|
$(MKDIR_P) shell; \
|
|
for f in $(subst $(srcdir)/,,$(ALL)); do \
|
|
ln -sf $(abs_top_srcdir)/test/$$f $$f; \
|
|
done; \
|
|
fi
|
|
@$(MKDIR_P) -m a=rwx $(LVM_TEST_RESULTS)
|
|
touch $@
|
|
|
|
.lib-dir-stamp:
|
|
$(MKDIR_P) lib
|
|
for i in $(CMDS); do ln -fs lvm-wrapper lib/$$i; done
|
|
ln -fs $(abs_top_builddir)/tools/dmsetup lib/dmsetup
|
|
ln -fs $(abs_top_builddir)/daemons/clvmd/clvmd lib/clvmd
|
|
ln -fs $(abs_top_builddir)/daemons/dmeventd/dmeventd lib/dmeventd
|
|
ln -fs $(abs_top_builddir)/daemons/lvmetad/lvmetad lib/lvmetad
|
|
ln -fs $(abs_top_srcdir)/scripts/vgimportclone.sh lib/vgimportclone
|
|
ln -fs $(abs_top_srcdir)/scripts/fsadm.sh lib/fsadm
|
|
touch $@
|
|
|
|
clean:
|
|
test "$(srcdir)" = . || $(RM) $(RUN_BASE)
|
|
$(RM) -r $(LVM_TEST_RESULTS)
|
|
|
|
CLEAN_TARGETS += .lib-dir-stamp .tests-stamp $(LIB) $(addprefix lib/,$(CMDS)) \
|
|
lib/clvmd lib/dmeventd lib/dmsetup lib/lvmetad lib/fsadm lib/vgimportclone
|
|
|
|
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
|
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
|
|
|
|
.NOTPARALLEL:
|