mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-12 15:52:55 +00:00
e430410480
The vcpupin command allowed specifying a negative number for the --vcpu argument. This would the overflow when the underlying virDomainPinVcpu API was called. $ virsh vcpupin r7 -1 0 error: numerical overflow: input too large: 4294967295 Switch the vCPU variable to a unsigned int and parse it using the corresponding function. Also improve the vcpupin test to cover all the defects. Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1101059 Signed-off-by: Jincheng Miao <jmiao@redhat.com> Signed-off-by: Peter Krempa <pkrempa@redhat.com>
79 lines
2.3 KiB
Bash
Executable File
79 lines
2.3 KiB
Bash
Executable File
#!/bin/sh
|
|
# ensure that an invalid CPU spec elicits a diagnostic
|
|
|
|
# Copyright (C) 2008 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, see
|
|
# <http://www.gnu.org/licenses/>.
|
|
|
|
test -z "$srcdir" && srcdir=$(pwd)
|
|
test -z "$abs_top_srcdir" && abs_top_srcdir=$(pwd)/..
|
|
test -z "$abs_top_builddir" && abs_top_builddir=$(pwd)/..
|
|
|
|
if test "$VERBOSE" = yes; then
|
|
set -x
|
|
$abs_top_builddir/tools/virsh --version
|
|
fi
|
|
|
|
. "$srcdir/test-lib.sh"
|
|
|
|
fail=0
|
|
|
|
# Invalid syntax.
|
|
$abs_top_builddir/tools/virsh --connect test:///default vcpupin test a 0,1 > out 2>&1
|
|
test $? = 1 || fail=1
|
|
cat <<\EOF > exp || fail=1
|
|
error: vcpupin: Invalid vCPU number.
|
|
|
|
EOF
|
|
compare exp out || fail=1
|
|
|
|
# An out-of-range vCPU number deserves a diagnostic, too.
|
|
$abs_top_builddir/tools/virsh --connect test:///default vcpupin test 100 0,1 > out 2>&1
|
|
test $? = 1 || fail=1
|
|
cat <<\EOF > exp || fail=1
|
|
error: vcpupin: vCPU index out of range.
|
|
|
|
EOF
|
|
compare exp out || fail=1
|
|
|
|
# Negative number
|
|
$abs_top_builddir/tools/virsh --connect test:///default vcpupin test -100 0,1 > out 2>&1
|
|
test $? = 1 || fail=1
|
|
cat <<\EOF > exp || fail=1
|
|
error: vcpupin: Invalid vCPU number.
|
|
|
|
EOF
|
|
compare exp out || fail=1
|
|
|
|
# missing argument
|
|
$abs_top_builddir/tools/virsh --connect test:///default vcpupin test --cpulist 0,1 > out 2>&1
|
|
test $? = 1 || fail=1
|
|
cat <<\EOF > exp || fail=1
|
|
error: vcpupin: Missing vCPU number in pin mode.
|
|
|
|
EOF
|
|
compare exp out || fail=1
|
|
|
|
# without arguments. This should succeed but the backend function in the
|
|
# test driver isn't implemented
|
|
$abs_top_builddir/tools/virsh --connect test:///default vcpupin test > out 2>&1
|
|
test $? = 1 || fail=1
|
|
cat <<\EOF > exp || fail=1
|
|
error: this function is not supported by the connection driver: virDomainGetVcpuPinInfo
|
|
|
|
EOF
|
|
compare exp out || fail=1
|
|
(exit $fail); exit $fail
|