[CRIU] [PATCH] tests: remove zdtm.sh (v2)

Andrey Vagin avagin at openvz.org
Sat Feb 20 08:27:41 PST 2016


From: Andrew Vagin <avagin at virtuozzo.com>

It was replaced by zdtm.py.

v2: remove zdtm.sh from other scripts
    remove fault-injection, because nobody uses it

Signed-off-by: Andrew Vagin <avagin at virtuozzo.com>
---
 Makefile                                 |    2 +-
 test/jenkins/ppc.sh                      |    4 -
 test/maps.py                             |   16 -
 test/others/fault-injection/Makefile     |    2 -
 test/others/fault-injection/parasite.stp |   44 --
 test/zdtm.sh                             | 1249 ------------------------------
 6 files changed, 1 insertion(+), 1316 deletions(-)
 delete mode 100644 test/jenkins/ppc.sh
 delete mode 100644 test/maps.py
 delete mode 100644 test/others/fault-injection/Makefile
 delete mode 100644 test/others/fault-injection/parasite.stp
 delete mode 100755 test/zdtm.sh

diff --git a/Makefile b/Makefile
index 836c745..2906249 100644
--- a/Makefile
+++ b/Makefile
@@ -201,7 +201,7 @@ docker-build:
 PHONY += docker-build
 
 docker-test:
-	docker run --rm -it --privileged criu-x86_64 ./test/zdtm.sh -C -x tcp6 -x tcpbuf6 -x static/rtc -x cgroup -x mountpoint
+	docker run --rm -it --privileged criu-x86_64 ./test/zdtm.py run -a -x tcp6 -x tcpbuf6 -x static/rtc -x cgroup
 PHONY += docker-test
 
 help:
diff --git a/test/jenkins/ppc.sh b/test/jenkins/ppc.sh
deleted file mode 100644
index c05822b..0000000
--- a/test/jenkins/ppc.sh
+++ /dev/null
@@ -1,4 +0,0 @@
-source `dirname $0`/criu-lib.sh &&
-prep &&
-bash ./test/zdtm.sh -C -x '\(fpu\|mmx\|sse\|rtc\|ext_auto\)' &&
-true || fail
diff --git a/test/maps.py b/test/maps.py
deleted file mode 100644
index 1b7f96c..0000000
--- a/test/maps.py
+++ /dev/null
@@ -1,16 +0,0 @@
-import sys
-start = 0;
-end = 0;
-
-for l in sys.stdin:
-	l = l.split()[0]
-	s, e = l.split('-')
-	s = int("0x" + s, 0)
-	e = int("0x" + e, 0)
-	if end == s:
-		end = e;
-	else:
-		print "%x-%x" % (start, end)
-		start = s
-		end = e
-print "%x-%x" % (start, end)
diff --git a/test/others/fault-injection/Makefile b/test/others/fault-injection/Makefile
deleted file mode 100644
index 23257eb..0000000
--- a/test/others/fault-injection/Makefile
+++ /dev/null
@@ -1,2 +0,0 @@
-all:
-	stap -g -d ../../../criu/criu parasite.stp $$RANDOM -c 'bash -x ../zdtm.sh -d -x socket-tcp'
diff --git a/test/others/fault-injection/parasite.stp b/test/others/fault-injection/parasite.stp
deleted file mode 100644
index c1b0818..0000000
--- a/test/others/fault-injection/parasite.stp
+++ /dev/null
@@ -1,44 +0,0 @@
-global i, n, fini_cmd = -1, last_cmd
-
-probe process("../../criu/criu").begin
-{
-	i = 0;
-	/* randint() returns numbers multiple of 5 */
-	n = randint(20 * 5) / 5
-	printf("The %d command will be replaced on -1\n", n);
-}
-
-probe process("../../criu/criu").function("__parasite_execute_daemon")
-{
-	printf("%s\n", $$parms);
-	last_cmd = $cmd;
-	if (++i > n) {
-		printf("Send invalid command to parasite\n");
-		$cmd = -1;
-	}
-}
-
-probe process("../../criu/criu").function("__parasite_execute_daemon").return
-{
-	printf("%d\n", $return);
-}
-
-probe process("../../criu/criu").function("main").return
-{
-	printf("CRIU exits with code %d\n", $return);
-	if  ( i > n) {
-		if ($return)
-			$return = 0;
-		else {
-			printf("CRIU exited with zero code\n");
-			if (fini_cmd < 0 || fini_cmd == last_cmd) {
-				printf("%d looks like FINI command\n", n);
-				fini_cmd = last_cmd
-			} else {
-				printf("This is the second FINI command %d (%d)",
-								n, fini_cmd);
-				$return = 1;
-			}
-		}
-	}
-}
diff --git a/test/zdtm.sh b/test/zdtm.sh
deleted file mode 100755
index 8b8faf5..0000000
--- a/test/zdtm.sh
+++ /dev/null
@@ -1,1249 +0,0 @@
-#!/bin/bash
-
-# duplicate stdout into 3
-exec 3<&1
-# duplicate stderr into stdout
-exec 1>&2
-
-ARCH=`uname -m | sed			\
-		-e s/i.86/i386/		\
-		-e s/sun4u/sparc64/	\
-		-e s/s390x/s390/	\
-		-e s/parisc64/parisc/	\
-		-e s/mips.*/mips/	\
-		-e s/sh[234].*/sh/`
-
-ZP="zdtm/live"
-
-source $(readlink -f `dirname $0`/env.sh) || exit 1
-
-generate_test_list()
-{
-
-	check_mainstream || exit 1
-
-	TEST_LIST="
-		static/pipe00
-		static/pipe01
-		static/pipe02
-		static/busyloop00
-		static/cwd00
-		static/cwd01
-		static/cwd02
-		static/env00
-		static/maps00
-		static/maps01
-		static/maps02
-		static/maps04
-		static/maps05
-		static/mlock_setuid
-		static/maps_file_prot
-		static/mprotect00
-		static/mtime_mmap
-		static/sleeping00
-		static/write_read00
-		static/write_read01
-		static/write_read02
-		static/write_read10
-		static/wait00
-		static/vdso00
-		static/sched_prio00
-		static/sched_policy00
-		static/file_shared
-		static/file_append
-		static/timers
-		static/posix_timers
-		static/futex
-		static/futex-rl
-		static/xids00
-		static/groups
-		static/pthread00
-		static/pthread01
-		static/umask00
-		streaming/pipe_loop00
-		streaming/pipe_shared00
-		transition/file_read
-		static/sockets00
-		static/sockets01
-		static/sockets02
-		static/sock_opts00
-		static/sock_opts01
-		static/sockets_spair
-		static/sockets_dgram
-		static/socket_dgram_data
-		static/socket_queues
-		static/deleted_unix_sock
-		static/sk-unix-unconn
-		static/sk-unix-rel
-		static/pid00
-		static/pstree
-		static/caps00
-		static/cmdlinenv00
-		static/socket_listen
-		static/socket_listen6
-		static/packet_sock
-		static/packet_sock_mmap
-		static/socket_udp
-		static/sock_filter
-		static/socket6_udp
-		static/socket_udplite
-		static/selfexe00
-		static/link10
-		static/unlink_fstat00
-		static/unlink_fstat01
-		static/unlink_fstat02
-		static/unlink_fstat03
-		static/unlink_mmap00
-		static/unlink_mmap01
-		static/unlink_mmap02
-		static/rmdir_open
-		static/eventfs00
-		static/signalfd00
-		static/inotify00
-		static/inotify02
-		static/inotify_irmap
-		static/fanotify00
-		static/unbound_sock
-		static/fifo-rowo-pair
-		static/fifo-ghost
-		static/fifo
-		static/fifo_wronly
-		static/fifo_ro
-		static/unlink_fifo
-		static/unlink_fifo_wronly
-		static/zombie00
-		static/rlimits00
-		transition/fork
-		transition/fork2
-		transition/thread-bomb
-		static/pty00
-		static/pty01
-		static/pty04
-		static/tty02
-		static/tty03
-		static/console
-		static/vt
-		static/child_opened_proc
-		static/cow01
-		static/pdeath_sig
-		static/fdt_shared
-		static/file_locks00
-		static/file_locks01
-		static/file_locks02
-		static/file_locks03
-		static/file_locks04
-		static/file_locks05
-		static/sigpending
-		static/sigaltstack
-		static/sk-netlink
-		static/proc-self
-		static/grow_map
-		static/grow_map02
-		static/grow_map03
-		static/stopped
-		static/chroot
-		static/chroot-file
-		static/rtc
-		transition/maps007
-		static/dumpable01
-		static/dumpable02
-		static/deleted_dev
-		static/socket-tcpbuf-local
-		static/socket-tcpbuf6-local
-		static/socket-tcp-local
-		static/socket-tcp6-local
-	"
-
-	#
-	# Arch specific tests
-	if [ $ARCH = "x86_64" ]; then
-		TEST_LIST_ARCH="
-			static/fpu00
-			static/fpu01
-			static/mmx00
-			static/sse00
-			static/sse20
-			static/vdso01
-		"
-	fi
-
-	if [ $ARCH = "ppc64le" ]; then
-		TEST_LIST_ARCH="
-			static/vsx
-		"
-	fi
-
-	TEST_LIST=$TEST_LIST$TEST_LIST_ARCH
-
-	# Duplicate list with ns/ prefix
-	TEST_LIST=$TEST_LIST$(echo $TEST_LIST | tr ' ' '\n' | sed 's#^#ns/#')
-
-	# These ones are not in ns
-	TEST_LIST="$TEST_LIST
-		static/file_fown
-		static/socket-ext
-		static/socket-tcp
-		static/socket-tcp6
-		streaming/socket-tcp
-		streaming/socket-tcp6
-		static/socket-tcpbuf
-		static/socket-tcpbuf6
-		static/pty03
-		ns/static/mountpoints
-		ns/static/session00
-		ns/static/session01
-		ns/static/tempfs
-		ns/static/tempfs_ro
-		ns/static/tempfs_subns
-		ns/static/mnt_ro_bind
-		ns/static/mount_paths
-		ns/static/bind-mount
-		ns/static/utsname
-		ns/static/ipc_namespace
-		ns/static/shm
-		ns/static/msgque
-		ns/static/sem
-		ns/transition/ipc
-		ns/static/netns-dev
-		static/cgroup00
-		static/cgroup01
-		static/cgroup02
-		static/cgroup03
-		ns/static/clean_mntns
-		static/remap_dead_pid
-		static/poll
-		static/apparmor
-		ns/static/apparmor
-		static/different_creds
-	"
-
-	TEST_CR_KERNEL="
-	"
-
-	TEST_MNTNS="
-		ns/static/mnt_ext_auto
-		ns/static/mnt_ext_master
-		ns/static/mntns_open
-		ns/static/mntns_link_remap
-		ns/static/mntns_link_ghost
-		ns/static/mntns_shared_bind
-		ns/static/mntns_shared_bind02
-		ns/static/mntns_root_bind
-		ns/static/mntns_root_bind02
-		ns/static/mntns_deleted
-		ns/static/inotify01
-		ns/static/mntns_rw_ro_rw
-	"
-
-	TEST_AIO="
-		static/aio00
-		ns/static/aio00
-	"
-
-	TEST_TIMERFD="
-		static/timerfd
-		ns/static/timerfd
-	"
-
-	TEST_TUN="
-		ns/static/tun
-	"
-	TEST_SECCOMP_SUSPEND="
-		static/seccomp_strict
-	"
-
-	TEST_SECCOMP_FILTERS="
-		static/seccomp_filter
-		static/seccomp_filter_tsync
-		static/seccomp_filter_inheritance
-	"
-
-	$CRIU check -v0 --feature "mnt_id"
-	if [ $? -eq 0 ]; then
-		TEST_LIST="$TEST_LIST$TEST_MNTNS"
-	else
-		export ZDTM_NOSUBNS=1
-	fi
-
-	$CRIU check -v0 --feature "aio_remap"
-	if [ $? -eq 0 ]; then
-		TEST_LIST="$TEST_LIST$TEST_AIO"
-	fi
-
-	$CRIU check -v0 --feature "timerfd"
-	if [ $? -eq 0 ]; then
-		TEST_LIST="$TEST_LIST$TEST_TIMERFD"
-	fi
-
-	$CRIU check -v0 --feature "tun"
-	if [ $? -eq 0 ]; then
-		TEST_LIST="$TEST_LIST$TEST_TUN"
-	fi
-
-	$CRIU check -v0 --feature "seccomp_suspend"
-	if [ $? -eq 0 ]; then
-		TEST_LIST="$TEST_LIST$TEST_SECCOMP_SUSPEND"
-	fi
-
-	$CRIU check -v0 --feature "seccomp_filters"
-	if [ $? -eq 0 ]; then
-		TEST_LIST="$TEST_LIST$TEST_SECCOMP_FILTERS"
-	fi
-
-	# ns/static/clean_mntns: proc can't be mounted in userns, if it isn't mounted yet
-
-	BLACKLIST_FOR_USERNS="
-		ns/static/maps01
-		ns/static/mlock_setuid
-		ns/static/sched_prio00
-		ns/static/sched_policy00
-		ns/static/fanotify00
-		ns/static/dumpable02
-		ns/static/deleted_dev
-		ns/static/clean_mntns
-		ns/static/mntns_link_remap
-		ns/static/mntns_link_ghost
-		ns/static/console
-		ns/static/vt
-		ns/static/rtc
-		ns/static/cow01
-		ns/static/tempfs_ro
-		ns/static/ipc_namespace
-	"
-
-	# Add tests which can be executed in an user namespace
-	$CRIU check -v0 --feature "userns"
-	if [ $? -eq 0 ]; then
-		blist=`mktemp /tmp/zdtm.black.XXXXXX`
-		echo "$BLACKLIST_FOR_USERNS" | tr -d "[:blank:]" | sort > $blist
-
-
-		TEST_LIST="$TEST_LIST
-		`echo "$TEST_LIST" | tr -d "[:blank:]" | grep "^ns/" | sort | \
-		diff --changed-group-format="%<" --unchanged-group-format="" - $blist | \
-		sed s#ns/#ns/user/#`"
-		unlink $blist
-	fi
-
-	TEST_LIST=$(echo $TEST_LIST | tr " " "\n")
-}
-
-TEST_SUID_LIST="
-pid00
-caps00
-maps01
-mlock_setuid
-groups
-sched_prio00
-sched_policy00
-sock_opts00
-sock_opts01
-cmdlinenv00
-packet_sock
-packet_sock_mmap
-fanotify00
-sk-netlink
-tun
-chroot
-chroot-file
-console
-vt
-rtc
-maps007
-tempfs
-tempfs_ro
-tempfs_subns
-mnt_ro_bind
-bind-mount
-mountpoints
-inotify_irmap
-cgroup00
-cgroup01
-cgroup02
-cgroup03
-clean_mntns
-deleted_dev
-mntns_open
-mntns_link_remap
-mntns_link_ghost
-mntns_shared_bind
-mntns_shared_bind02
-mntns_root_bind
-mntns_root_bind02
-mntns_rw_ro_rw
-mntns_deleted
-mount_paths
-netns-dev
-sockets00
-cow01
-apparmor
-seccomp_strict
-seccomp_filter
-seccomp_filter_tsync
-seccomp_filter_inheritance
-different_creds
-inotify01
-ipc_namespace
-utsname
-"
-
-TEST_EXPECTED_FAILURE="
-static/different_creds
-"
-
-CRIU_CPT=$CRIU
-TMP_TREE=""
-SCRIPTDIR=`dirname $CRIU`/test
-POSTDUMP="--action-script $SCRIPTDIR/post-dump.sh"
-VERBOSE=0
-
-PID=""
-PIDNS=""
-
-ITERATIONS=1
-EXCLUDE_PATTERN=""
-CLEANUP=0
-PAGE_SERVER=0
-PS_PORT=12345
-COMPILE_ONLY=0
-START_ONLY=0
-BATCH_TEST=0
-SPECIFIED_NAME_USED=0
-START_FROM="."
-RESTORE_SIBLING=""
-FREEZE_CGROUP=""
-
-zdtm_sep()
-{ (
-	set +x
-	local msg=$1
-	[ -n "$msg" ] && msg=" $msg "
-	awk -v m=${2:-=} -v "msg=$msg" '
-		BEGIN {
-			l=length(msg);
-			s=int((79-l)/2);
-			sep = sprintf("%"s"s", " ")
-			gsub(/ /, m, sep);
-			printf("%s%s%s\n",sep,msg,sep);
-		}' < /dev/null
-) }
-
-check_criu()
-{
-	if [ ! -x $CRIU ]; then
-		echo "$CRIU is unavailable"
-		return 1
-	fi
-}
-
-check_mainstream()
-{
-	zdtm_sep "CRIU CHECK"
-
-	$CRIU check -v1 && return 0
-	MAINSTREAM_KERNEL=1
-
-	cat >&2 <<EOF
-============================= WARNING =============================
-Not all features needed for CRIU are merged to upstream kernel yet,
-so for now we maintain our own branch which can be cloned from:
-git://git.kernel.org/pub/scm/linux/kernel/git/gorcunov/linux-cr.git
-===================================================================
-EOF
-
-	set -- `uname -r | sed 's/[\.-]/ /g'`
-
-	[ $1 -gt 3 ] && return 0
-	[ $1 -eq 3 -a $2 -ge 11 ] && return 0
-
-	echo "Kernel version should be greater than or equal to 3.11" >&2
-
-	return 1
-}
-
-exit_callback()
-{
-	echo $@
-	if [ -n "$ZDTM_ROOT" ]; then
-		umount -l "$ZDTM_ROOT"
-		rmdir "$ZDTM_ROOT"
-	fi
-
-	[[ -n "$ZDTM_FAILED" && -n "$DUMP_ARCHIVE" ]] && tar -czf $DUMP_ARCHIVE dump
-	[ -n "$TMPFS_DUMP" ] &&
-		umount -l "$TMPFS_DUMP"
-}
-trap exit_callback EXIT
-
-construct_root()
-{
-	local root=$1
-	local test_path=$2
-	local ps_path=`type -P ps`
-	local libdir=$root/lib
-	local libdir2=$root/lib64
-	local tmpdir=$root/tmp
-	local lname tname
-
-	# inotify_irmap creates files in /etc so it should be able to do
-	# this from userns.
-	mkdir -m 0777 -p $root/etc
-
-	mkdir -p $root/bin
-	cp $ps_path $root/bin
-
-	mkdir -p $libdir $libdir2
-
-	# $ ldd /bin/ps test/zdtm/live/static/env00
-	# /bin/ps:
-	#	/usr/lib/arm-linux-gnueabihf/libcofi_rpi.so (0xb6f39000)
-	#	libprocps.so.0 => /lib/arm-linux-gnueabihf/libprocps.so.0 (0xb6f04000)
-	#	libgcc_s.so.1 => /lib/arm-linux-gnueabihf/libgcc_s.so.1 (0xb6edc000)
-	#	libc.so.6 => /lib/arm-linux-gnueabihf/libc.so.6 (0xb6dad000)
-	#	/lib/ld-linux-armhf.so.3 (0xb6f46000)
-	# test/zdtm/live/static/env00:
-	#	/usr/lib/arm-linux-gnueabihf/libcofi_rpi.so (0xb6efe000)
-	#	libc.so.6 => /lib/arm-linux-gnueabihf/libc.so.6 (0xb6dc5000)
-	#	/lib/ld-linux-armhf.so.3 (0xb6f0b000)
-
-	local libs=$(ldd $test_path $ps_path | awk '
-		!/^[ \t]/ { next }
-		/linux-vdso\.so/ { next }
-		/linux-vdso64\.so/ { next }
-		/linux-gate\.so/ { next }
-		/not a dynamic executable$/ { next }
-		$2 ~ /^=>$/ { print $3; next }
-		{ print $1 }
-	')
-	for i in ${libs}; do
-		local ldir lib=`basename $i`
-
-		[ -f $libdir2/$lib ] && continue # fast path
-
-		if [ -f $i ]; then
-			lname=$i
-		elif [ -f /lib64/$i ]; then
-			lname=/lib64/$i
-		elif [ -f /usr/lib64/$i ]; then
-			lname=/usr/lib64/$i
-		elif [ -f /lib/x86_64-linux-gnu/$i ]; then
-			lname=/lib/x86_64-linux-gnu/$i
-		elif [ -f /lib/arm-linux-gnueabi/$i ]; then
-			lname=/lib/arm-linux-gnueabi/$i
-		else
-			echo "Failed at " $i
-			return 1
-		fi
-
-		# When tests are executed concurrently all of them use the same root,
-		# so libraries must be copied atomically.
-
-		for ldir in "$libdir" "$libdir2"; do
-			tname=$(mktemp $ldir/lib.XXXXXX)
-			cp -pf $lname $tname &&
-			mv -n $tname $ldir/$lib || return 1
-			[ -f $tname ] && unlink $tname
-		done
-	done
-
-	mkdir -p $root/dev
-	mkdir -p $root/dev/pts
-	mknod -m 0666 $root/dev/tty c 5 0
-	mknod -m 0666 $root/dev/null c 1 3
-	if [ -r "/dev/net/tun" ]; then
-		mkdir -p $root/dev/net/
-		mknod -m 0666 $root/dev/net/tun c $(stat -c "0x%t" /dev/net/tun) $(stat -c "0x%T" /dev/net/tun)
-	fi
-	if [ -r "/dev/rtc" ]; then
-		mknod -m 0666 $root/dev/rtc c $(stat -c "0x%t" /dev/rtc) $(stat -c "0x%T" /dev/rtc)
-	fi
-
-	mkdir -p $root/proc
-
-	# make 'tmp' dir under new root
-	mkdir -p $tmpdir
-	chmod 0777 $tmpdir
-}
-
-export MAKEFLAGS=--no-print-directory
-
-start_test()
-{
-	local tdir=$1
-	local tname=$2
-	local test=$(readlink -f $tdir)/$tname
-	export ZDTM_ROOT
-
-	killall -9 $tname > /dev/null 2>&1
-	make -C $tdir $tname.cleanout
-
-	unset ZDTM_UID
-	unset ZDTM_GID
-	unset ZDTM_GROUPS
-
-	if ! echo $TEST_SUID_LIST | grep -q $tname; then
-		export ZDTM_UID=18943
-		export ZDTM_GID=58467
-		export ZDTM_GROUPS="27495 48244"
-		chmod a+w $tdir
-	fi
-
-	if [ -z "$USERNS" ]; then
-		unset ZDTM_USERNS
-	else
-		# we need to be able to create a temporary directory in a test
-		# root for restoring mount namespaces
-		chmod go+wxr .
-		export ZDTM_USERNS=1
-	fi
-
-	if [ -z "$PIDNS" ]; then
-		TPID="$test.pid"
-		unset ZDTM_NEWNS
-	else
-		TPID=$test.init.pid
-		if [ -z "$ZDTM_ROOT" ]; then
-			mkdir -p dump
-			ZDTM_ROOT=`mktemp -d /tmp/criu-root.XXXXXX`
-			ZDTM_ROOT=`readlink -f $ZDTM_ROOT`
-			mount --make-private --bind . $ZDTM_ROOT || return 1
-		fi
-		construct_root $ZDTM_ROOT $test || return 1
-		export ZDTM_NEWNS=1
-		export ZDTM_PIDFILE=$TPID
-		cd $ZDTM_ROOT
-		rm -f $ZDTM_PIDFILE
-	fi
-
-	(
-		if [ -n "$FREEZE_CGROUP" ]; then
-			mkdir -p $FREEZE_CGROUP
-			echo 0 > $FREEZE_CGROUP/tasks || exit 1
-		else
-			export ZDTM_THREAD_BOMB=5
-		fi
-		# Here is no way to set FD_CLOEXEC on 3
-		exec 3>&-
-		make -C $tdir $tname.pid
-	)
-
-	if [ $? -ne 0 ]; then
-		echo ERROR: fail to start $test
-		return 1
-	fi
-
-	if [ -n "$FREEZE_CGROUP" ] && [ -n "$FREEZER_STATE" ]; then
-		echo $FREEZER_STATE > $FREEZE_CGROUP/freezer.state
-	fi
-
-	[ -z "$PIDNS" ] || cd -
-
-	PID=`cat "$TPID"` || return 1
-	if ! kill -0 $PID ; then
-		echo "Test failed to start"
-		return 1
-	fi
-
-	if [ -n "$ZDTM_ROOT" ]; then
-		mount --make-private "$ZDTM_ROOT"
-		umount -l "$ZDTM_ROOT"
-		mount --make-private --bind . $ZDTM_ROOT || return 1
-	fi
-}
-
-stop_test()
-{
-	kill $PID
-}
-
-save_fds()
-{
-	test -z "$PIDNS" && return 0
-	echo -n > $2 # Busybox doesn't have truncate
-	for p in `ls /proc/$1/root/proc/ | grep "^[0-9]*$"`; do
-		ls -l /proc/$1/root/proc/$p/fd |
-			sed 's/\(-> \(pipe\|socket\)\):.*/\1/' |
-			sed -e 's/\/.nfs[0-9a-zA-Z]*/.nfs-silly-rename/' |
-			sed 's/net:\[[0-9].*\]/net/' |
-			awk '{ print $9,$10,$11; }' | sort >> $2
-	done
-}
-
-save_maps()
-{
-	test -z "$PIDNS" && return 0
-	echo -n > $2 # Busybox doesn't have truncate
-	for p in `ls /proc/$1/root/proc/ | grep "^[0-9]*$"`; do
-		cat /proc/$1/root/proc/$p/maps | python maps.py >> $2
-	done
-}
-
-diff_maps()
-{
-	test -z "$PIDNS" && return 0
-	if ! diff -up $1 $2; then
-		echo ERROR: Sets of mappings differ:
-		echo $1
-		echo $2
-		return 1
-	fi
-}
-
-diff_fds()
-{
-	test -z "$PIDNS" && return 0
-	if ! diff -up $1 $2; then
-		echo ERROR: Sets of descriptors differ:
-		echo $1
-		echo $2
-		return 1
-	fi
-}
-
-run_test()
-{
-	local test_name=$1
-	local test=$1
-	local snappdir=
-	local ps_pid=
-
-	[ -n "$EXCLUDE_PATTERN" ] && echo $test | grep "$EXCLUDE_PATTERN" && return 0
-
-	if [ -n "$MAINSTREAM_KERNEL" ] && [ $COMPILE_ONLY -eq 0 ]; then
-		if echo $TEST_CR_KERNEL | grep -q ${test#ns/}; then
-			echo "Skip $test"
-			return 0
-		fi
-	fi
-
-	expr "$test" : 'ns/' > /dev/null && PIDNS=1 || PIDNS=""
-	test=${test#ns/}
-	expr "$test" : 'user/' > /dev/null && USERNS=1 || USERNS=""
-	test=${test#user/}
-	test=${ZP}/${test}
-
-	shift
-	local gen_args=$*
-	local tname=`basename $test`
-	local tdir=`dirname $test`
-	local rst_args=
-	DUMP_PATH=""
-
-	if [ -f "$test".checkskip ] && ! "$test".checkskip; then
-		echo "Skip $test"
-		return 0
-	fi
-
-	if [ $COMPILE_ONLY -eq 1 ]; then
-		echo "Compile $test"
-		make -C $tdir $tname && return 0 || return 1
-	fi
-
-	echo "Execute $test_name"
-
-	start_test $tdir $tname || return 1
-
-	if [ $START_ONLY -eq 1 ]; then
-		echo "Test is started"
-		return 0
-	fi
-
-	local ddump
-
-	if [ -f "${test}.opts" ]; then
-		gen_args="$gen_args $(cat "${test}.opts")"
-	fi
-
-	if [ -n "$PIDNS" ]; then
-		[ -z "$CR_IP_TOOL" ] && CR_IP_TOOL=ip
-		if ! $CR_IP_TOOL a help 2>&1 | grep -q showdump; then
-			cat >&2 <<EOF
-The util "ip" is incompatible. The good one can be cloned from
-git://git.criu.org/iproute2. It should be compiled and a path
-to ip is written in \$CR_IP_TOOL.
-EOF
-			exit 1
-		fi
-		gen_args="--root $ZDTM_ROOT --pidfile $TPID $gen_args"
-	fi
-
-	if [ $tname = "rtc" ]; then
-		gen_args="$gen_args -L `pwd`/$tdir/lib"
-	fi
-
-	if [ -n "$AUTO_DEDUP" ]; then
-		gen_args="$gen_args --auto-dedup"
-		ps_args="--auto-dedup"
-	fi
-
-	if [ -n "$RESTORE_SIBLING" ]; then
-		rst_args="$rst_args --restore-sibling"
-	fi
-
-	if echo $tname | fgrep -q 'irmap'; then
-		gen_args="$gen_args --force-irmap"
-	fi
-
-	# X will be substituted with an iteration number
-	ddump=`pwd`/dump/$test_name/$PID/X
-	for i in `seq $ITERATIONS`; do
-		local cpt_args=
-		local dump_only=
-		local dump_cmd="dump"
-		ddump=`dirname $ddump`/$i
-		DUMP_PATH=$ddump
-		echo Dump $PID
-		mkdir -p $ddump
-
-		[ -n "$DUMP_ONLY" ] && dump_only=1
-
-		if [ $PAGE_SERVER -eq 1 ]; then
-			$CRIU page-server -D $ddump -o page_server.log -v4 --port $PS_PORT $ps_args --daemon --pidfile $ddump/page-server.pid || return 1
-			ps_pid=`cat $ddump/page-server.pid`
-			ps -p "$ps_pid" -o cmd h | grep -q page-server || {
-				echo "Unable to determing PID of page-server"
-				return 1
-			}
-			cpt_args="$cpt_args --page-server --address 127.0.0.1 --port $PS_PORT"
-		fi
-
-		if [ -n "$SNAPSHOT" ]; then
-			cpt_args="$cpt_args --track-mem"
-			if [ "$i" -ne "$ITERATIONS" ]; then
-				cpt_args="$cpt_args -R"
-				dump_only=1
-				[ -n "$PRE_DUMP" ] && dump_cmd="pre-dump"
-			fi
-			[ -n "$snappdir" ] && cpt_args="$cpt_args --prev-images-dir=$snappdir"
-		fi
-		if [ -n "$FREEZE_CGROUP" ]; then
-			cpt_args="$cpt_args --freeze-cgroup $FREEZE_CGROUP --manage-cgroups"
-			rst_args="$rst_args --manage-cgroups"
-		fi
-
-		[ -n "$dump_only" ] && cpt_args="$cpt_args $POSTDUMP"
-
-		expr $tdir : ".*static$" > /dev/null && {
-			save_fds $PID  $ddump/dump.fd
-			save_maps $PID  $ddump/dump.maps
-		}
-		setsid $CRIU_CPT $dump_cmd -D $ddump -o dump.log -v4 -t $PID $gen_args $cpt_args
-		retcode=$?
-
-		cat $ddump/dump.log | grep Error
-
-		#
-		# Here we may have two cases: either checkpoint is failed
-		# with some error code, or checkpoint is complete but return
-		# code is non-zero because of post dump action.
-		if echo $TEST_EXPECTED_FAILURE | grep -q $tname; then
-			echo "Expect dump falure: $retcode"
-			if [ "$retcode" -eq 0 ]; then
-				return 1
-			fi
-			dump_only=1
-			retcode=32
-		fi
-		if [ "$retcode" -ne 0 ] && [[ "$retcode" -ne 32 || -z "$dump_only" ]]; then
-			if [ $BATCH_TEST -eq 0 ]; then
-				echo WARNING: $tname returned $retcode and left running for debug needs
-			else
-				echo WARNING: $tname failed and returned $retcode
-			fi
-			return 1
-		fi
-
-		if [ -n "$SNAPSHOT" ]; then
-			snappdir=../`basename $ddump`
-			[ "$i" -ne "$ITERATIONS" ] && continue
-		fi
-
-		if [ $PAGE_SERVER -eq 1 ]; then
-			while :; do
-				kill -0 $ps_pid > /dev/null 2>&1 || break
-				echo Waiting the process $ps_pid
-				sleep 0.1
-			done
-		fi
-
-		if [ -n "$dump_only" ]; then
-			expr $tdir : ".*static$" > /dev/null && {
-				save_fds $PID  $ddump/dump.fd.after
-				diff_fds $ddump/dump.fd $ddump/dump.fd.after || return 1
-
-				save_maps $PID  $ddump/dump.maps.after
-				diff_maps $ddump/dump.maps $ddump/dump.maps.after || return 1
-			}
-
-			if [ -n "$FREEZE_CGROUP" ] && [ -n "$FREEZER_STATE" ]; then
-				while :; do
-					echo freezer.state=`cat $FREEZE_CGROUP/freezer.state`
-					cat $FREEZE_CGROUP/freezer.state | grep -q $FREEZER_STATE && break;
-					sleep 0.1
-				done
-			fi
-			echo THAWED > $FREEZE_CGROUP/freezer.state
-
-			rm -f ./$tdir/link_remap.*
-		else
-			# Wait while tasks are dying, otherwise PIDs would be busy.
-			for i in $ddump/core-*.img; do
-				local pid
-
-				[ -n "$PIDNS" ] && break
-
-				pid=`expr "$i" : '.*/core-\([0-9]*\).img'`
-				while :; do
-					kill -0 $pid > /dev/null 2>&1 || break
-					echo Waiting the process $pid
-					sleep 0.1
-				done
-			done
-
-			if [ -x "${test}.hook" ]; then
-				echo "Executing pre-restore hook"
-				"${test}.hook" --pre-restore || return 2
-			fi
-
-			# Restore fails if --pidfile exists, so remove it.
-			rm -f $TPID || true
-
-			echo Restore
-			setsid $CRIU restore -D $ddump -o restore.log -v4 -d $gen_args $rst_args || return 2
-			cat $ddump/restore.log* | grep Error
-
-			[ -n "$PIDNS" ] && PID=`cat $TPID`
-
-			expr $tdir : ".*static$" > /dev/null && {
-				save_fds $PID  $ddump/restore.fd
-				save_maps $PID $ddump/restore.maps
-				diff_fds $ddump/dump.fd $ddump/restore.fd || return 2
-				diff_maps $ddump/dump.maps $ddump/restore.maps || return 2
-			}
-			[ "$CLEANUP" -ne 0 ] && rm -f --one-file-system $ddump/pages-*.img
-		fi
-
-	done
-
-	echo Check results $PID
-	if ! stop_test $tdir $tname; then
-		echo "Unable to stop $tname ($PID)"
-		return 2
-	fi
-
-	sltime=1
-	for i in `seq 200`; do
-		kill -0 $PID > /dev/null 2>&1 || break
-		echo Waiting...
-		sleep 0.$sltime
-		[ $sltime -lt 9 ] && sltime=$((sltime+1))
-	done
-
-	if [ -x "${test}.hook" ]; then
-		echo "Executing cleanup hook"
-		"${test}.hook" --clean || return 2
-	fi
-
-	if [ -n "$AUTO_DEDUP" ]; then
-		for img in $ddump/pages-*.img; do
-			img_name="${img##*/}"
-			size=$(du -sh -BK "$img" | grep -Eo '[0-9]+' | head -1)
-			echo "Size of $img_name is $size"
-			if [ "$size" -ne 0 ]; then
-				echo "Check: $test, Auto-dedup: image size is more than 0"
-				return 2
-			fi
-		done
-	fi
-
-	cat $test.out
-	[ $i -gt 50 ] && return 2 # waiting too long
-	cat $test.out | grep -q PASS || return 2
-	[ "$CLEANUP" -ne 0 ] && rm -rf --one-file-system `dirname $ddump`
-	echo "Test: $test, Result: PASS"
-	return 0
-}
-
-case_error()
-{
-	local test=${ZP}/${1#ns/}
-	local test_log=`pwd`/$test.out
-
-	echo "Test: $test, Result: FAIL"
-	ZDTM_FAILED=1
-
-(	exec >&2
-
-	zdtm_sep ERROR
-
-	echo "Test: $test, Namespace: $PIDNS"
-
-	if [ -n "$DUMP_PATH" ]; then
-		if [ -e "$DUMP_PATH/dump.log" ]; then
-			echo "Dump log   : $DUMP_PATH/dump.log"
-			zdtm_sep "grep Error" "-"
-			cat $DUMP_PATH/dump.log* | grep Error
-			if [ $VERBOSE -gt 0 ]; then
-				zdtm_sep "" "-"
-				tail -n 40 $DUMP_PATH/dump.log*
-			fi
-			zdtm_sep "END" "-"
-		fi
-		if [ -e "$DUMP_PATH/restore.log" ]; then
-			echo "Restore log: $DUMP_PATH/restore.log"
-			zdtm_sep "grep Error" "-"
-			cat $DUMP_PATH/restore.log* | grep Error
-			if [ $VERBOSE -gt 0 ]; then
-				zdtm_sep "" "-"
-				tail -n 40 $DUMP_PATH/restore.log*
-			fi
-			zdtm_sep "END" "-"
-		fi
-	fi
-	if [ -e "$test_log" ]; then
-		echo "Output file: $test_log"
-		zdtm_sep "" "-"
-		cat $test_log*
-		zdtm_sep "END" "-"
-	fi
-
-	[ -n "$HEAD" ] &&
-		echo "The initial HEAD was $HEAD"
-
-	zdtm_sep "ERROR OVER"
-)
-	if [ $BATCH_TEST -eq 0 ]; then
-		exit 1
-	else
-		# kill failed test
-		local tname=`basename $test`
-		killall -9 $tname > /dev/null 2>&1
-	fi
-}
-
-checkout()
-{
-	local commit=`git describe $1` &&
-	TMP_TREE=`dirname $CRIU`/criu.$commit &&
-	mkdir -p $TMP_TREE &&
-	git --git-dir `dirname $CRIU`/.git archive $commit . | tar -x -C $TMP_TREE &&
-	make -C $TMP_TREE -j 32
-}
-
-usage() {
-	cat << EOF
-This script is used for executing unit tests.
-Usage:
-zdtm.sh [OPTIONS]
-zdtm.sh [OPTIONS] [TEST PATTERN]
-Options:
-	-l : Show list of tests.
-	-d : Dump a test process and check that this process can continue working.
-	-i : Number of ITERATIONS of dump/restore
-	-p : Test page server
-	-C : Delete dump files if a test completed successfully
-	-b <commit> : Check backward compatibility
-	-x <PATTERN>: Exclude pattern
-	-t : mount tmpfs for dump files
-	-a <FILE>.tar.gz : save archive with dump files and logs
-	-g : Generate executables only
-	-S : Only start the test
-	-n : Batch test
-	-r : Run test with specified name directly without match or check
-	-f <name>: Run tests starting from @name
-	-v : Verbose mode
-	-P : Make pre-dump instead of dump on all iterations except the last one
-	-s : Make iterative snapshots. Only the last one will be checked.
-	--auto-dedup : Make auto-dedup on restore. Check sizes of pages imges, it must be zero.
-	--ct : re-execute $0 in a container
-EOF
-}
-
-cd `dirname $0` || exit 1
-
-while :; do
-	case $1 in
-	  -d)
-		DUMP_ONLY=1
-		shift
-		;;
-	  -i)
-		shift
-		ITERATIONS=$1
-		shift
-		;;
-	  -b)
-		shift
-		checkout $1 || exit 1
-		CRIU_CPT=$TMP_TREE/criu
-		shift
-		;;
-	  -c)
-		shift
-		checkout $1 || exit 1
-		shift
-		$TMP_TREE/test/zdtm.sh "$@"
-		exit
-		;;
-	  -p)
-		shift
-		PAGE_SERVER=1
-		;;
-	  -C)
-		shift
-		CLEANUP=1
-		;;
-	  -x)
-		shift
-		if [ -z "$EXCLUDE_PATTERN" ]; then
-			EXCLUDE_PATTERN=$1
-		else
-			EXCLUDE_PATTERN="${EXCLUDE_PATTERN}\|$1"
-		fi
-		shift
-		;;
-	  -t)
-		shift
-		TMPFS_DUMP=dump
-		[ -d dump ] || mkdir -p $TMPFS_DUMP
-		mount -t tmpfs none $TMPFS_DUMP || exit 1
-		;;
-	  -a)
-		shift
-		DUMP_ARCHIVE=$1
-		shift
-		;;
-	  -s)
-		if [ -n "$PRE_DUMP" ]; then
-			echo "-P and -s can not be used together"
-			exit 1
-		fi
-		SNAPSHOT=1
-		shift
-		;;
-	  -P)
-		if [ -n "$SNAPSHOT" ]; then
-			echo "-P and -s can not be used together"
-			exit 1
-		fi
-		PRE_DUMP=1
-		SNAPSHOT=1
-		shift
-		;;
-	  --auto-dedup)
-		AUTO_DEDUP=1
-		shift
-		;;
-	  --freeze-cgroup)
-		shift
-		FREEZE_CGROUP=$1
-		shift
-		;;
-	  --frozen)
-		FREEZER_STATE=FROZEN
-		shift
-		;;
-	  -g)
-		COMPILE_ONLY=1
-		shift
-		;;
-	  -S)
-	  	START_ONLY=1
-		shift
-		;;
-	  -f)
-	  	shift
-	  	START_FROM="^${1}$"
-		shift
-		;;
-	  -n)
-		BATCH_TEST=1
-		shift
-		;;
-	  -r)
-		SPECIFIED_NAME_USED=1
-		shift
-		;;
-	  -l)
-		generate_test_list
-		echo "$TEST_LIST" >&3
-		exit 0
-		;;
-	  -v)
-		VERBOSE=1
-		shift
-		;;
-	  -h)
-		usage
-		exit 0
-		;;
-	  --ct)
-		[ -z "$ZDTM_SH_IN_CT" ] && {
-			export ZDTM_SH_IN_CT=1
-			shift
-			# pidns is used to avoid conflicts
-			# mntns is used to mount /proc
-			# net is used to avoid conflicts of parasite sockets
-			./zdtm_ct ./zdtm.sh "$@"
-			exit
-		}
-		shift
-		;;
-	  --restore-sibling)
-		RESTORE_SIBLING=1
-		shift
-		;;
-	  -*)
-		echo "Unrecognized option $1, aborting!" 1>&2
-		usage
-		exit 1
-		;;
-	  *)
-		break
-		;;
-	esac
-done
-
-if [ $# -gt 1 ]; then
-	echo "Too many arguments: $*" 1>&2
-	exit 1
-fi
-
-if [ $COMPILE_ONLY -eq 0 ]; then
-	check_criu || exit 1
-fi
-
-if [ $SPECIFIED_NAME_USED -eq 1 ]; then
-	if [ $# -eq 0 ]; then
-		echo "test name should be provided"
-		exit 1
-	fi
-	$CRIU check -v0 --feature "mnt_id" || export ZDTM_NOSUBNS=1
-	# don't run file_locks* tests simultaneously
-	(
-		expr $1 : ".*file_locks" > /dev/null && flock 10
-		run_test $1 10<&-
-	) 10<zdtm.sh || case_error $1
-else
-	if [ $# -eq 0 ]; then
-		pattern='.*'
-	else
-		pattern=$1
-	fi
-
-	generate_test_list
-	for t in $(echo "$TEST_LIST" | sed -n -e "/${START_FROM////\/}/,\$p" | grep -x "$pattern"); do
-		run_test $t || case_error $t
-	done
-
-	if [ $COMPILE_ONLY -eq 0 ]; then
-		if [ -n "$ZDTM_FAILED" ]; then
-			echo ZDTM tests FAIL.
-		else
-			echo ZDTM tests PASS.
-		fi
-	fi
-fi
-
-[ -n "$TMP_TREE" ] && rm -rf --one-file-system $TMP_TREE
-[ -n "$ZDTM_FAILED" ] && exit 1 || exit 0
-- 
2.5.0



More information about the CRIU mailing list