2013-10-27 15:59:46 -05:00
|
|
|
# Copyright (C) 2013 Red Hat, Inc.
|
2013-03-17 16:06:52 -05:00
|
|
|
#
|
2018-04-04 08:35:41 -05:00
|
|
|
# This work is licensed under the GNU GPLv2 or later.
|
2018-03-20 14:00:02 -05:00
|
|
|
# See the COPYING file in the top-level directory.
|
2013-03-17 16:06:52 -05:00
|
|
|
|
|
|
|
import logging
|
2018-01-05 14:49:53 -06:00
|
|
|
import os
|
2018-03-28 13:56:52 -05:00
|
|
|
import re
|
2018-01-02 13:58:57 -06:00
|
|
|
import sys
|
2016-04-07 16:13:17 -05:00
|
|
|
import traceback
|
2018-01-05 14:49:53 -06:00
|
|
|
import unittest
|
2013-09-25 17:52:41 -05:00
|
|
|
|
2013-04-10 18:48:07 -05:00
|
|
|
from tests import utils
|
2013-09-25 17:52:41 -05:00
|
|
|
|
2019-01-31 11:54:50 -06:00
|
|
|
from virtinst import Installer
|
2013-09-25 17:52:41 -05:00
|
|
|
from virtinst import Guest
|
2015-09-06 13:26:50 -05:00
|
|
|
from virtinst import util
|
2013-09-25 17:52:41 -05:00
|
|
|
|
2013-09-26 13:47:08 -05:00
|
|
|
|
2018-03-28 13:39:40 -05:00
|
|
|
class _URLTestData(object):
|
|
|
|
"""
|
|
|
|
Class that tracks all data needed for a single URL test case.
|
|
|
|
Data is stored in test_urls.ini
|
|
|
|
"""
|
2018-01-02 13:58:57 -06:00
|
|
|
def __init__(self, name, url, detectdistro,
|
2019-03-24 10:22:50 -05:00
|
|
|
testxen, testshortcircuit, kernelarg, kernelregex,
|
|
|
|
skip_libosinfo):
|
2018-01-02 13:58:57 -06:00
|
|
|
self.name = name
|
2017-08-29 10:04:57 -05:00
|
|
|
self.url = url
|
2013-09-26 09:24:28 -05:00
|
|
|
self.detectdistro = detectdistro
|
2018-01-02 13:58:57 -06:00
|
|
|
self.arch = self._find_arch()
|
2018-04-02 15:50:41 -05:00
|
|
|
self.kernelarg = kernelarg
|
2018-10-18 12:01:59 -05:00
|
|
|
self.kernelregex = kernelregex
|
2019-03-24 10:22:50 -05:00
|
|
|
self.skip_libosinfo = skip_libosinfo
|
2018-01-02 13:58:57 -06:00
|
|
|
|
|
|
|
self.testxen = testxen
|
2013-09-26 09:24:28 -05:00
|
|
|
|
2013-09-26 16:44:30 -05:00
|
|
|
# If True, pass in the expected distro value to getDistroStore
|
2018-01-02 13:58:57 -06:00
|
|
|
# so it can short circuit the lookup checks. Speeds up the tests
|
|
|
|
# and exercises the shortcircuit infrastructure
|
2013-09-26 16:44:30 -05:00
|
|
|
self.testshortcircuit = testshortcircuit
|
|
|
|
|
2018-01-02 13:58:57 -06:00
|
|
|
def _find_arch(self):
|
|
|
|
if ("i686" in self.url or
|
|
|
|
"i386" in self.url or
|
|
|
|
"i586" in self.url):
|
|
|
|
return "i686"
|
|
|
|
if ("arm64" in self.url or
|
|
|
|
"aarch64" in self.url):
|
|
|
|
return "aarch64"
|
|
|
|
if ("ppc64el" in self.url or
|
|
|
|
"ppc64le" in self.url):
|
|
|
|
return "ppc64le"
|
|
|
|
if "s390" in self.url:
|
|
|
|
return "s390x"
|
|
|
|
if ("x86_64" in self.url or
|
|
|
|
"amd64" in self.url):
|
|
|
|
return "x86_64"
|
|
|
|
return "x86_64"
|
2013-03-17 16:06:52 -05:00
|
|
|
|
2018-02-22 13:57:10 -06:00
|
|
|
testconn = utils.URIs.open_testdefault_cached()
|
2013-09-26 12:04:28 -05:00
|
|
|
hvmguest = Guest(testconn)
|
|
|
|
hvmguest.os.os_type = "hvm"
|
|
|
|
xenguest = Guest(testconn)
|
|
|
|
xenguest.os.os_type = "xen"
|
|
|
|
|
2018-02-22 12:46:24 -06:00
|
|
|
meter = util.make_meter(quiet=not utils.clistate.debug)
|
2013-03-17 16:06:52 -05:00
|
|
|
|
2019-03-24 10:22:50 -05:00
|
|
|
if utils.clistate.url_skip_libosinfo:
|
|
|
|
os.environ["VIRTINST_TEST_SUITE_FORCE_LIBOSINFO"] = "0"
|
|
|
|
elif utils.clistate.url_force_libosinfo:
|
|
|
|
os.environ["VIRTINST_TEST_SUITE_FORCE_LIBOSINFO"] = "1"
|
|
|
|
|
2013-04-13 13:34:52 -05:00
|
|
|
|
2018-03-28 13:56:52 -05:00
|
|
|
def _sanitize_osdict_name(detectdistro):
|
2018-10-18 12:43:12 -05:00
|
|
|
if detectdistro in ["none", "None", None]:
|
|
|
|
return None
|
2018-03-28 13:56:52 -05:00
|
|
|
return detectdistro
|
|
|
|
|
|
|
|
|
2019-03-24 10:22:50 -05:00
|
|
|
def _skipmsg(testdata):
|
|
|
|
is_iso = testdata.url.lower().endswith(".iso")
|
|
|
|
distname = testdata.name
|
|
|
|
|
|
|
|
if utils.clistate.url_iso_only and not is_iso:
|
|
|
|
return "skipping non-iso test"
|
|
|
|
elif utils.clistate.url_only and is_iso:
|
|
|
|
return "skipping non-url test"
|
|
|
|
|
|
|
|
if not utils.clistate.url_force_libosinfo:
|
|
|
|
return
|
|
|
|
if testdata.skip_libosinfo:
|
|
|
|
return "force-libosinfo requested but test has skip_libosinfo set"
|
|
|
|
if is_iso:
|
|
|
|
return
|
|
|
|
|
|
|
|
# If --force-libosinfo used, don't run tests that we know libosinfo
|
|
|
|
# can't detect, non-treeinfo URLs basically
|
|
|
|
if ("ubuntu" in distname or
|
|
|
|
"debian" in distname or
|
|
|
|
"mageia" in distname or
|
|
|
|
"opensuse10" in distname or
|
|
|
|
"opensuse11" in distname or
|
|
|
|
"opensuse12" in distname or
|
|
|
|
"opensuse13" in distname or
|
|
|
|
"opensuseleap-42" in distname or
|
|
|
|
"generic" in distname):
|
|
|
|
return "skipping known busted libosinfo URL tests"
|
|
|
|
|
|
|
|
|
2019-01-31 11:54:50 -06:00
|
|
|
def _testGuest(testdata, guest):
|
2018-03-28 13:39:40 -05:00
|
|
|
distname = testdata.name
|
|
|
|
arch = testdata.arch
|
2019-01-31 11:54:50 -06:00
|
|
|
url = testdata.url
|
|
|
|
checkdistro = testdata.detectdistro
|
2018-03-28 13:56:52 -05:00
|
|
|
|
2019-01-31 11:54:50 -06:00
|
|
|
guest.os.arch = arch
|
2018-03-28 13:39:40 -05:00
|
|
|
if testdata.testshortcircuit:
|
2019-01-31 11:54:50 -06:00
|
|
|
guest.set_os_name(checkdistro)
|
2013-03-17 16:06:52 -05:00
|
|
|
|
2019-03-24 10:22:50 -05:00
|
|
|
msg = _skipmsg(testdata)
|
|
|
|
if msg:
|
|
|
|
raise unittest.SkipTest(msg)
|
|
|
|
|
2019-01-31 11:54:50 -06:00
|
|
|
installer = Installer(guest.conn, location=url)
|
2016-04-07 16:13:17 -05:00
|
|
|
try:
|
2019-01-31 11:54:50 -06:00
|
|
|
detected_distro = installer.detect_distro(guest)
|
2017-07-24 03:26:48 -05:00
|
|
|
except Exception:
|
2019-01-31 11:54:50 -06:00
|
|
|
raise AssertionError("\nFailed in installer detect_distro():\n"
|
2016-04-07 16:13:17 -05:00
|
|
|
"name = %s\n"
|
|
|
|
"url = %s\n\n%s" %
|
2019-01-31 11:54:50 -06:00
|
|
|
(distname, url, "".join(traceback.format_exc())))
|
|
|
|
|
|
|
|
# Make sure the stores are reporting correct distro name/variant
|
|
|
|
if checkdistro != detected_distro:
|
|
|
|
raise AssertionError(
|
|
|
|
"Detected OS did not match expected values:\n"
|
|
|
|
"found = %s\n"
|
|
|
|
"expect = %s\n\n"
|
|
|
|
"testname = %s\n"
|
|
|
|
"url = %s\n" %
|
|
|
|
(detected_distro, checkdistro, distname, url))
|
|
|
|
|
|
|
|
if guest is xenguest:
|
|
|
|
return
|
2013-09-26 10:49:16 -05:00
|
|
|
|
2019-03-24 10:22:50 -05:00
|
|
|
|
2019-01-31 12:42:02 -06:00
|
|
|
# Do this only after the distro detection, since we actually need
|
|
|
|
# to fetch files for that part
|
|
|
|
treemedia = installer._treemedia # pylint: disable=protected-access
|
|
|
|
fetcher = treemedia._cached_fetcher # pylint: disable=protected-access
|
|
|
|
def fakeAcquireFile(filename):
|
|
|
|
logging.debug("Fake acquiring %s", filename)
|
|
|
|
return filename
|
|
|
|
fetcher.acquireFile = fakeAcquireFile
|
|
|
|
|
2013-09-26 10:49:16 -05:00
|
|
|
# Fetch regular kernel
|
2019-01-31 12:42:02 -06:00
|
|
|
kernel, initrd, kernelargs = treemedia.prepare(guest, meter)
|
2019-01-29 15:05:27 -06:00
|
|
|
dummy = initrd
|
2018-10-18 12:01:59 -05:00
|
|
|
if testdata.kernelregex and not re.match(testdata.kernelregex, kernel):
|
|
|
|
raise AssertionError("kernel=%s but testdata.kernelregex='%s'" %
|
|
|
|
(kernel, testdata.kernelregex))
|
|
|
|
|
2018-04-02 15:50:41 -05:00
|
|
|
if testdata.kernelarg == "None":
|
|
|
|
if bool(kernelargs):
|
|
|
|
raise AssertionError("kernelargs='%s' but testdata.kernelarg='%s'"
|
|
|
|
% (kernelargs, testdata.kernelarg))
|
|
|
|
elif testdata.kernelarg:
|
2019-01-31 12:42:02 -06:00
|
|
|
if testdata.kernelarg != str(kernelargs).split("=")[0]:
|
2018-04-02 15:50:41 -05:00
|
|
|
raise AssertionError("kernelargs='%s' but testdata.kernelarg='%s'"
|
|
|
|
% (kernelargs, testdata.kernelarg))
|
|
|
|
|
2013-09-26 10:49:16 -05:00
|
|
|
|
2019-01-31 11:54:50 -06:00
|
|
|
def _testURL(testdata):
|
|
|
|
"""
|
|
|
|
Test that our URL detection logic works for grabbing kernels
|
|
|
|
"""
|
|
|
|
testdata.detectdistro = _sanitize_osdict_name(testdata.detectdistro)
|
|
|
|
_testGuest(testdata, hvmguest)
|
|
|
|
if testdata.testxen:
|
|
|
|
_testGuest(testdata, xenguest)
|
2018-03-29 18:22:28 -05:00
|
|
|
|
|
|
|
|
2018-03-28 13:39:40 -05:00
|
|
|
def _testURLWrapper(testdata):
|
2018-01-27 13:49:43 -06:00
|
|
|
os.environ.pop("VIRTINST_TEST_SUITE", None)
|
|
|
|
|
2018-03-28 13:39:40 -05:00
|
|
|
sys.stdout.write("\nTesting %-25s " % testdata.name)
|
2018-01-27 13:49:43 -06:00
|
|
|
sys.stdout.flush()
|
|
|
|
|
2019-01-31 11:54:50 -06:00
|
|
|
return _testURL(testdata)
|
2013-09-26 10:49:16 -05:00
|
|
|
|
|
|
|
|
|
|
|
# Register tests to be picked up by unittest
|
|
|
|
class URLTests(unittest.TestCase):
|
2018-03-29 18:22:28 -05:00
|
|
|
def test001BadURL(self):
|
|
|
|
badurl = "http://aksdkakskdfa-idontexist.com/foo/tree"
|
|
|
|
|
|
|
|
try:
|
2019-01-31 11:54:50 -06:00
|
|
|
installer = Installer(hvmguest.conn, location=badurl)
|
|
|
|
installer.detect_distro(hvmguest)
|
2018-03-29 18:22:28 -05:00
|
|
|
raise AssertionError("Expected URL failure")
|
|
|
|
except ValueError as e:
|
|
|
|
self.assertTrue("maybe you mistyped" in str(e))
|
|
|
|
|
2019-01-31 12:01:33 -06:00
|
|
|
# Non-existent cdrom fails
|
|
|
|
try:
|
2019-05-16 06:13:09 -05:00
|
|
|
installer = Installer(hvmguest.conn, cdrom="/not/exist/foobar")
|
2019-01-31 12:01:33 -06:00
|
|
|
self.assertEqual(None, installer.detect_distro(hvmguest))
|
|
|
|
raise AssertionError("Expected cdrom failure")
|
|
|
|
except ValueError as e:
|
|
|
|
self.assertTrue("non-existent path" in str(e))
|
|
|
|
|
|
|
|
# Ensure existing but non-distro file doesn't error
|
|
|
|
installer = Installer(hvmguest.conn, cdrom="/dev/null")
|
|
|
|
self.assertEqual(None, installer.detect_distro(hvmguest))
|
2013-09-26 10:49:16 -05:00
|
|
|
|
|
|
|
|
|
|
|
def _make_tests():
|
2017-10-11 06:35:39 -05:00
|
|
|
import configparser
|
|
|
|
cfg = configparser.ConfigParser()
|
2018-01-02 13:58:57 -06:00
|
|
|
cfg.read("tests/test_urls.ini")
|
|
|
|
|
2018-04-03 14:29:03 -05:00
|
|
|
manualpath = "~/.config/virt-manager/test_urls_manual.ini"
|
2018-04-16 10:36:39 -05:00
|
|
|
cfg.read(os.path.expanduser(manualpath))
|
2018-04-03 14:29:03 -05:00
|
|
|
if not os.path.exists(os.path.expanduser(manualpath)):
|
2018-01-05 14:49:53 -06:00
|
|
|
print("NOTE: Pass in manual data with %s" % manualpath)
|
|
|
|
|
2018-01-02 13:58:57 -06:00
|
|
|
urls = {}
|
|
|
|
for name in cfg.sections():
|
|
|
|
vals = dict(cfg.items(name))
|
2019-03-02 15:52:24 -06:00
|
|
|
url = vals["url"]
|
|
|
|
|
|
|
|
if "distro" not in vals:
|
|
|
|
print("url needs an explicit distro= value: %s" % url)
|
|
|
|
sys.exit(1)
|
|
|
|
d = _URLTestData(name, url, vals["distro"],
|
2018-03-28 13:39:40 -05:00
|
|
|
vals.get("testxen", "0") == "1",
|
2018-04-02 15:50:41 -05:00
|
|
|
vals.get("testshortcircuit", "0") == "1",
|
2018-10-18 12:01:59 -05:00
|
|
|
vals.get("kernelarg", None),
|
2019-03-24 10:22:50 -05:00
|
|
|
vals.get("kernelregex", None),
|
|
|
|
vals.get("skiplibosinfo", "0") == "1")
|
2018-01-02 13:58:57 -06:00
|
|
|
urls[d.name] = d
|
2013-09-26 17:32:50 -05:00
|
|
|
|
2018-12-18 07:44:51 -06:00
|
|
|
for key, testdata in sorted(urls.items()):
|
2018-01-02 13:58:57 -06:00
|
|
|
def _make_wrapper(d):
|
|
|
|
return lambda _self: _testURLWrapper(d)
|
|
|
|
setattr(URLTests, "testURL%s" % key.replace("-", "_"),
|
2018-03-28 13:39:40 -05:00
|
|
|
_make_wrapper(testdata))
|
2013-03-17 16:06:52 -05:00
|
|
|
|
2013-09-26 10:49:16 -05:00
|
|
|
_make_tests()
|