mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-23 02:04:16 +03:00
better diagnostic when failing to undefine a running domain via ID
* src/virsh.c (cmdUndefine): Tell user to shutdown and then use name or UUID. * tests/undefine: New test. Exercise virsh's undefine command. * tests/Makefile.am (test_scripts): Add undefine.
This commit is contained in:
parent
fa6177aafe
commit
2eb8ab2057
@ -1,3 +1,11 @@
|
|||||||
|
Tue Jul 22 18:11:13 CEST 2008 Jim Meyering <meyering@redhat.com>
|
||||||
|
|
||||||
|
better diagnostic when failing to undefine a running domain via ID
|
||||||
|
* src/virsh.c (cmdUndefine): Tell user to shutdown and then use name
|
||||||
|
or UUID.
|
||||||
|
* tests/undefine: New test. Exercise virsh's undefine command.
|
||||||
|
* tests/Makefile.am (test_scripts): Add undefine.
|
||||||
|
|
||||||
Mon Jul 21 15:31:52 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
Mon Jul 21 15:31:52 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
* src/openvz_conf.c src/openvz_driver.c: patch from Evgeniy Sokolov
|
* src/openvz_conf.c src/openvz_driver.c: patch from Evgeniy Sokolov
|
||||||
|
14
src/virsh.c
14
src/virsh.c
@ -974,10 +974,24 @@ cmdUndefine(vshControl * ctl, vshCmd * cmd)
|
|||||||
virDomainPtr dom;
|
virDomainPtr dom;
|
||||||
int ret = TRUE;
|
int ret = TRUE;
|
||||||
char *name;
|
char *name;
|
||||||
|
int found;
|
||||||
|
int id;
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
|
name = vshCommandOptString(cmd, "domain", &found);
|
||||||
|
if (!found)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (name && virStrToLong_i(name, NULL, 10, &id) == 0
|
||||||
|
&& id >= 0 && (dom = virDomainLookupByID(ctl->conn, id))) {
|
||||||
|
vshError(ctl, FALSE, _("a running domain like %s cannot be undefined;\n"
|
||||||
|
"to undefine, first shutdown then undefine"
|
||||||
|
" using its name or UUID"), name);
|
||||||
|
virDomainFree(dom);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
if (!(dom = vshCommandOptDomainBy(ctl, cmd, "domain", &name,
|
if (!(dom = vshCommandOptDomainBy(ctl, cmd, "domain", &name,
|
||||||
VSH_BYNAME|VSH_BYUUID)))
|
VSH_BYNAME|VSH_BYUUID)))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -51,6 +51,7 @@ test_scripts += \
|
|||||||
int-overflow \
|
int-overflow \
|
||||||
read-bufsiz \
|
read-bufsiz \
|
||||||
read-non-seekable \
|
read-non-seekable \
|
||||||
|
undefine \
|
||||||
vcpupin
|
vcpupin
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
55
tests/undefine
Executable file
55
tests/undefine
Executable file
@ -0,0 +1,55 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# exercise virsh's "undefine" command
|
||||||
|
|
||||||
|
# Copyright (C) 2008 Free Software Foundation, 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 3 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/>.
|
||||||
|
|
||||||
|
if test "$VERBOSE" = yes; then
|
||||||
|
set -x
|
||||||
|
virsh --version
|
||||||
|
fi
|
||||||
|
|
||||||
|
. $srcdir/test-lib.sh
|
||||||
|
|
||||||
|
fail=0
|
||||||
|
|
||||||
|
# Attempt to undefine a running domain, by domain name.
|
||||||
|
virsh -q -c test:///default undefine test > out 2>&1
|
||||||
|
test $? = 1 || fail=1
|
||||||
|
cat <<\EOF > exp || fail=1
|
||||||
|
libvir: Test error test: internal error Domain is still running
|
||||||
|
error: Failed to undefine domain test
|
||||||
|
EOF
|
||||||
|
compare out exp || fail=1
|
||||||
|
|
||||||
|
# A different diagnostic when specifying a domain ID
|
||||||
|
virsh -q -c test:///default undefine 1 > out 2>&1
|
||||||
|
test $? = 1 || fail=1
|
||||||
|
cat <<\EOF > exp || fail=1
|
||||||
|
error: a running domain like 1 cannot be undefined;
|
||||||
|
to undefine, first shutdown then undefine using its name or UUID
|
||||||
|
EOF
|
||||||
|
compare out exp || fail=1
|
||||||
|
|
||||||
|
# Succeed, now: first shut down, then undefine, both via name.
|
||||||
|
virsh -q -c test:///default 'shutdown test; undefine test' > out 2>&1
|
||||||
|
test $? = 0 || fail=1
|
||||||
|
cat <<\EOF > exp || fail=1
|
||||||
|
Domain test is being shutdown
|
||||||
|
Domain test has been undefined
|
||||||
|
EOF
|
||||||
|
compare out exp || fail=1
|
||||||
|
|
||||||
|
(exit $fail); exit $fail
|
Loading…
x
Reference in New Issue
Block a user