summaryrefslogtreecommitdiff
path: root/bin
diff options
Diffstat (limited to 'bin')
-rwxr-xr-xbin/virtualization77
1 files changed, 45 insertions, 32 deletions
diff --git a/bin/virtualization b/bin/virtualization
index 46cf13ed..b67a5fac 100755
--- a/bin/virtualization
+++ b/bin/virtualization
@@ -229,14 +229,14 @@ class KVMTest(object):
def _construct_filename(alt_pattern=None, initial_url=None):
if self.qemu_config['cloudimg_type'] == CLOUD_IMAGE_TYPE_TAR:
cloud_iso = "%s-server-cloudimg-%s.tar.gz" % (
- self.release, self.qemu_config['cloudimg_arch'])
+ self.release, self.qemu_config['cloudimg_arch'])
elif alt_pattern is "modern":
# LP 1635345 - yakkety and beyond have a new naming scheme
cloud_iso = "%s-server-cloudimg-%s.img" % (
- self.release, self.qemu_config['cloudimg_arch'])
+ self.release, self.qemu_config['cloudimg_arch'])
elif self.qemu_config['cloudimg_type'] == CLOUD_IMAGE_TYPE_DISK:
cloud_iso = "%s-server-cloudimg-%s-disk1.img" % (
- self.release, self.qemu_config['cloudimg_arch'])
+ self.release, self.qemu_config['cloudimg_arch'])
elif initial_url:
# LP 1662580 - if we pass a full URL, assume the last piece is
# the filname and return that.
@@ -388,7 +388,7 @@ class KVMTest(object):
logging.debug("Using params:{}".format(" ".join(params)))
logging.info("Storing VM console output in {}".format(
- os.path.realpath(self.debug_file)))
+ os.path.realpath(self.debug_file)))
# Open VM STDERR/STDOUT log file for writing
try:
file = open(self.debug_file, 'w')
@@ -440,6 +440,12 @@ final_message: CERTIFICATION BOOT COMPLETE
except CalledProcessError as exception:
logging.exception("Cloud data disk creation failed")
+ def log_check(self, stream):
+ if "CERTIFICATION BOOT COMPLETE" in stream:
+ return 0
+ else:
+ return 1
+
def start(self):
if self.arch == 'arm64':
# lp:1548539 - For arm64, we need to make sure we're using qemu
@@ -485,36 +491,42 @@ final_message: CERTIFICATION BOOT COMPLETE
# Boot Virtual Machine
instance = self.boot_image(self.image)
- time.sleep(self.timeout)
# If running in console, reset console window to regain
# control from VM Serial I/0
if sys.stdout.isatty():
call('reset')
# Check to be sure VM boot was successful
- with open(self.debug_file, 'r') as debug_file:
- file_contents = debug_file.read()
- if "CERTIFICATION BOOT COMPLETE" in file_contents:
- if "END SSH HOST KEY KEYS" in file_contents:
- print("Booted successfully", file=sys.stderr)
+ self.elapsed_time = 0
+ status = 1
+ while self.elapsed_time <= self.timeout:
+ # Check log every 30 seconds to see if the VM boots
+ with open(self.debug_file, 'r') as debug_file:
+ status = self.log_check(debug_file.read())
+ if status == 0:
+ logging.info("Booted successfully.")
+ break
else:
- print("Booted successfully (Previously "
- "initalized VM)", file=sys.stderr)
- status = 0
- else:
- print("E: KVM instance failed to boot",
- file=sys.stderr)
- print("Console output".center(72, "="),
- file=sys.stderr)
- with open(self.debug_file, 'r') as console_log:
- print(console_log.read(), file=sys.stderr)
- print("E: KVM instance failed to boot",
- file=sys.stderr)
+ # Sleep 30 seconds and log check again
+ time.sleep(30)
+ self.elapsed_time += 30
+ else:
+ # Finally, if we didn't get the Success message by now try
+ # one more time and return 1 if we still haven't booted
+ if status != 0:
+ with open(self.debug_file, 'r') as debug_file:
+ stream = debug_file.read()
+ status = self.log_check(stream)
+ if status == 0:
+ logging.info("Booted successfully.")
+ else:
+ logging.error("KVM instance failed to boot.")
+ logging.error("Console output".center(72, "="))
+ logging.error(stream)
self.process.terminate()
elif not self.image:
- print("Could not find downloaded image")
+ logging.error("Could not find downloaded image")
else:
- print("Could not find: {}".format(self.image),
- file=sys.stderr)
+ logging.error("Could not find: {}".format(self.image))
return status
@@ -560,7 +572,7 @@ class LXDTest(object):
task = RunCommand(cmd)
if task.returncode != 0:
logging.error('Command {} returnd a code of {}'.format(
- task.cmd, task.returncode))
+ task.cmd, task.returncode))
logging.error(' STDOUT: {}'.format(task.stdout))
logging.error(' STDERR: {}'.format(task.stderr))
return False
@@ -611,7 +623,7 @@ class LXDTest(object):
filename)
if not self.rootfs_tarball:
logging.error("Unable to download {} from{}".format(
- self.rootfs_tarball, self.rootfs_url))
+ self.rootfs_tarball, self.rootfs_url))
logging.error("Aborting")
result = False
else:
@@ -620,11 +632,11 @@ class LXDTest(object):
self.rootfs_tarball = filename
# Insert images
- if self.template_url is not None and self.rootfs_url is not None:
+ if self.template_url is not None and self.rootfs_url is not None:
logging.debug("Importing images into LXD")
cmd = 'lxc image import {} rootfs {} --alias {}'.format(
- self.template_tarball, self.rootfs_tarball,
- self.image_alias)
+ self.template_tarball, self.rootfs_tarball,
+ self.image_alias)
if not self.run_command(cmd):
logging.error('Error encountered while attempting to '
'import images into LXD')
@@ -633,7 +645,7 @@ class LXDTest(object):
logging.debug("No local image available, attempting to "
"import from default remote.")
cmd = 'lxc image copy {}{} local: --alias {}'.format(
- self.default_remote, self.os_version, self.image_alias)
+ self.default_remote, self.os_version, self.image_alias)
if not self.run_command(cmd):
logging.error('Error encountered while attempting to '
'import images from default remote.')
@@ -735,7 +747,7 @@ def test_lxd(args):
def test_kvm(args):
- print("Executing KVM Test", file=sys.stderr)
+ logging.debug("Executing KVM Test")
image = ""
timeout = ""
@@ -809,6 +821,7 @@ def main():
# silence normal output from requests module
logging.getLogger("requests").setLevel(logging.WARNING)
+ logging.getLogger("urllib3").setLevel(logging.WARNING)
# Verify args
try: