c085d819a8
virt-manager-1.5.0.tar.bz2 * python3 prep work (Radostin Stoyanov, Cole Robinson, Cédric Bosdonnat) * Switch –location ISO to use isoinfo (Andrew Wong) * virt-install: add –cpu numa distance handling (Menno Lageman) * virt-install: fix –disk for rbd volumes with auth (Rauno Väli) * virt-install: add –cputune vcpupin handling (Wim ten Have) * details ui: Showing attached scsi devices per controller (Lin Ma) * network ui: Show details about SR-IOV VF pool (Lin Ma) * Greatly expand UI test suite coverage - Dropped patches 0001-Improve-container-image-url-example.patch 0001-py3-store-exception-variables-for-use-outside-except.patch 0002-create-wizard-fix-alignment-in-os-container-page.patch 0003-oscontainer-ask-root-password-in-the-wizard.patch 0004-Harmonize-invisible_char-values.patch 083dfcc8-Show-details-about-the-network-of-SR-IOV-VF-pool.patch 08a58d61-pycodestyle-remove-description-of-fixed-errors.patch 0c6bcb09-fix-bytes-string-mess-in-serial-console.patch 0e812e3c-dont-skip-authentication-for-listen-type-none-with-fixed-QEMU.patch 23aaf852-network-Set-bridge-name-to-None-instead-of-blank.patch 2d276ebe-progress-dont-overwrite-format.patch 2eb455c9-correctly-calculate-virtio-scsi-controller-index.patch 374a3779-urlfetcher-write-test-file-as-binary-content.patch 37ea5207-replace-StandardError-with-Exception.patch 3b769643-dont-add-URI-into-params-for-tunneled-migration.patch 3be78d1f-addhardware-dont-allow-panic-option-where-not-supported.patch 44de92b7-use-reload-from-imp-module.patch 63fce081-pycodestyle-Use-isinstance-for-type-checking.patch 67122615-python2to3-division-compatability.patch OBS-URL: https://build.opensuse.org/package/show/Virtualization/virt-manager?expand=0&rev=406
629 lines
24 KiB
Diff
629 lines
24 KiB
Diff
Index: virt-manager-1.5.0/virt-install
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virt-install
|
|
+++ virt-manager-1.5.0/virt-install
|
|
@@ -1,4 +1,4 @@
|
|
-#!/usr/bin/env python2
|
|
+#!/usr/bin/python3
|
|
#
|
|
# Copyright 2005-2014 Red Hat, Inc.
|
|
#
|
|
Index: virt-manager-1.5.0/virtinst/uri.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/uri.py
|
|
+++ virt-manager-1.5.0/virtinst/uri.py
|
|
@@ -19,7 +19,7 @@
|
|
|
|
import logging
|
|
import re
|
|
-import urllib
|
|
+import urllib.request, urllib.parse, urllib.error
|
|
|
|
from .cli import parse_optstr_tuples
|
|
|
|
@@ -47,7 +47,7 @@ class URI(object):
|
|
"""
|
|
def __init__(self, uri):
|
|
self.uri = uri
|
|
- unquoted_uri = urllib.unquote(uri)
|
|
+ unquoted_uri = urllib.parse.unquote(uri)
|
|
|
|
(self.scheme, self.username, self.hostname,
|
|
self.path, self.query, self.fragment) = self._split(unquoted_uri)
|
|
Index: virt-manager-1.5.0/virtinst/hostkeymap.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/hostkeymap.py
|
|
+++ virt-manager-1.5.0/virtinst/hostkeymap.py
|
|
@@ -20,6 +20,7 @@
|
|
import logging
|
|
import os
|
|
import re
|
|
+import functools
|
|
|
|
|
|
_ETC_VCONSOLE = "/etc/vconsole.conf"
|
|
@@ -202,7 +203,7 @@ def sanitize_keymap(kt):
|
|
return len(b) - len(a)
|
|
|
|
clean_kt = kt.replace("-", "").replace("_", "")
|
|
- sorted_keys = sorted(keytable.keys(), len_cmp)
|
|
+ sorted_keys = sorted(list(keytable.keys()), key=functools.cmp_to_key(len_cmp))
|
|
|
|
for key in sorted_keys:
|
|
origkey = key
|
|
Index: virt-manager-1.5.0/virtinst/support.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/support.py
|
|
+++ virt-manager-1.5.0/virtinst/support.py
|
|
@@ -167,7 +167,7 @@ class _SupportCheck(object):
|
|
self.hv_version = hv_version or {}
|
|
self.hv_libvirt_version = hv_libvirt_version or {}
|
|
|
|
- versions = ([self.version] + self.hv_libvirt_version.values())
|
|
+ versions = ([self.version] + list(self.hv_libvirt_version.values()))
|
|
for vstr in versions:
|
|
v = _version_str_to_int(vstr)
|
|
if vstr is not None and v != 0 and v < 7009:
|
|
Index: virt-manager-1.5.0/virtinst/osdict.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/osdict.py
|
|
+++ virt-manager-1.5.0/virtinst/osdict.py
|
|
@@ -79,7 +79,7 @@ def _sort(tosort, sortpref=None, limit_p
|
|
retlist = []
|
|
sortpref = sortpref or []
|
|
|
|
- for key, osinfo in tosort.items():
|
|
+ for key, osinfo in list(tosort.items()):
|
|
# Libosinfo has some duplicate version numbers here, so append .1
|
|
# if there's a collision
|
|
sortby = osinfo.sortby
|
|
@@ -98,12 +98,12 @@ def _sort(tosort, sortpref=None, limit_p
|
|
# debian5, debian4, fedora14, fedora13
|
|
# rather than
|
|
# debian4, debian5, fedora13, fedora14
|
|
- for distro_list in distro_mappings.values():
|
|
+ for distro_list in list(distro_mappings.values()):
|
|
distro_list.sort()
|
|
distro_list.reverse()
|
|
|
|
# Move the sortpref values to the front of the list
|
|
- sorted_distro_list = distro_mappings.keys()
|
|
+ sorted_distro_list = list(distro_mappings.keys())
|
|
sorted_distro_list.sort()
|
|
sortpref.reverse()
|
|
for prefer in sortpref:
|
|
@@ -258,7 +258,7 @@ class _OSDB(object):
|
|
"""
|
|
sortmap = {}
|
|
|
|
- for name, osobj in self._all_variants.items():
|
|
+ for name, osobj in list(self._all_variants.items()):
|
|
if typename and typename != osobj.get_typename():
|
|
continue
|
|
if only_supported and not osobj.get_supported():
|
|
Index: virt-manager-1.5.0/virtinst/guest.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/guest.py
|
|
+++ virt-manager-1.5.0/virtinst/guest.py
|
|
@@ -434,7 +434,7 @@ class Guest(XMLBuilder):
|
|
domain.undefine()
|
|
except Exception:
|
|
pass
|
|
- raise exc_info[0], exc_info[1], exc_info[2]
|
|
+ raise exc_info[0](exc_info[1]).with_traceback(exc_info[2])
|
|
|
|
if install_xml and install_xml != final_xml:
|
|
domain = self.conn.defineXML(final_xml)
|
|
@@ -1075,7 +1075,7 @@ class Guest(XMLBuilder):
|
|
(str(d), str(addresses[addrstr][addr.function])))
|
|
addresses[addrstr][addr.function] = d
|
|
|
|
- for devs in addresses.values():
|
|
+ for devs in list(addresses.values()):
|
|
if len(devs) > 1 and 0 in devs:
|
|
devs[0].address.multifunction = True
|
|
|
|
Index: virt-manager-1.5.0/virtinst/distroinstaller.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/distroinstaller.py
|
|
+++ virt-manager-1.5.0/virtinst/distroinstaller.py
|
|
@@ -68,7 +68,7 @@ def _sanitize_url(url):
|
|
MEDIA_LOCATION_URL,
|
|
MEDIA_CDROM_PATH,
|
|
MEDIA_CDROM_URL,
|
|
- MEDIA_CDROM_IMPLIED) = range(1, 7)
|
|
+ MEDIA_CDROM_IMPLIED) = list(range(1, 7))
|
|
|
|
|
|
class DistroInstaller(Installer):
|
|
Index: virt-manager-1.5.0/virtinst/cli.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/cli.py
|
|
+++ virt-manager-1.5.0/virtinst/cli.py
|
|
@@ -19,7 +19,7 @@
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
# MA 02110-1301 USA.
|
|
|
|
-from __future__ import print_function
|
|
+
|
|
|
|
import argparse
|
|
import collections
|
|
@@ -294,7 +294,7 @@ def _do_creds_authname(creds):
|
|
|
|
res = cred[retindex]
|
|
if credtype == libvirt.VIR_CRED_AUTHNAME:
|
|
- res = raw_input(prompt)
|
|
+ res = input(prompt)
|
|
elif credtype == libvirt.VIR_CRED_PASSPHRASE:
|
|
import getpass
|
|
res = getpass.getpass(prompt)
|
|
@@ -1193,7 +1193,7 @@ class VirtCLIParser(object):
|
|
passed an invalid argument such as --disk idontexist=foo
|
|
"""
|
|
if optdict:
|
|
- fail(_("Unknown options %s") % optdict.keys())
|
|
+ fail(_("Unknown options %s") % list(optdict.keys()))
|
|
|
|
def _parse(self, inst):
|
|
"""
|
|
@@ -1681,7 +1681,7 @@ class ParserBoot(VirtCLIParser):
|
|
def _parse(self, inst):
|
|
# Build boot order
|
|
boot_order = []
|
|
- for cliname in self.optdict.keys():
|
|
+ for cliname in list(self.optdict.keys()):
|
|
if cliname not in inst.os.BOOT_DEVICES:
|
|
continue
|
|
|
|
Index: virt-manager-1.5.0/virtinst/xmlbuilder.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/xmlbuilder.py
|
|
+++ virt-manager-1.5.0/virtinst/xmlbuilder.py
|
|
@@ -327,7 +327,7 @@ class XMLChildProperty(property):
|
|
|
|
def _findpropname(self, xmlbuilder):
|
|
if self._propname is None:
|
|
- for key, val in xmlbuilder._all_child_props().items():
|
|
+ for key, val in list(xmlbuilder._all_child_props().items()):
|
|
if val is self:
|
|
self._propname = key
|
|
break
|
|
@@ -475,7 +475,7 @@ class XMLProperty(property):
|
|
as in the XMLBuilder class. This is just for debug purposes.
|
|
"""
|
|
if self._propname is None:
|
|
- for key, val in xmlbuilder._all_xml_props().items():
|
|
+ for key, val in list(xmlbuilder._all_xml_props().items()):
|
|
if val is self:
|
|
self._propname = key
|
|
break
|
|
@@ -829,7 +829,7 @@ class XMLBuilder(object):
|
|
self.conn = conn
|
|
|
|
if self._XML_SANITIZE:
|
|
- parsexml = parsexml.decode('ascii', 'ignore').encode('ascii')
|
|
+ #parsexml = parsexml.decode('ascii', 'ignore').encode('ascii')
|
|
parsexml = "".join([c for c in parsexml if c in string.printable])
|
|
|
|
self._propstore = {}
|
|
@@ -843,7 +843,7 @@ class XMLBuilder(object):
|
|
def _initial_child_parse(self):
|
|
# Walk the XML tree and hand of parsing to any registered
|
|
# child classes
|
|
- for xmlprop in self._all_child_props().values():
|
|
+ for xmlprop in list(self._all_child_props().values()):
|
|
if xmlprop.is_single:
|
|
child_class = xmlprop.child_classes[0]
|
|
prop_path = xmlprop.get_prop_xpath(self, child_class)
|
|
@@ -885,7 +885,7 @@ class XMLBuilder(object):
|
|
|
|
# XMLChildProperty stores a list in propstore, which dict shallow
|
|
# copy won't fix for us.
|
|
- for name, value in ret._propstore.items():
|
|
+ for name, value in list(ret._propstore.items()):
|
|
if not isinstance(value, list):
|
|
continue
|
|
ret._propstore[name] = [obj.copy() for obj in ret._propstore[name]]
|
|
@@ -926,8 +926,8 @@ class XMLBuilder(object):
|
|
if leave_stub:
|
|
_top_node = _get_xpath_node(self._xmlstate.xml_ctx,
|
|
self.get_root_xpath())
|
|
- props = self._all_xml_props().values()
|
|
- props += self._all_child_props().values()
|
|
+ props = list(self._all_xml_props().values())
|
|
+ props += list(self._all_child_props().values())
|
|
for prop in props:
|
|
prop.clear(self)
|
|
finally:
|
|
@@ -990,7 +990,7 @@ class XMLBuilder(object):
|
|
if not hasattr(self.__class__, cachename):
|
|
ret = {}
|
|
for c in reversed(type.mro(self.__class__)[:-1]):
|
|
- for key, val in c.__dict__.items():
|
|
+ for key, val in list(c.__dict__.items()):
|
|
if isinstance(val, checkclass):
|
|
ret[key] = val
|
|
setattr(self.__class__, cachename, ret)
|
|
@@ -1025,7 +1025,7 @@ class XMLBuilder(object):
|
|
|
|
def _find_child_prop(self, child_class, return_single=False):
|
|
xmlprops = self._all_child_props()
|
|
- for xmlprop in xmlprops.values():
|
|
+ for xmlprop in list(xmlprops.values()):
|
|
if xmlprop.is_single and not return_single:
|
|
continue
|
|
if child_class in xmlprop.child_classes:
|
|
@@ -1084,7 +1084,7 @@ class XMLBuilder(object):
|
|
Return a list of all XML child objects with the passed class
|
|
"""
|
|
ret = []
|
|
- for prop in self._all_child_props().values():
|
|
+ for prop in list(self._all_child_props().values()):
|
|
ret += [obj for obj in util.listify(prop._get(self))
|
|
if obj.__class__ == klass]
|
|
return ret
|
|
@@ -1107,7 +1107,7 @@ class XMLBuilder(object):
|
|
xpaths point at their particular element
|
|
"""
|
|
typecount = {}
|
|
- for propname, xmlprop in self._all_child_props().items():
|
|
+ for propname, xmlprop in list(self._all_child_props().items()):
|
|
for obj in util.listify(getattr(self, propname)):
|
|
idxstr = ""
|
|
if not xmlprop.is_single:
|
|
@@ -1165,7 +1165,7 @@ class XMLBuilder(object):
|
|
xmlprops = self._all_xml_props()
|
|
childprops = self._all_child_props()
|
|
|
|
- for prop in xmlprops.values():
|
|
+ for prop in list(xmlprops.values()):
|
|
prop._set_default(self)
|
|
|
|
# Set up preferred XML ordering
|
|
@@ -1180,7 +1180,7 @@ class XMLBuilder(object):
|
|
elif key in childprops:
|
|
do_order.insert(0, key)
|
|
|
|
- for key in childprops.keys():
|
|
+ for key in list(childprops.keys()):
|
|
if key not in do_order:
|
|
do_order.append(key)
|
|
|
|
Index: virt-manager-1.5.0/virtinst/domcapabilities.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/domcapabilities.py
|
|
+++ virt-manager-1.5.0/virtinst/domcapabilities.py
|
|
@@ -139,7 +139,7 @@ class DomainCapabilities(XMLBuilder):
|
|
return _("BIOS")
|
|
return _("None")
|
|
|
|
- for arch, patterns in self._uefi_arch_patterns.items():
|
|
+ for arch, patterns in list(self._uefi_arch_patterns.items()):
|
|
for pattern in patterns:
|
|
if re.match(pattern, path):
|
|
return (_("UEFI %(arch)s: %(path)s") %
|
|
@@ -151,7 +151,7 @@ class DomainCapabilities(XMLBuilder):
|
|
"""
|
|
Return True if we know how to setup UEFI for the passed arch
|
|
"""
|
|
- return self.arch in self._uefi_arch_patterns.keys()
|
|
+ return self.arch in list(self._uefi_arch_patterns.keys())
|
|
|
|
def supports_uefi_xml(self):
|
|
"""
|
|
Index: virt-manager-1.5.0/virtinst/devicedisk.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/devicedisk.py
|
|
+++ virt-manager-1.5.0/virtinst/devicedisk.py
|
|
@@ -87,7 +87,7 @@ def _is_dir_searchable(uid, username, pa
|
|
logging.debug("Cmd '%s' failed: %s", cmd, err)
|
|
return False
|
|
|
|
- return bool(re.search("user:%s:..x" % username, out))
|
|
+ return bool(re.search("user:%s:..x" % username, out.decode()))
|
|
|
|
|
|
class _Host(XMLBuilder):
|
|
@@ -453,7 +453,7 @@ class VirtualDisk(VirtualDevice):
|
|
digit = 1
|
|
|
|
seen_valid = True
|
|
- gen_t += "%c" % (ord('a') + digit - 1)
|
|
+ gen_t += "%c" % int(ord('a') + digit - 1)
|
|
|
|
return gen_t
|
|
|
|
@@ -1054,11 +1054,11 @@ class VirtualDisk(VirtualDevice):
|
|
def get_target():
|
|
first_found = None
|
|
|
|
- ran = range(maxnode)
|
|
+ ran = list(range(maxnode))
|
|
if pref_ctrl is not None:
|
|
# We assume narrow SCSI bus and libvirt assigning 7
|
|
# (1-7, 8-14, etc.) devices per controller
|
|
- ran = range(pref_ctrl * 7, (pref_ctrl + 1) * 7)
|
|
+ ran = list(range(pref_ctrl * 7, (pref_ctrl + 1) * 7))
|
|
|
|
for i in ran:
|
|
postfix = self.num_to_target(i + 1)
|
|
Index: virt-manager-1.5.0/virtinst/storage.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/storage.py
|
|
+++ virt-manager-1.5.0/virtinst/storage.py
|
|
@@ -130,7 +130,7 @@ class StoragePool(_StorageObject):
|
|
"""
|
|
Return list of appropriate pool types
|
|
"""
|
|
- return StoragePool._descs.keys()
|
|
+ return list(StoragePool._descs.keys())
|
|
|
|
@staticmethod
|
|
def get_pool_type_desc(pool_type):
|
|
Index: virt-manager-1.5.0/virtinst/devicegraphics.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/devicegraphics.py
|
|
+++ virt-manager-1.5.0/virtinst/devicegraphics.py
|
|
@@ -84,7 +84,7 @@ class VirtualGraphics(VirtualDevice):
|
|
"""
|
|
from . import hostkeymap
|
|
|
|
- orig_list = hostkeymap.keytable.values()
|
|
+ orig_list = list(hostkeymap.keytable.values())
|
|
sort_list = []
|
|
|
|
orig_list.sort()
|
|
Index: virt-manager-1.5.0/virtinst/util.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/util.py
|
|
+++ virt-manager-1.5.0/virtinst/util.py
|
|
@@ -147,7 +147,7 @@ def generate_name(base, collision_cb, su
|
|
else:
|
|
return collision_cb(tryname)
|
|
|
|
- numrange = range(start_num, start_num + 100000)
|
|
+ numrange = list(range(start_num, start_num + 100000))
|
|
if not force_num:
|
|
numrange = [None] + numrange
|
|
|
|
Index: virt-manager-1.5.0/virtinst/urlfetcher.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/urlfetcher.py
|
|
+++ virt-manager-1.5.0/virtinst/urlfetcher.py
|
|
@@ -19,7 +19,7 @@
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
# MA 02110-1301 USA.
|
|
|
|
-import ConfigParser
|
|
+import configparser
|
|
import ftplib
|
|
import io
|
|
import logging
|
|
@@ -27,8 +27,8 @@ import os
|
|
import re
|
|
import subprocess
|
|
import tempfile
|
|
-import urllib2
|
|
-import urlparse
|
|
+import urllib.request, urllib.error, urllib.parse
|
|
+import urllib.parse
|
|
|
|
import requests
|
|
|
|
@@ -220,9 +220,13 @@ class _FTPURLFetcher(_URLFetcher):
|
|
return
|
|
|
|
try:
|
|
- parsed = urlparse.urlparse(self.location)
|
|
+ parsed = urllib.parse.urlparse(self.location)
|
|
self._ftp = ftplib.FTP()
|
|
- self._ftp.connect(parsed.hostname, parsed.port)
|
|
+ if parsed.port is None:
|
|
+ port = 0
|
|
+ else:
|
|
+ port = parsed.port
|
|
+ self._ftp.connect(parsed.hostname, port)
|
|
self._ftp.login()
|
|
# Force binary mode
|
|
self._ftp.voidcmd("TYPE I")
|
|
@@ -234,9 +238,9 @@ class _FTPURLFetcher(_URLFetcher):
|
|
"""
|
|
Use urllib2 and ftplib to grab the file
|
|
"""
|
|
- request = urllib2.Request(url)
|
|
- urlobj = urllib2.urlopen(request)
|
|
- size = self._ftp.size(urlparse.urlparse(url)[2])
|
|
+ request = urllib.request.Request(url)
|
|
+ urlobj = urllib.request.urlopen(request)
|
|
+ size = self._ftp.size(urllib.parse.urlparse(url)[2])
|
|
return urlobj, size
|
|
|
|
|
|
@@ -252,7 +256,7 @@ class _FTPURLFetcher(_URLFetcher):
|
|
self._ftp = None
|
|
|
|
def _hasFile(self, url):
|
|
- path = urlparse.urlparse(url)[2]
|
|
+ path = urllib.parse.urlparse(url)[2]
|
|
|
|
try:
|
|
try:
|
|
@@ -277,7 +281,7 @@ class _LocalURLFetcher(_URLFetcher):
|
|
return os.path.exists(url)
|
|
|
|
def _grabber(self, url):
|
|
- urlobj = open(url, "r")
|
|
+ urlobj = open(url, "rb")
|
|
size = os.path.getsize(url)
|
|
return urlobj, size
|
|
|
|
@@ -395,14 +399,14 @@ def _grabTreeinfo(fetcher):
|
|
return None
|
|
|
|
try:
|
|
- treeinfo = ConfigParser.SafeConfigParser()
|
|
+ treeinfo = configparser.SafeConfigParser()
|
|
treeinfo.read(tmptreeinfo)
|
|
finally:
|
|
os.unlink(tmptreeinfo)
|
|
|
|
try:
|
|
treeinfo.get("general", "family")
|
|
- except ConfigParser.NoSectionError:
|
|
+ except configparser.NoSectionError:
|
|
logging.debug("Did not find 'family' section in treeinfo")
|
|
return None
|
|
|
|
@@ -415,11 +419,13 @@ def _distroFromSUSEContent(fetcher, arch
|
|
# None if no content, GenericDistro if unknown label type.
|
|
try:
|
|
cbuf = fetcher.acquireFileContent("content")
|
|
+ cbuf = cbuf.decode()
|
|
except ValueError:
|
|
try:
|
|
# If no content file, try media.1/products and media.1/build and create
|
|
# a cbuf with enough info for the content file parsing code below to work
|
|
pbuf = fetcher.acquireFileContent("media.1/products").strip()
|
|
+ pbuf = pbuf.decode()
|
|
pbuf = pbuf.split(' ', 1)[1].strip()
|
|
# The media.1/products file naming convention changed between SLE11 and SLE12
|
|
if pbuf.startswith('SLE'):
|
|
@@ -428,6 +434,7 @@ def _distroFromSUSEContent(fetcher, arch
|
|
cbuf = "\nDISTRO ," + pbuf.replace('-', ' ')
|
|
try:
|
|
bbuf = fetcher.acquireFileContent("media.1/build").split('-')
|
|
+ bbuf = bbuf.decode()
|
|
except:
|
|
bbuf = ["x86_64"]
|
|
cbuf = cbuf + "\n" + " ".join(bbuf)
|
|
@@ -645,7 +652,7 @@ class Distro(object):
|
|
try:
|
|
kernelpath = self._getTreeinfoMedia("kernel")
|
|
initrdpath = self._getTreeinfoMedia("initrd")
|
|
- except ConfigParser.NoSectionError:
|
|
+ except configparser.NoSectionError:
|
|
pass
|
|
|
|
if not kernelpath or not initrdpath:
|
|
@@ -712,6 +719,7 @@ class Distro(object):
|
|
# Fetch 'filename' and return True/False if it matches the regex
|
|
try:
|
|
content = self.fetcher.acquireFileContent(filename)
|
|
+ content = content.decode()
|
|
except ValueError:
|
|
return False
|
|
|
|
@@ -781,15 +789,15 @@ class GenericDistro(Distro):
|
|
self._valid_kernel_path = (
|
|
self._getTreeinfoMedia("kernel"),
|
|
self._getTreeinfoMedia("initrd"))
|
|
- except (ConfigParser.NoSectionError,
|
|
- ConfigParser.NoOptionError) as e:
|
|
+ except (configparser.NoSectionError,
|
|
+ configparser.NoOptionError) as e:
|
|
logging.debug(e)
|
|
|
|
if self.treeinfo.has_section(isoSection):
|
|
try:
|
|
self._valid_iso_path = self.treeinfo.get(isoSection,
|
|
"boot.iso")
|
|
- except ConfigParser.NoOptionError as e:
|
|
+ except configparser.NoOptionError as e:
|
|
logging.debug(e)
|
|
|
|
if self.type == "xen":
|
|
@@ -1472,7 +1480,7 @@ class ALTLinuxDistro(Distro):
|
|
# Build list of all *Distro classes
|
|
def _build_distro_list():
|
|
allstores = []
|
|
- for obj in globals().values():
|
|
+ for obj in list(globals().values()):
|
|
if isinstance(obj, type) and issubclass(obj, Distro) and obj.name:
|
|
allstores.append(obj)
|
|
|
|
Index: virt-manager-1.5.0/virtinst/diskbackend.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/diskbackend.py
|
|
+++ virt-manager-1.5.0/virtinst/diskbackend.py
|
|
@@ -391,7 +391,7 @@ class CloneStorageCreator(_StorageCreato
|
|
else:
|
|
vfs = os.statvfs(os.path.dirname(self._path))
|
|
avail = vfs.f_frsize * vfs.f_bavail
|
|
- need = long(self._size * 1024 * 1024 * 1024)
|
|
+ need = int(self._size * 1024 * 1024 * 1024)
|
|
if need > avail:
|
|
if self._sparse:
|
|
msg = _("The filesystem will not have enough free space"
|
|
@@ -411,7 +411,7 @@ class CloneStorageCreator(_StorageCreato
|
|
text = (_("Cloning %(srcfile)s") %
|
|
{'srcfile': os.path.basename(self._input_path)})
|
|
|
|
- size_bytes = long(self.get_size() * 1024 * 1024 * 1024)
|
|
+ size_bytes = int(self.get_size() * 1024 * 1024 * 1024)
|
|
progresscb.start(filename=self._output_path, size=size_bytes,
|
|
text=text)
|
|
|
|
Index: virt-manager-1.5.0/virtinst/progress.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/progress.py
|
|
+++ virt-manager-1.5.0/virtinst/progress.py
|
|
@@ -481,7 +481,7 @@ def format_number(number, SI=0, space='
|
|
depth = depth + 1
|
|
number = number / step
|
|
|
|
- if isinstance(number, int) or isinstance(number, long):
|
|
+ if isinstance(number, int) or isinstance(number, int):
|
|
# it's an int or a long, which means it didn't get divided,
|
|
# which means it's already short enough
|
|
fmt = '%i%s%s'
|
|
Index: virt-manager-1.5.0/virtinst/pollhelpers.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtinst/pollhelpers.py
|
|
+++ virt-manager-1.5.0/virtinst/pollhelpers.py
|
|
@@ -50,7 +50,7 @@ def _new_poll_helper(origmap, typename,
|
|
current[connkey] = origmap[connkey]
|
|
del(origmap[connkey])
|
|
|
|
- return (origmap.values(), new.values(), current.values())
|
|
+ return (list(origmap.values()), list(new.values()), list(current.values()))
|
|
|
|
|
|
def _old_poll_helper(origmap, typename,
|
|
@@ -108,7 +108,7 @@ def _old_poll_helper(origmap, typename,
|
|
except Exception:
|
|
logging.exception("Couldn't fetch %s '%s'", typename, name)
|
|
|
|
- return (origmap.values(), new.values(), current.values())
|
|
+ return (list(origmap.values()), list(new.values()), list(current.values()))
|
|
|
|
|
|
def fetch_nets(backend, origmap, build_func):
|
|
@@ -143,7 +143,7 @@ def fetch_pools(backend, origmap, build_
|
|
for obj in objs:
|
|
try:
|
|
obj.refresh(0)
|
|
- except Exception, e:
|
|
+ except Exception as e:
|
|
pass
|
|
|
|
return _new_poll_helper(origmap, name,
|
|
@@ -222,7 +222,7 @@ def _old_fetch_vms(backend, origmap, bui
|
|
new = {}
|
|
|
|
# Build list of previous vms with proper id/name mappings
|
|
- for vm in origmap.values():
|
|
+ for vm in list(origmap.values()):
|
|
if vm.is_active():
|
|
oldActiveIDs[vm.get_id()] = vm
|
|
else:
|
|
@@ -285,7 +285,7 @@ def _old_fetch_vms(backend, origmap, bui
|
|
except Exception:
|
|
logging.exception("Couldn't fetch domain '%s'", name)
|
|
|
|
- return (origmap.values(), new.values(), current.values())
|
|
+ return (list(origmap.values()), list(new.values()), list(current.values()))
|
|
|
|
|
|
def fetch_vms(backend, origmap, build_func):
|