2010-04-26 13:44:05 +04:00
|
|
|
#!/bin/bash
|
2009-06-22 20:29:05 +04:00
|
|
|
#
|
|
|
|
# Copyright (C) 2009 Red Hat, Inc.
|
|
|
|
# Copyright (c) 2000-2005 Silicon Graphics, Inc. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it would 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
|
2009-07-16 21:26:54 +04:00
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2009-06-22 20:29:05 +04:00
|
|
|
#
|
|
|
|
#
|
|
|
|
# common procedures for QA scripts
|
|
|
|
#
|
|
|
|
|
|
|
|
_setenvironment()
|
|
|
|
{
|
|
|
|
MSGVERB="text:action"
|
|
|
|
export MSGVERB
|
|
|
|
}
|
|
|
|
|
2014-05-25 01:24:55 +04:00
|
|
|
rm -f "$OUTPUT_DIR/$iam.out"
|
2009-06-22 20:29:05 +04:00
|
|
|
_setenvironment
|
|
|
|
|
|
|
|
check=${check-true}
|
|
|
|
|
|
|
|
diff="diff -u"
|
|
|
|
verbose=false
|
2015-05-18 04:39:12 +03:00
|
|
|
debug=false
|
2009-06-22 20:29:05 +04:00
|
|
|
group=false
|
|
|
|
xgroup=false
|
2012-03-27 15:45:14 +04:00
|
|
|
imgopts=false
|
2009-06-22 20:29:05 +04:00
|
|
|
showme=false
|
|
|
|
sortme=false
|
|
|
|
expunge=true
|
|
|
|
have_test_arg=false
|
|
|
|
randomize=false
|
2013-12-04 05:06:58 +04:00
|
|
|
cachemode=false
|
2009-06-22 20:29:05 +04:00
|
|
|
rm -f $tmp.list $tmp.tmp $tmp.sed
|
|
|
|
|
|
|
|
export IMGFMT=raw
|
2013-09-27 16:48:15 +04:00
|
|
|
export IMGFMT_GENERIC=true
|
2011-01-17 20:01:17 +03:00
|
|
|
export IMGPROTO=file
|
2012-03-27 15:45:14 +04:00
|
|
|
export IMGOPTS=""
|
2013-12-04 05:07:01 +04:00
|
|
|
export CACHEMODE="writeback"
|
2009-06-22 20:29:05 +04:00
|
|
|
export QEMU_IO_OPTIONS=""
|
2013-12-04 05:06:58 +04:00
|
|
|
export CACHEMODE_IS_DEFAULT=true
|
2016-10-17 21:39:17 +03:00
|
|
|
export QEMU_OPTIONS="-nodefaults -machine accel=qtest"
|
2015-10-30 22:25:18 +03:00
|
|
|
export VALGRIND_QEMU=
|
2016-05-10 19:11:28 +03:00
|
|
|
export IMGKEYSECRET=
|
2016-05-10 19:11:27 +03:00
|
|
|
export IMGOPTSSYNTAX=false
|
2009-06-22 20:29:05 +04:00
|
|
|
|
|
|
|
for r
|
|
|
|
do
|
|
|
|
|
|
|
|
if $group
|
|
|
|
then
|
2013-09-04 15:16:04 +04:00
|
|
|
# arg after -g
|
2014-05-25 01:24:55 +04:00
|
|
|
group_list=`sed -n <"$source_iotests/group" -e 's/$/ /' -e "/^[0-9][0-9][0-9].* $r /"'{
|
2009-06-22 20:29:05 +04:00
|
|
|
s/ .*//p
|
|
|
|
}'`
|
2013-09-04 15:16:04 +04:00
|
|
|
if [ -z "$group_list" ]
|
|
|
|
then
|
|
|
|
echo "Group \"$r\" is empty or not defined?"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
[ ! -s $tmp.list ] && touch $tmp.list
|
|
|
|
for t in $group_list
|
|
|
|
do
|
|
|
|
if grep -s "^$t\$" $tmp.list >/dev/null
|
|
|
|
then
|
|
|
|
:
|
|
|
|
else
|
|
|
|
echo "$t" >>$tmp.list
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
group=false
|
|
|
|
continue
|
2009-06-22 20:29:05 +04:00
|
|
|
|
|
|
|
elif $xgroup
|
|
|
|
then
|
2013-09-04 15:16:04 +04:00
|
|
|
# arg after -x
|
|
|
|
[ ! -s $tmp.list ] && ls [0-9][0-9][0-9] [0-9][0-9][0-9][0-9] >$tmp.list 2>/dev/null
|
2014-05-25 01:24:55 +04:00
|
|
|
group_list=`sed -n <"$source_iotests/group" -e 's/$/ /' -e "/^[0-9][0-9][0-9].* $r /"'{
|
2009-06-22 20:29:05 +04:00
|
|
|
s/ .*//p
|
|
|
|
}'`
|
2013-09-04 15:16:04 +04:00
|
|
|
if [ -z "$group_list" ]
|
|
|
|
then
|
|
|
|
echo "Group \"$r\" is empty or not defined?"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
numsed=0
|
|
|
|
rm -f $tmp.sed
|
|
|
|
for t in $group_list
|
|
|
|
do
|
|
|
|
if [ $numsed -gt 100 ]
|
|
|
|
then
|
|
|
|
sed -f $tmp.sed <$tmp.list >$tmp.tmp
|
|
|
|
mv $tmp.tmp $tmp.list
|
|
|
|
numsed=0
|
|
|
|
rm -f $tmp.sed
|
|
|
|
fi
|
|
|
|
echo "/^$t\$/d" >>$tmp.sed
|
|
|
|
numsed=`expr $numsed + 1`
|
|
|
|
done
|
|
|
|
sed -f $tmp.sed <$tmp.list >$tmp.tmp
|
|
|
|
mv $tmp.tmp $tmp.list
|
|
|
|
xgroup=false
|
|
|
|
continue
|
2012-03-27 15:45:14 +04:00
|
|
|
|
|
|
|
elif $imgopts
|
|
|
|
then
|
|
|
|
IMGOPTS="$r"
|
|
|
|
imgopts=false
|
|
|
|
continue
|
2013-12-04 05:06:58 +04:00
|
|
|
elif $cachemode
|
|
|
|
then
|
|
|
|
CACHEMODE="$r"
|
|
|
|
CACHEMODE_IS_DEFAULT=false
|
|
|
|
cachemode=false
|
|
|
|
continue
|
2009-06-22 20:29:05 +04:00
|
|
|
fi
|
|
|
|
|
|
|
|
xpand=true
|
|
|
|
case "$r"
|
|
|
|
in
|
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-\? | -h | --help) # usage
|
|
|
|
echo "Usage: $0 [options] [testlist]"'
|
2009-06-22 20:29:05 +04:00
|
|
|
|
|
|
|
common options
|
2013-12-04 05:07:02 +04:00
|
|
|
-v verbose
|
2015-05-18 04:39:12 +03:00
|
|
|
-d debug
|
2009-06-22 20:29:05 +04:00
|
|
|
|
|
|
|
check options
|
|
|
|
-raw test raw (default)
|
2014-03-26 16:05:30 +04:00
|
|
|
-bochs test bochs
|
2014-03-26 16:05:23 +04:00
|
|
|
-cloop test cloop
|
2014-03-26 16:06:08 +04:00
|
|
|
-parallels test parallels
|
2009-06-22 20:29:05 +04:00
|
|
|
-qcow test qcow
|
|
|
|
-qcow2 test qcow2
|
2010-10-31 23:10:20 +03:00
|
|
|
-qed test qed
|
2009-07-06 13:48:30 +04:00
|
|
|
-vdi test vdi
|
2009-06-22 20:29:05 +04:00
|
|
|
-vpc test vpc
|
2013-09-27 16:48:15 +04:00
|
|
|
-vhdx test vhdx
|
2009-06-22 20:29:05 +04:00
|
|
|
-vmdk test vmdk
|
2014-02-03 13:26:17 +04:00
|
|
|
-file test file (default)
|
2011-01-17 20:01:17 +03:00
|
|
|
-rbd test rbd
|
|
|
|
-sheepdog test sheepdog
|
2012-11-02 17:01:23 +04:00
|
|
|
-nbd test nbd
|
2013-04-09 18:30:55 +04:00
|
|
|
-ssh test ssh
|
2014-02-03 13:26:17 +04:00
|
|
|
-nfs test nfs
|
2014-07-23 18:07:33 +04:00
|
|
|
-archipelago test archipelago
|
2016-03-21 17:11:52 +03:00
|
|
|
-luks test luks
|
2013-12-04 05:07:02 +04:00
|
|
|
-xdiff graphical mode diff
|
|
|
|
-nocache use O_DIRECT on backing file
|
|
|
|
-misalign misalign memory allocations
|
|
|
|
-n show me, do not run tests
|
2012-03-27 15:45:14 +04:00
|
|
|
-o options -o options to pass to qemu-img create/convert
|
2013-12-04 05:07:02 +04:00
|
|
|
-T output timestamps
|
|
|
|
-r randomize test order
|
2013-12-04 05:06:58 +04:00
|
|
|
-c mode cache mode
|
2013-09-04 15:16:04 +04:00
|
|
|
|
2009-06-22 20:29:05 +04:00
|
|
|
testlist options
|
2013-09-04 15:16:04 +04:00
|
|
|
-g group[,group...] include tests from these groups
|
|
|
|
-x group[,group...] exclude tests from these groups
|
|
|
|
NNN include test NNN
|
2013-12-04 05:07:02 +04:00
|
|
|
NNN-NNN include test range (eg. 012-021)
|
2009-06-22 20:29:05 +04:00
|
|
|
'
|
2013-09-04 15:16:04 +04:00
|
|
|
exit 0
|
|
|
|
;;
|
|
|
|
|
|
|
|
-raw)
|
|
|
|
IMGFMT=raw
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2014-03-26 16:05:30 +04:00
|
|
|
-bochs)
|
|
|
|
IMGFMT=bochs
|
|
|
|
IMGFMT_GENERIC=false
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2014-03-26 16:05:23 +04:00
|
|
|
-cloop)
|
|
|
|
IMGFMT=cloop
|
|
|
|
IMGFMT_GENERIC=false
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2014-03-26 16:06:08 +04:00
|
|
|
-parallels)
|
|
|
|
IMGFMT=parallels
|
|
|
|
IMGFMT_GENERIC=false
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-qcow)
|
|
|
|
IMGFMT=qcow
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
|
|
|
-qcow2)
|
|
|
|
IMGFMT=qcow2
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2016-05-10 19:11:29 +03:00
|
|
|
-luks)
|
|
|
|
IMGOPTSSYNTAX=true
|
|
|
|
IMGFMT=luks
|
|
|
|
IMGKEYSECRET=123456
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-qed)
|
|
|
|
IMGFMT=qed
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
|
|
|
-vdi)
|
|
|
|
IMGFMT=vdi
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
|
|
|
-vmdk)
|
|
|
|
IMGFMT=vmdk
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
|
|
|
-vpc)
|
|
|
|
IMGFMT=vpc
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2013-09-27 16:48:15 +04:00
|
|
|
-vhdx)
|
|
|
|
IMGFMT=vhdx
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2014-02-03 13:26:17 +04:00
|
|
|
-file)
|
|
|
|
IMGPROTO=file
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-rbd)
|
|
|
|
IMGPROTO=rbd
|
|
|
|
xpand=false
|
|
|
|
;;
|
2014-02-03 13:26:17 +04:00
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-sheepdog)
|
|
|
|
IMGPROTO=sheepdog
|
|
|
|
xpand=false
|
|
|
|
;;
|
2014-02-03 13:26:17 +04:00
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-nbd)
|
|
|
|
IMGPROTO=nbd
|
|
|
|
xpand=false
|
|
|
|
;;
|
2014-02-03 13:26:17 +04:00
|
|
|
|
2013-04-09 18:30:55 +04:00
|
|
|
-ssh)
|
|
|
|
IMGPROTO=ssh
|
|
|
|
xpand=false
|
|
|
|
;;
|
2014-02-03 13:26:17 +04:00
|
|
|
|
|
|
|
-nfs)
|
|
|
|
IMGPROTO=nfs
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2014-07-23 18:07:33 +04:00
|
|
|
-archipelago)
|
|
|
|
IMGPROTO=archipelago
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-nocache)
|
2013-12-04 05:06:58 +04:00
|
|
|
CACHEMODE="none"
|
|
|
|
CACHEMODE_IS_DEFAULT=false
|
2013-09-04 15:16:04 +04:00
|
|
|
xpand=false
|
|
|
|
;;
|
2009-06-22 20:29:05 +04:00
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-misalign)
|
|
|
|
QEMU_IO_OPTIONS="$QEMU_IO_OPTIONS --misalign"
|
|
|
|
xpand=false
|
|
|
|
;;
|
2009-06-22 20:29:05 +04:00
|
|
|
|
2014-02-03 13:26:17 +04:00
|
|
|
-valgrind)
|
2015-10-30 22:25:18 +03:00
|
|
|
VALGRIND_QEMU='y'
|
2013-09-04 15:16:04 +04:00
|
|
|
xpand=false
|
2014-02-03 13:26:17 +04:00
|
|
|
;;
|
2012-06-28 18:55:54 +04:00
|
|
|
|
2013-09-04 15:16:04 +04:00
|
|
|
-g) # -g group ... pick from group file
|
|
|
|
group=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
|
|
|
-xdiff) # graphical diff mode
|
|
|
|
xpand=false
|
|
|
|
|
|
|
|
if [ ! -z "$DISPLAY" ]
|
|
|
|
then
|
2014-11-19 10:07:12 +03:00
|
|
|
command -v xdiff >/dev/null 2>&1 && diff=xdiff
|
|
|
|
command -v gdiff >/dev/null 2>&1 && diff=gdiff
|
|
|
|
command -v tkdiff >/dev/null 2>&1 && diff=tkdiff
|
|
|
|
command -v xxdiff >/dev/null 2>&1 && diff=xxdiff
|
2013-09-04 15:16:04 +04:00
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
|
|
|
-n) # show me, don't do it
|
|
|
|
showme=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
2012-03-27 15:45:14 +04:00
|
|
|
-o)
|
|
|
|
imgopts=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
2013-12-04 05:06:58 +04:00
|
|
|
-c)
|
|
|
|
cachemode=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
2013-09-04 15:16:04 +04:00
|
|
|
-r) # randomize test order
|
|
|
|
randomize=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
|
|
|
-T) # turn on timestamp output
|
|
|
|
timestamp=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
|
|
|
|
-v)
|
|
|
|
verbose=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
2015-05-18 04:39:12 +03:00
|
|
|
-d)
|
|
|
|
debug=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
2013-09-04 15:16:04 +04:00
|
|
|
-x) # -x group ... exclude from group file
|
|
|
|
xgroup=true
|
|
|
|
xpand=false
|
|
|
|
;;
|
|
|
|
'[0-9][0-9][0-9] [0-9][0-9][0-9][0-9]')
|
|
|
|
echo "No tests?"
|
|
|
|
status=1
|
|
|
|
exit $status
|
|
|
|
;;
|
|
|
|
|
|
|
|
[0-9]*-[0-9]*)
|
|
|
|
eval `echo $r | sed -e 's/^/start=/' -e 's/-/ end=/'`
|
|
|
|
;;
|
|
|
|
|
|
|
|
[0-9]*-)
|
|
|
|
eval `echo $r | sed -e 's/^/start=/' -e 's/-//'`
|
|
|
|
end=`echo [0-9][0-9][0-9] [0-9][0-9][0-9][0-9] | sed -e 's/\[0-9]//g' -e 's/ *$//' -e 's/.* //'`
|
|
|
|
if [ -z "$end" ]
|
|
|
|
then
|
|
|
|
echo "No tests in range \"$r\"?"
|
|
|
|
status=1
|
|
|
|
exit $status
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
|
|
|
*)
|
|
|
|
start=$r
|
|
|
|
end=$r
|
|
|
|
;;
|
2009-06-22 20:29:05 +04:00
|
|
|
|
|
|
|
esac
|
|
|
|
|
|
|
|
# get rid of leading 0s as can be interpreted as octal
|
|
|
|
start=`echo $start | sed 's/^0*//'`
|
|
|
|
end=`echo $end | sed 's/^0*//'`
|
|
|
|
|
|
|
|
if $xpand
|
|
|
|
then
|
2013-09-04 15:16:04 +04:00
|
|
|
have_test_arg=true
|
|
|
|
$AWK_PROG </dev/null '
|
|
|
|
BEGIN { for (t='$start'; t<='$end'; t++) printf "%03d\n",t }' \
|
|
|
|
| while read id
|
|
|
|
do
|
2014-05-25 01:24:55 +04:00
|
|
|
if grep -s "^$id " "$source_iotests/group" >/dev/null
|
2013-09-04 15:16:04 +04:00
|
|
|
then
|
|
|
|
# in group file ... OK
|
|
|
|
echo $id >>$tmp.list
|
|
|
|
else
|
|
|
|
if [ -f expunged ] && $expunge && egrep "^$id([ ]|\$)" expunged >/dev/null
|
|
|
|
then
|
|
|
|
# expunged ... will be reported, but not run, later
|
|
|
|
echo $id >>$tmp.list
|
|
|
|
else
|
|
|
|
# oops
|
2014-09-24 07:05:57 +04:00
|
|
|
if [ "$start" == "$end" -a "$id" == "$end" ]
|
|
|
|
then
|
|
|
|
echo "$id - unknown test"
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
echo "$id - unknown test, ignored"
|
|
|
|
fi
|
2013-09-04 15:16:04 +04:00
|
|
|
fi
|
|
|
|
fi
|
2014-09-24 07:05:57 +04:00
|
|
|
done || exit 1
|
2009-06-22 20:29:05 +04:00
|
|
|
fi
|
|
|
|
|
|
|
|
done
|
|
|
|
|
2013-12-04 05:06:58 +04:00
|
|
|
# Set qemu-io cache mode with $CACHEMODE we have
|
2016-05-10 19:11:27 +03:00
|
|
|
if [ "$IMGOPTSSYNTAX" = "true" ]; then
|
|
|
|
QEMU_IO_OPTIONS="$QEMU_IO_OPTIONS --cache $CACHEMODE"
|
|
|
|
else
|
|
|
|
QEMU_IO_OPTIONS="$QEMU_IO_OPTIONS -f $IMGFMT --cache $CACHEMODE"
|
|
|
|
fi
|
2013-12-04 05:06:58 +04:00
|
|
|
|
2012-03-27 15:45:14 +04:00
|
|
|
# Set default options for qemu-img create -o if they were not specified
|
|
|
|
_set_default_imgopts
|
|
|
|
|
2009-06-22 20:29:05 +04:00
|
|
|
if [ -s $tmp.list ]
|
|
|
|
then
|
|
|
|
# found some valid test numbers ... this is good
|
|
|
|
:
|
|
|
|
else
|
|
|
|
if $have_test_arg
|
|
|
|
then
|
2013-09-04 15:16:04 +04:00
|
|
|
# had test numbers, but none in group file ... do nothing
|
|
|
|
touch $tmp.list
|
2009-06-22 20:29:05 +04:00
|
|
|
else
|
2013-09-04 15:16:04 +04:00
|
|
|
# no test numbers, do everything from group file
|
2014-05-25 01:24:55 +04:00
|
|
|
sed -n -e '/^[0-9][0-9][0-9]*/s/[ ].*//p' <"$source_iotests/group" >$tmp.list
|
2009-06-22 20:29:05 +04:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# should be sort -n, but this did not work for Linux when this
|
|
|
|
# was ported from IRIX
|
|
|
|
#
|
|
|
|
list=`sort $tmp.list`
|
|
|
|
rm -f $tmp.list $tmp.tmp $tmp.sed
|
|
|
|
|
|
|
|
if $randomize
|
|
|
|
then
|
|
|
|
list=`echo $list | awk -f randomize.awk`
|
|
|
|
fi
|
|
|
|
|
|
|
|
[ "$QEMU" = "" ] && _fatal "qemu not found"
|
|
|
|
[ "$QEMU_IMG" = "" ] && _fatal "qemu-img not found"
|
2012-11-02 17:01:23 +04:00
|
|
|
[ "$QEMU_IO" = "" ] && _fatal "qemu-io not found"
|
|
|
|
|
|
|
|
if [ "$IMGPROTO" = "nbd" ] ; then
|
|
|
|
[ "$QEMU_NBD" = "" ] && _fatal "qemu-nbd not found"
|
|
|
|
fi
|