From patchwork Fri May 6 15:03:47 2011 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Amos Kong X-Patchwork-Id: 762302 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by demeter1.kernel.org (8.14.4/8.14.3) with ESMTP id p46F485W010398 for ; Fri, 6 May 2011 15:04:08 GMT Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755383Ab1EFPEF (ORCPT ); Fri, 6 May 2011 11:04:05 -0400 Received: from mx1.redhat.com ([209.132.183.28]:33875 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755345Ab1EFPEE (ORCPT ); Fri, 6 May 2011 11:04:04 -0400 Received: from int-mx12.intmail.prod.int.phx2.redhat.com (int-mx12.intmail.prod.int.phx2.redhat.com [10.5.11.25]) by mx1.redhat.com (8.14.4/8.14.4) with ESMTP id p46F437I030311 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=OK); Fri, 6 May 2011 11:04:03 -0400 Received: from localhost6.localdomain6 (vpn2-8-71.sin2.redhat.com [10.67.8.71]) by int-mx12.intmail.prod.int.phx2.redhat.com (8.14.4/8.14.4) with ESMTP id p46F3psV014221; Fri, 6 May 2011 11:03:52 -0400 Subject: [PATCH 2/3] KVM-test: Simple stop/continue test To: autotest@test.kernel.org From: Amos Kong Cc: lmr@redhat.com, kvm@vger.kernel.org Date: Fri, 06 May 2011 23:03:47 +0800 Message-ID: <20110506150347.5847.29528.stgit@localhost6.localdomain6> In-Reply-To: References: User-Agent: StGit/0.15 MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.68 on 10.5.11.25 Sender: kvm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org X-Greylist: IP, sender and recipient auto-whitelisted, not delayed by milter-greylist-4.2.6 (demeter1.kernel.org [140.211.167.41]); Fri, 06 May 2011 15:04:08 +0000 (UTC) Change guest state by monitor cmd, verify guest status, and try to login guest by network. Changes from v1: - use new method verify_status() to check vm status Signed-off-by: Jason Wang Signed-off-by: Amos Kong --- client/tests/kvm/tests/stop_continue.py | 43 +++++++++++++++++++++++++++++++ client/tests/kvm/tests_base.cfg.sample | 4 +++ 2 files changed, 47 insertions(+), 0 deletions(-) create mode 100644 client/tests/kvm/tests/stop_continue.py -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html diff --git a/client/tests/kvm/tests/stop_continue.py b/client/tests/kvm/tests/stop_continue.py new file mode 100644 index 0000000..62df48e --- /dev/null +++ b/client/tests/kvm/tests/stop_continue.py @@ -0,0 +1,43 @@ +import logging +from autotest_lib.client.common_lib import error + + +def run_stop_continue(test, params, env): + """ + Suspend a running Virtual Machine and verify its state. + + 1) Boot the vm + 2) Suspend the vm through stop command + 3) Verify the state through info status command + 4) Check is the ssh session to guest is still responsive, + if succeed, fail the test. + + @param test: Kvm test object + @param params: Dictionary with the test parameters + @param env: Dictionary with test environment. + """ + vm = env.get_vm(params["main_vm"]) + vm.verify_alive() + timeout = float(params.get("login_timeout", 240)) + session = vm.wait_for_login(timeout=timeout) + + try: + logging.info("Stop the VM") + vm.monitor.cmd("stop") + logging.info("Verifying the status of VM is 'paused'") + vm.verify_status("paused") + + logging.info("Check the session is responsive") + if session.is_responsive(): + raise error.TestFail("Session is still responsive after stop") + + logging.info("Try to resume the guest") + vm.monitor.cmd("cont") + logging.info("Verifying the status of VM is 'running'") + vm.verify_status("running") + + logging.info("Try to re-log into guest") + session = vm.wait_for_login(timeout=timeout) + + finally: + session.close() diff --git a/client/tests/kvm/tests_base.cfg.sample b/client/tests/kvm/tests_base.cfg.sample index 78c84c6..1e659bc 100644 --- a/client/tests/kvm/tests_base.cfg.sample +++ b/client/tests/kvm/tests_base.cfg.sample @@ -261,6 +261,10 @@ variants: - systemtap: test_control_file = systemtap.control + - stop_continue: + type = stop_continue + kill_vm_on_error = yes + - linux_s3: install setup unattended_install.cdrom only Linux type = linux_s3