diff --git a/0002-virtinst-python3-avoid-comparison-of-None-and-int.patch b/0002-virtinst-python3-avoid-comparison-of-None-and-int.patch index 6b380583..55b6b1aa 100644 --- a/0002-virtinst-python3-avoid-comparison-of-None-and-int.patch +++ b/0002-virtinst-python3-avoid-comparison-of-None-and-int.patch @@ -14,11 +14,11 @@ TypeError: '>' not supported between instances of 'NoneType' and 'int' virtinst/progress.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) -diff --git a/virtinst/progress.py b/virtinst/progress.py -index e07591a14fa0..eef3f7613506 100644 ---- a/virtinst/progress.py -+++ b/virtinst/progress.py -@@ -339,7 +339,7 @@ class RateEstimator: +Index: virt-manager-2.0.0/virtinst/progress.py +=================================================================== +--- virt-manager-2.0.0.orig/virtinst/progress.py ++++ virt-manager-2.0.0/virtinst/progress.py +@@ -321,7 +321,7 @@ class RateEstimator: self.start_time = now self.last_update_time = now self.last_amount_read = 0 @@ -27,7 +27,7 @@ index e07591a14fa0..eef3f7613506 100644 def update(self, amount_read, now=None): if now is None: now = time.time() -@@ -351,7 +351,7 @@ class RateEstimator: +@@ -333,7 +333,7 @@ class RateEstimator: # if we just started this file, all bets are off self.last_update_time = now self.last_amount_read = amount_read @@ -36,6 +36,3 @@ index e07591a14fa0..eef3f7613506 100644 return #print 'times', now, self.last_update_time --- -2.15.1 - diff --git a/0003-virtinst-python3-avoid-using-long-type.patch b/0003-virtinst-python3-avoid-using-long-type.patch index 3fb5576c..aaebb3c9 100644 --- a/0003-virtinst-python3-avoid-using-long-type.patch +++ b/0003-virtinst-python3-avoid-using-long-type.patch @@ -12,27 +12,24 @@ Avoids the following error: virtinst/progress.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) -diff --git a/virtinst/progress.py b/virtinst/progress.py -index eef3f7613506..bea4fad98938 100644 ---- a/virtinst/progress.py -+++ b/virtinst/progress.py -@@ -30,6 +30,7 @@ import math +Index: virt-manager-2.0.0/virtinst/progress.py +=================================================================== +--- virt-manager-2.0.0.orig/virtinst/progress.py ++++ virt-manager-2.0.0/virtinst/progress.py +@@ -16,6 +16,7 @@ import math import fcntl import struct import termios +from six import integer_types - # Code from http://mail.python.org/pipermail/python-list/2000-May/033365.html + # Code from https://mail.python.org/pipermail/python-list/2000-May/033365.html def terminal_width(fd=1): -@@ -481,7 +482,7 @@ def format_number(number, SI=0, space=' '): +@@ -464,7 +465,7 @@ def format_number(number, SI=0, space=' depth = depth + 1 number = number / step -- if isinstance(number, int) or isinstance(number, int): +- if isinstance(number, int): + if isinstance(number, integer_types): # 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' --- -2.15.1 - diff --git a/0004-virtinst-python3-use-binary-mode-for-kernel.patch b/0004-virtinst-python3-use-binary-mode-for-kernel.patch deleted file mode 100644 index ddff3b0c..00000000 --- a/0004-virtinst-python3-use-binary-mode-for-kernel.patch +++ /dev/null @@ -1,34 +0,0 @@ -From 1e38d32429205ed8fbd088bcfe2dfea4229544b6 Mon Sep 17 00:00:00 2001 -From: Martin Wilck -Date: Thu, 7 Dec 2017 12:42:45 +0100 -Subject: [PATCH 4/4] virtinst: python3: use binary mode for kernel - -This avoids the following error: - - File "/usr/share/virt-manager/virtinst/kernelupload.py", line 146, in upload_kernel_initrd - kvol = _upload_file(conn, meter, pool, kernel) - File "/usr/share/virt-manager/virtinst/kernelupload.py", line 105, in _upload_file - data = fileobj.read(blocksize) - File "/usr/lib64/python3.6/codecs.py", line 321, in decode - (result, consumed) = self._buffer_decode(data, self.errors, final) -UnicodeDecodeError: 'utf-8' codec can't decode byte 0xea in position 2: invalid continuation byte ---- - virtinst/kernelupload.py | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/virtinst/kernelupload.py b/virtinst/kernelupload.py -index 80bb9c6d1143..5caeb51c4100 100644 ---- a/virtinst/kernelupload.py -+++ b/virtinst/kernelupload.py -@@ -93,7 +93,7 @@ def _upload_file(conn, meter, destpool, src): - vol.upload(stream, offset, length, flags) - - # Open source file -- fileobj = open(src, "r") -+ fileobj = open(src, "rb") - - # Start transfer - total = 0 --- -2.15.1 - diff --git a/27d4b167-virtinst-update-location-for-opensuse.patch b/27d4b167-virtinst-update-location-for-opensuse.patch deleted file mode 100644 index 33f3ec6c..00000000 --- a/27d4b167-virtinst-update-location-for-opensuse.patch +++ /dev/null @@ -1,21 +0,0 @@ -Subject: Update --location for OpenSUSE -From: Nicolas Bock nicolas.bock@suse.com Tue Mar 6 15:54:23 2018 -0700 -Date: Wed Mar 7 09:27:38 2018 +0100: -Git: 27d4b167d5572ade0246cf9340abae88ad5097eb - -OpenSUSE is currently at Leap 42.3. This change updates the man page -for virt-install to point to the current repository. - -diff --git a/man/virt-install.pod b/man/virt-install.pod -index 00f8d125..712386fc 100644 ---- a/man/virt-install.pod -+++ b/man/virt-install.pod -@@ -429,7 +429,7 @@ http://us.archive.ubuntu.com/ubuntu/dists/wily/main/installer-amd64/ - - =item Suse - --http://download.opensuse.org/distribution/11.0/repo/oss/ -+http://download.opensuse.org/pub/opensuse/distribution/leap/42.3/repo/oss/ - - =item Mandriva - diff --git a/5a7698c7-fix-select-network-vol.patch b/5a7698c7-fix-select-network-vol.patch deleted file mode 100644 index 8fad1361..00000000 --- a/5a7698c7-fix-select-network-vol.patch +++ /dev/null @@ -1,65 +0,0 @@ -commit 5a7698c7998d673e0742046478630824162966b4 -Author: Jim Fehlig -Date: Tue Oct 9 14:30:09 2018 -0600 - - Fix selection of network volumes - - When creating a new VM and selecting a volume from a network-based - storage pool such as rbd, the volume is not recognized as network-based - and is treated as a volume from a directory storage pool. - - This patch adds a method to check if the volume's path points to a - network-based volume, then uses the method to avoid actions like - setting unix file permissions on the volume, which doesn't make - sense for a network-based volume. - - Signed-off-by: Jim Fehlig - - (crobinso: rebase, tweak lookup logic) - -Index: virt-manager-1.5.1/virtinst/diskbackend.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/diskbackend.py -+++ virt-manager-1.5.1/virtinst/diskbackend.py -@@ -156,7 +156,7 @@ def manage_path(conn, path): - if not path: - return None, None - -- if not path_is_url(path): -+ if not path_is_url(path) and not path_is_network_vol(conn, path): - path = os.path.abspath(path) - vol, pool = check_if_path_managed(conn, path) - if vol or pool or not _can_auto_manage(path): -@@ -188,6 +188,19 @@ def path_is_url(path): - return bool(re.match("[a-zA-Z]+(\+[a-zA-Z]+)?://.*", path)) - - -+def path_is_network_vol(conn, path): -+ """ -+ Detect if path is a network volume such as rbd, gluster, etc -+ """ -+ if not path: -+ return False -+ -+ for volxml in conn.fetch_all_vols(): -+ if volxml.target_path == path: -+ return volxml.type == "network" -+ return False -+ -+ - def _get_dev_type(path, vol_xml, vol_object, pool_xml, remote): - """ - Try to get device type for volume. -Index: virt-manager-1.5.1/virtinst/devicedisk.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/devicedisk.py -+++ virt-manager-1.5.1/virtinst/devicedisk.py -@@ -216,6 +216,8 @@ class VirtualDisk(VirtualDevice): - return [] - if diskbackend.path_is_url(path): - return [] -+ if diskbackend.path_is_network_vol(conn, path): -+ return [] - - try: - # Get UID for string name diff --git a/d15b78ab-virtinst-read-CPU-model-from-domain-capabilities.patch b/d15b78ab-virtinst-read-CPU-model-from-domain-capabilities.patch deleted file mode 100644 index f6e631f9..00000000 --- a/d15b78ab-virtinst-read-CPU-model-from-domain-capabilities.patch +++ /dev/null @@ -1,193 +0,0 @@ -Subject: virtinst: read CPU model from domain capabilities -From: Charles Arnold carnold@suse.com Wed Mar 28 13:45:29 2018 -0600 -Date: Tue Apr 3 10:57:15 2018 -0400: -Git: d15b78ab0d7b9e73261a19fafc841a4ee206d413 - -Add functionality to acquire the CPU model from the -libvirt domain capabilities. This is used to compare -with the host CPU model. - -(crobinso: add test coverage, rework domcaps layout a bit) - -Index: virt-manager-1.5.0/tests/capabilities-xml/kvm-x86_64-domcaps.xml -=================================================================== ---- virt-manager-1.5.0.orig/tests/capabilities-xml/kvm-x86_64-domcaps.xml -+++ virt-manager-1.5.0/tests/capabilities-xml/kvm-x86_64-domcaps.xml -@@ -18,6 +18,68 @@ - - - -+ -+ -+ -+ Broadwell -+ Intel -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ qemu64 -+ qemu32 -+ phenom -+ pentium3 -+ pentium2 -+ pentium -+ n270 -+ kvm64 -+ kvm32 -+ coreduo -+ core2duo -+ athlon -+ Westmere -+ Westmere-IBRS -+ Skylake-Server -+ Skylake-Server-IBRS -+ Skylake-Client -+ Skylake-Client-IBRS -+ SandyBridge -+ SandyBridge-IBRS -+ Penryn -+ Opteron_G5 -+ Opteron_G4 -+ Opteron_G3 -+ Opteron_G2 -+ Opteron_G1 -+ Nehalem -+ Nehalem-IBRS -+ IvyBridge -+ IvyBridge-IBRS -+ Haswell -+ Haswell-noTSX -+ Haswell-noTSX-IBRS -+ Haswell-IBRS -+ EPYC -+ EPYC-IBPB -+ Conroe -+ Broadwell -+ Broadwell-noTSX -+ Broadwell-noTSX-IBRS -+ Broadwell-IBRS -+ 486 -+ -+ - - - -@@ -32,8 +94,25 @@ - scsi - virtio - usb -+ sata - - -+ -+ -+ sdl -+ vnc -+ spice -+ -+ -+ - - - subsystem -@@ -50,11 +129,10 @@ - scsi - - -- -- default -- kvm -- vfio -- -+ - - -+ -+ -+ - -Index: virt-manager-1.5.0/tests/capabilities.py -=================================================================== ---- virt-manager-1.5.0.orig/tests/capabilities.py -+++ virt-manager-1.5.0/tests/capabilities.py -@@ -131,6 +131,16 @@ class TestCapabilities(unittest.TestCase - self.assertEqual(caps.os.loader.get_enum("type").get_values(), - ["rom", "pflash"]) - -+ def testDomainCapabilitiesx86(self): -+ xml = open("tests/capabilities-xml/kvm-x86_64-domcaps.xml").read() -+ caps = DomainCapabilities(utils.URIs.open_testdriver_cached(), xml) -+ -+ custom_mode = caps.cpu.get_mode("custom") -+ self.assertTrue(bool(custom_mode)) -+ cpu_model = custom_mode.get_model("Opteron_G4") -+ self.assertTrue(bool(cpu_model)) -+ self.assertTrue(cpu_model.usable) -+ - - if __name__ == "__main__": - unittest.main() -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 -@@ -76,6 +76,33 @@ class _Features(_CapsBlock): - gic = XMLChildProperty(_make_capsblock("gic"), is_single=True) - - -+ -+class _CPUModel(XMLBuilder): -+ _XML_ROOT_NAME = "model" -+ model = XMLProperty(".") -+ usable = XMLProperty("./@usable", is_yesno=True) -+ -+ -+class _CPUMode(XMLBuilder): -+ _XML_ROOT_NAME = "mode" -+ name = XMLProperty("./@name") -+ models = XMLChildProperty(_CPUModel) -+ -+ def get_model(self, name): -+ for model in self.models: -+ if model.model == name: -+ return model -+ -+class _CPU(XMLBuilder): -+ _XML_ROOT_NAME = "cpu" -+ modes = XMLChildProperty(_CPUMode) -+ -+ def get_mode(self, name): -+ for mode in self.modes: -+ if mode.name == name: -+ return mode -+ -+ - class DomainCapabilities(XMLBuilder): - @staticmethod - def build_from_params(conn, emulator, arch, machine, hvtype): -@@ -163,6 +190,7 @@ class DomainCapabilities(XMLBuilder): - - _XML_ROOT_NAME = "domainCapabilities" - os = XMLChildProperty(_OS, is_single=True) -+ cpu = XMLChildProperty(_CPU, is_single=True) - devices = XMLChildProperty(_Devices, is_single=True) - - arch = XMLProperty("./arch") diff --git a/fd6a8154-virtinst-compare-host-and-domain-cpu-models.patch b/fd6a8154-virtinst-compare-host-and-domain-cpu-models.patch deleted file mode 100644 index 7c54ba93..00000000 --- a/fd6a8154-virtinst-compare-host-and-domain-cpu-models.patch +++ /dev/null @@ -1,81 +0,0 @@ -Subject: virtinst: compare host and domain cpu models -From: Charles Arnold carnold@suse.com Wed Mar 28 13:45:30 2018 -0600 -Date: Tue Apr 3 10:57:49 2018 -0400: -Git: fd6a8154408fb462e5437dc920afe4d80da3c1f8 - -Lookup the domain capabilities CPU model and compare with -the host capabilities CPU model and if they are not equal -set the guest's CPU model to None. - -(crobinso: compare against 'custom' list not 'host-model', move - to separate function) - -Index: virt-manager-1.5.0/tests/cli-test-xml/compare/virt-install-boot-uefi.xml -=================================================================== ---- virt-manager-1.5.0.orig/tests/cli-test-xml/compare/virt-install-boot-uefi.xml -+++ virt-manager-1.5.0/tests/cli-test-xml/compare/virt-install-boot-uefi.xml -@@ -15,9 +15,7 @@ - - - -- -- Opteron_G4 -- -+ - - - -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 -@@ -880,6 +880,33 @@ class Guest(XMLBuilder): - else: - self.emulator = "/usr/lib/xen/bin/qemu-dm" - -+ def _set_cpu_x86_kvm_default(self): -+ if self.os.arch != self.conn.caps.host.cpu.arch: -+ return -+ -+ self.cpu.set_special_mode(self.x86_cpu_default) -+ if self.x86_cpu_default != self.cpu.SPECIAL_MODE_HOST_MODEL_ONLY: -+ return -+ if not self.cpu.model: -+ return -+ -+ # It's possible that the value HOST_MODEL_ONLY gets from -+ # is not actually supported by qemu/kvm -+ # combo which will be reported in -+ domcaps = DomainCapabilities.build_from_guest(self) -+ domcaps_mode = domcaps.cpu.get_mode("custom") -+ if not domcaps_mode: -+ return -+ -+ cpu_model = domcaps_mode.get_model(self.cpu.model) -+ if cpu_model and cpu_model.usable: -+ return -+ -+ logging.debug("Host capabilities CPU '%s' is not supported " -+ "according to domain capabilities. Unsetting CPU model", -+ self.cpu.model) -+ self.cpu.model = None -+ - def _set_cpu_defaults(self): - self.cpu.set_topology_defaults(self.vcpus) - -@@ -898,14 +925,11 @@ class Guest(XMLBuilder): - self.cpu.model = "cortex-a57" - - elif self.os.is_x86() and self.type == "kvm": -- if self.os.arch != self.conn.caps.host.cpu.arch: -- return -+ self._set_cpu_x86_kvm_default() - -- self.cpu.set_special_mode(self.x86_cpu_default) - if self._os_object.broken_x2apic(): - self.cpu.add_feature("x2apic", policy="disable") - -- - def _hyperv_supported(self): - if (self.os.loader_type == "pflash" and - self.os_variant in ("win2k8r2", "win7")): diff --git a/virt-manager-1.5.1.tar.bz2 b/virt-manager-1.5.1.tar.bz2 deleted file mode 100644 index 55697feb..00000000 --- a/virt-manager-1.5.1.tar.bz2 +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:df7d2519d54e77b98d5d96b2b012311dae10eaf2c19e2c8019dbbb36f66e7d46 -size 1548321 diff --git a/virt-manager-2.0.0.tar.bz2 b/virt-manager-2.0.0.tar.bz2 new file mode 100644 index 00000000..f9ce2628 --- /dev/null +++ b/virt-manager-2.0.0.tar.bz2 @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:097aaf409c9d4d7a325deb34de40b6dd570c2671cb3d5720ed7183995b46aa8c +size 1484896 diff --git a/virt-manager.changes b/virt-manager.changes index 0752c1f9..b0193106 100644 --- a/virt-manager.changes +++ b/virt-manager.changes @@ -1,8 +1,52 @@ ------------------------------------------------------------------- -Mon Oct 22 11:33:51 UTC 2018 - Guillaume GARDET +Tue Oct 30 15:37:09 MDT 2018 - carnold@suse.com -- boo#1112729 - Add missing python3-six dep introduced by patch - 0003-virtinst-python3-avoid-using-long-type.patch +- Update to virt-manager 2.0.0 (bsc#1027942) + virt-manager-2.0.0.tar.bz2 + * Finish port to Python 3 (Radostin Stoyanov, Cole Robinson) + * Improved VM defaults for supported OS: q35 PCIe, usb3, CPU host-model + * Search based OS selection UI for new VMs (Daniel P. Berrangé, Cole Robinson) + * Track OS name for lifetime of domain in XML + * Host interface management UI has been completely removed + * Show domain IP on interface details page (Lin Ma, Cole Robinson) + * More efficient stats polling with AllDomainStats (Simon Kobyda, Cole Robinson) + * TPM device model and backend UI (Marc-André Lureau, Stefan Berger) + * Show connection state in UI (Lin Ma) + * Show attached devices in UI (Lin Ma) + * UI option to plug/unplug VM nic link (Simon Kobyda) + * UI support for disk discard and detect_zeroes (Povilas Kanapickas, Lin Ma) + * Improved SUSE –location URL/ISO detection (Charles Arnold) + * cli and UI support for SCSI persistent reservations (Lin Ma) + * cli: Add –network mtu.size= option (Anya Harter) + * cli: Add –disk driver.copy_on_read (Anya Harter) + * cli: Add –disk geometry support (Anya Harter) + * cli: Add –sound codec support (Anya Harter) + * cli: Add –hostdev net/char/block for LXC (Lubomir Rintel) + * cli: Add –memorybacking access_mode and source_type (Marc-André Lureau) + * cli: Add –boot rebootTimout (Yossi Ovadia) + * cli: Add –boot bootloader= + * cli: Add –destroy-on-exit +- Drop patches contained in new tarball or not required + 0004-virtinst-python3-use-binary-mode-for-kernel.patch + 27d4b167-virtinst-update-location-for-opensuse.patch + 5a7698c7-fix-select-network-vol.patch + d15b78ab-virtinst-read-CPU-model-from-domain-capabilities.patch + fd6a8154-virtinst-compare-host-and-domain-cpu-models.patch + 5a7698c7-fix-select-network-vol.patch + virtcli-python2-to-python3-conversion.patch + virtinst-add-ppc64-arch-support.patch + virtinst-check-date-format.patch + virtinst-fix-sle-distro-parsing.patch + virtinst-handle-tumbleweed-treeinfo-file.patch + virtinst-nfs-install-sanitize.patch + virtinst-no-usb-tablet-for-xenpv.patch + virtinst-set-qemu-emulator.patch + virtinst-storage-ocfs2.patch + virtman-add-connect-default.patch + virtman-fix-missing-translations.patch + virtman-libvirtd-not-running.patch + virtman-packages.patch + virtmisc-python2-to-python3-conversion.patch ------------------------------------------------------------------- Tue Oct 16 02:24:29 UTC 2018 - James Fehlig diff --git a/virt-manager.spec b/virt-manager.spec index 3d55c0d5..57f0685d 100644 --- a/virt-manager.spec +++ b/virt-manager.spec @@ -12,22 +12,16 @@ # license that conforms to the Open Source Definition (Version 1.9) # published by the Open Source Initiative. -# Please submit bugfixes or comments via https://bugs.opensuse.org/ +# Please submit bugfixes or comments via http://bugs.opensuse.org/ # -%define with_guestfs 0 -%define askpass_package "openssh-askpass" -%define qemu_user "qemu" -%define libvirt_kvm_packages "" -%define libvirt_xen_packages "" -%define preferred_distros "sles15,opensuse15" -%define kvm_packages "" -%define _version 1.5.1 -%define _release 0 +%global __python %{__python3} +%global with_guestfs 0 +%global default_hvs "qemu,xen,lxc" Name: virt-manager -Version: 1.5.1 +Version: 2.0.0 Release: 0 Summary: Virtual Machine Manager License: GPL-2.0-or-later @@ -38,35 +32,25 @@ Source1: virt-install.rb Source2: virt-install.desktop Source3: virt-manager-supportconfig # Upstream Patches -Patch1: 27d4b167-virtinst-update-location-for-opensuse.patch -Patch2: d15b78ab-virtinst-read-CPU-model-from-domain-capabilities.patch -Patch3: fd6a8154-virtinst-compare-host-and-domain-cpu-models.patch -Patch4: 5a7698c7-fix-select-network-vol.patch # SUSE Only Patch70: virtman-desktop.patch Patch71: virtman-kvm.patch Patch72: virtman-keycombo.patch Patch73: virtman-show-suse-install-repos.patch -Patch74: virtman-libvirtd-not-running.patch -Patch75: virtman-dont-allow-grub.xen-to-be-deleted.patch -Patch76: virtinst-pvgrub2-bootloader.patch -Patch77: virtinst-nfs-install-sanitize.patch +Patch74: virtman-dont-allow-grub.xen-to-be-deleted.patch +Patch75: virtinst-pvgrub2-bootloader.patch # Features or Enhancements Patch101: virtman-default-guest-from-host-os.patch Patch102: virtman-default-to-xen-pv.patch -Patch103: virtman-packages.patch -Patch104: virtman-load-stored-uris.patch -Patch105: virtman-add-connect-default.patch -Patch120: virtinst-storage-ocfs2.patch -Patch121: virtinst-default-xen-to-qcow2-format.patch -Patch122: virtinst-detect-oes-distros.patch -Patch123: virtinst-modify-gui-defaults.patch -Patch124: virtinst-vol-default-nocow.patch -Patch125: virtinst-set-cache-mode-unsafe-for-install.patch -Patch126: virtinst-set-qemu-emulator.patch -Patch127: virtinst-add-ppc64-arch-support.patch -Patch128: virtinst-s390x-disable-graphics.patch -Patch129: virtinst-add-caasp-support.patch +Patch103: virtman-load-stored-uris.patch +Patch120: virtinst-default-xen-to-qcow2-format.patch +Patch121: virtinst-detect-oes-distros.patch +Patch122: virtinst-modify-gui-defaults.patch +Patch123: virtinst-vol-default-nocow.patch +Patch124: virtinst-set-cache-mode-unsafe-for-install.patch +Patch125: virtinst-s390x-disable-graphics.patch +Patch126: virtinst-add-caasp-support.patch +Patch127: virtinst-add-sle15-detection-support.patch # Bug Fixes Patch150: virtman-prevent-double-click-starting-vm-twice.patch Patch151: virtman-increase-setKeepAlive-count.patch @@ -74,32 +58,23 @@ Patch152: virtman-allow-destroy-from-shutdown-menu-of-crashed-vm.patch Patch153: virtman-check-for-valid-display.patch Patch154: virtman-allow-creating-i686-vm.patch Patch155: virtman-dont-specify-vte-version.patch -Patch156: virtman-fix-missing-translations.patch Patch160: virtinst-xen-drive-type.patch Patch161: virtinst-xenbus-disk-index-fix.patch Patch162: virtinst-refresh_before_fetch_pool.patch Patch163: virtinst-use-xenpae-kernel-for-32bit.patch Patch164: virtinst-use-qemu-for-cdrom-device.patch -Patch165: virtinst-fix-sle-distro-parsing.patch -Patch166: virtinst-check-date-format.patch -Patch167: virtinst-no-usb-tablet-for-xenpv.patch -Patch168: virtinst-add-sle15-detection-support.patch -Patch169: virtinst-keep-install-iso-attached.patch -Patch170: virtinst-osdict-get_supported.patch -Patch171: virtinst-dont-use-special-copy-cpu-features.patch -Patch172: virtinst-use-latest-opensuse-version-when-unknown-media.patch -Patch173: virtinst-handle-tumbleweed-treeinfo-file.patch +Patch165: virtinst-keep-install-iso-attached.patch +Patch166: virtinst-osdict-get_supported.patch +Patch167: virtinst-dont-use-special-copy-cpu-features.patch +Patch168: virtinst-use-latest-opensuse-version-when-unknown-media.patch # Python2 to Python3 patches -Patch200: virtmisc-python2-to-python3-conversion.patch -Patch201: virtcli-python2-to-python3-conversion.patch -Patch202: virtconv-python2-to-python3-conversion.patch -Patch203: virtinst-python2-to-python3-conversion.patch -Patch204: virtman-python2-to-python3-conversion.patch -Patch205: virttests-python2-to-python3-conversion.patch -Patch206: 0002-virtinst-python3-avoid-comparison-of-None-and-int.patch -Patch207: 0003-virtinst-python3-avoid-using-long-type.patch -Patch208: 0004-virtinst-python3-use-binary-mode-for-kernel.patch -Patch209: virtman-register-delete-event-for-details-dialog.patch +Patch200: virtconv-python2-to-python3-conversion.patch +Patch201: virtinst-python2-to-python3-conversion.patch +Patch202: virtman-python2-to-python3-conversion.patch +Patch203: virttests-python2-to-python3-conversion.patch +Patch204: 0002-virtinst-python3-avoid-comparison-of-None-and-int.patch +Patch205: 0003-virtinst-python3-avoid-using-long-type.patch +Patch206: virtman-register-delete-event-for-details-dialog.patch BuildArch: noarch BuildRoot: %{_tmppath}/%{name}-%{version}-build @@ -109,8 +84,6 @@ Requires: dbus-1-x11 Requires: dconf Requires: gtk3 Requires: python3-gobject-Gdk -# Patch 0003-virtinst-python3-avoid-using-long-type.patch adds a python3-six dependency. Drop it when dropping the patch. -Requires: python3-six # For console widget Requires: python3-cairo Requires: python3-gobject-cairo @@ -186,10 +159,6 @@ machine). %prep %setup -q # Upstream Patches -%patch1 -p1 -%patch2 -p1 -%patch3 -p1 -%patch4 -p1 # SUSE Only %patch70 -p1 %patch71 -p1 @@ -197,14 +166,10 @@ machine). %patch73 -p1 %patch74 -p1 %patch75 -p1 -%patch76 -p1 -%patch77 -p1 # Enhancements %patch101 -p1 %patch102 -p1 %patch103 -p1 -%patch104 -p1 -%patch105 -p1 %patch120 -p1 %patch121 -p1 %patch122 -p1 @@ -213,8 +178,6 @@ machine). %patch125 -p1 %patch126 -p1 %patch127 -p1 -%patch128 -p1 -%patch129 -p1 # Bug Fixes %patch150 -p1 %patch151 -p1 @@ -222,7 +185,6 @@ machine). %patch153 -p1 %patch154 -p1 %patch155 -p1 -%patch156 -p1 %patch160 -p1 %patch161 -p1 %patch162 -p1 @@ -232,11 +194,6 @@ machine). %patch166 -p1 %patch167 -p1 %patch168 -p1 -%patch169 -p1 -%patch170 -p1 -%patch171 -p1 -%patch172 -p1 -%patch173 -p1 # Python2 to Python3 patches %patch200 -p1 %patch201 -p1 @@ -245,45 +202,16 @@ machine). %patch204 -p1 %patch205 -p1 %patch206 -p1 -%patch207 -p1 -%patch208 -p1 -%patch209 -p1 %build -%if %{qemu_user} -%define _qemu_user --qemu-user=%{qemu_user} -%endif - -%if %{kvm_packages} -%define _kvm_packages --kvm-package-names=%{kvm_packages} -%endif - -%if %{preferred_distros} -%define _preferred_distros --preferred-distros=%{preferred_distros} -%endif - -%if %{libvirt_kvm_packages} -%define _libvirt_kvm_packages --libvirt-kvm-package-names=%{libvirt_kvm_packages} -%endif - -%if %{libvirt_xen_packages} -%define _libvirt_xen_packages --libvirt-xen-package-names=%{libvirt_xen_packages} -%endif - -%if %{askpass_package} -%define _askpass_package --askpass-package-names=%{askpass_package} +%if %{default_hvs} +%global _default_hvs --default-hvs %{default_hvs} %endif python3 setup.py configure \ --prefix=%{_prefix} \ --default-graphics="spice" \ - %{?_qemu_user} \ - %{?_kvm_packages} \ - %{?_libvirt_kvm_packages} \ - %{?_libvirt_xen_packages} \ - %{?_askpass_package} \ - %{?_preferred_distros} \ - %{?_default_graphics} + %{?_default_hvs} %install python3 setup.py \ @@ -338,7 +266,6 @@ fi %{_datadir}/applications/%{name}.desktop %{_datadir}/applications/YaST2/virt-install.desktop %{_datadir}/glib-2.0/schemas/org.virt-manager.virt-manager.gschema.xml -%{_datadir}/GConf/gsettings/org.virt-manager.virt-manager.convert %dir /usr/lib/supportconfig %dir /usr/lib/supportconfig/plugins /usr/lib/supportconfig/plugins/virt_manager @@ -365,8 +292,6 @@ fi %dir %{_datadir}/YaST2 %dir %{_datadir}/YaST2/clients %dir %{_datadir}/applications/YaST2 -%dir %{_datadir}/GConf -%dir %{_datadir}/GConf/gsettings %dir %{_datadir}/appdata %{_datadir}/YaST2/clients/virt-install.rb diff --git a/virtcli-python2-to-python3-conversion.patch b/virtcli-python2-to-python3-conversion.patch deleted file mode 100644 index 847d8040..00000000 --- a/virtcli-python2-to-python3-conversion.patch +++ /dev/null @@ -1,27 +0,0 @@ -Index: virt-manager-1.4.3/virtcli/cliconfig.py -=================================================================== ---- virt-manager-1.4.3.orig/virtcli/cliconfig.py -+++ virt-manager-1.4.3/virtcli/cliconfig.py -@@ -21,11 +21,11 @@ - Configuration variables that can be set at build time - """ - --import ConfigParser -+import configparser - import os - - --_cfg = ConfigParser.ConfigParser() -+_cfg = configparser.ConfigParser() - _filepath = os.path.abspath(__file__) - _srcdir = os.path.abspath(os.path.join(os.path.dirname(_filepath), "..")) - _cfgpath = os.path.join(os.path.dirname(_filepath), "cli.cfg") -@@ -46,7 +46,7 @@ def _get_param(name, default): - return default - try: - return _cfg.get("config", name) -- except (ConfigParser.NoOptionError, ConfigParser.NoSectionError): -+ except (configparser.NoOptionError, configparser.NoSectionError): - return default - - diff --git a/virtconv-python2-to-python3-conversion.patch b/virtconv-python2-to-python3-conversion.patch index fb4a68a4..733c5a36 100644 --- a/virtconv-python2-to-python3-conversion.patch +++ b/virtconv-python2-to-python3-conversion.patch @@ -1,18 +1,8 @@ -Index: virt-manager-1.4.3/virt-convert +Index: virt-manager-2.0.0/virtconv/vmx.py =================================================================== ---- virt-manager-1.4.3.orig/virt-convert -+++ virt-manager-1.4.3/virt-convert -@@ -1,4 +1,4 @@ --#!/usr/bin/env python2 -+#!/usr/bin/python3 - # - # Copyright 2008, 2013, 2014 Red Hat, Inc. - # Joey Boggs -Index: virt-manager-1.4.3/virtconv/vmx.py -=================================================================== ---- virt-manager-1.4.3.orig/virtconv/vmx.py -+++ virt-manager-1.4.3/virtconv/vmx.py -@@ -271,7 +271,7 @@ class vmx_parser(parser_class): +--- virt-manager-2.0.0.orig/virtconv/vmx.py ++++ virt-manager-2.0.0/virtconv/vmx.py +@@ -259,7 +259,7 @@ class vmx_parser(parser_class): def _find_keys(prefixes): ret = [] @@ -21,29 +11,3 @@ Index: virt-manager-1.4.3/virtconv/vmx.py for p in util.listify(prefixes): if key.startswith(p): ret.append((key, value)) -Index: virt-manager-1.4.3/virtconv/ovf.py -=================================================================== ---- virt-manager-1.4.3.orig/virtconv/ovf.py -+++ virt-manager-1.4.3/virtconv/ovf.py -@@ -90,7 +90,7 @@ def node_list(node): - child = node.children - while child: - child_list.append(child) -- child = child.next -+ child = child.__next__ - return child_list - - -Index: virt-manager-1.4.3/virtconv/formats.py -=================================================================== ---- virt-manager-1.4.3.orig/virtconv/formats.py -+++ virt-manager-1.4.3/virtconv/formats.py -@@ -19,7 +19,7 @@ - # MA 02110-1301 USA. - # - --from __future__ import print_function -+ - - from distutils.spawn import find_executable - import logging diff --git a/virtinst-add-caasp-support.patch b/virtinst-add-caasp-support.patch index c07134e8..a2106569 100644 --- a/virtinst-add-caasp-support.patch +++ b/virtinst-add-caasp-support.patch @@ -1,40 +1,43 @@ References: bsc#1010060 -Index: virt-manager-1.5.1/virtinst/urlfetcher.py +Index: virt-manager-2.0.0/virtinst/urldetect.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/urlfetcher.py -+++ virt-manager-1.5.1/virtinst/urlfetcher.py -@@ -490,6 +490,12 @@ def _distroFromSUSEContent(fetcher, arch - dclass = OESDistro - if distro_version is None: - distro_version = _parse_sle_distribution(distribution) -+ elif re.match(".*SUSE Container as a Service Platform*", distribution[1]) or \ -+ re.match(".*SUSE CaaS Platform*", distribution[1]): -+ dclass = CAASPDistro -+ if distro_version is None: -+ dparts = distribution[1].strip().rsplit(' ') -+ distro_version = ['VERSION', dparts[len(dparts)-1]] - elif re.match(".*openSUSE.*", distribution[1]): - dclass = OpensuseDistro - if distro_version is None: -@@ -1076,6 +1082,8 @@ class SuseDistro(Distro): - self.os_variant += major_version + 'sp' + sp_version - else: - self.os_variant += major_version -+ elif self.os_variant.startswith("caasp"): -+ self.os_variant = "caasp" + distro_version - else: - self.os_variant += "9" - -@@ -1122,6 +1130,11 @@ class SLESDistro(SuseDistro): - class SLEDDistro(SuseDistro): - urldistro = "sled" +--- virt-manager-2.0.0.orig/virtinst/urldetect.py ++++ virt-manager-2.0.0/virtinst/urldetect.py +@@ -235,6 +235,12 @@ class _SUSEContent(object): + self.product_name.strip().rsplit(' ')[5][2]) + distro_version = sle_version ++ # SUSE Container as a Service Platform ++ if "Container" in self.product_name: ++ distro_version = self.product_name.strip().rsplit(' ')[6] ++ elif "CaaS" in self.product_name: ++ distro_version = self.product_name.strip().rsplit(' ')[3] + + return distro_version + + +@@ -567,6 +573,9 @@ class SuseDistro(Distro): + # Tumbleweed 8 digit date + return "opensusetumbleweed" + ++ if self._variant_prefix.startswith(("caasp")): ++ return self._variant_prefix + distro_version ++ + if int(version) < 10: + return self._variant_prefix + "9" + +@@ -642,6 +651,13 @@ class OpensuseDistro(SuseDistro): + famregex = ".*openSUSE.*" + + +class CAASPDistro(SuseDistro): -+ urldistro = "caasp" ++ PRETTY_NAME = "SLES" ++ _variant_prefix = "caasp" ++ _suse_regex = [".*SUSE Container as a Service Platform*", ".*SUSE CaaS Platform*"] ++ famregex = ".*SUSE Container as a Service Platform.*" + + class OESDistro(SuseDistro): - urldistro = "oes" - + PRETTY_NAME = "OES" + _variant_prefix = "oes" diff --git a/virtinst-add-ppc64-arch-support.patch b/virtinst-add-ppc64-arch-support.patch deleted file mode 100644 index 49031135..00000000 --- a/virtinst-add-ppc64-arch-support.patch +++ /dev/null @@ -1,32 +0,0 @@ -Reference: bnc#869024 -Add s390x and ppc64 support -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 -@@ -464,6 +464,10 @@ def _distroFromSUSEContent(fetcher, arch - arch = "i586" - elif cbuf.find("s390x") != -1: - arch = "s390x" -+ elif cbuf.find("ppc64") != -1: -+ arch = "ppc64" -+ elif cbuf.find("ppc64le") != -1: -+ arch = "ppc64le" - - def _parse_sle_distribution(d): - sle_version = d[1].strip().rsplit(' ')[4] -@@ -1022,10 +1026,12 @@ class SuseDistro(Distro): - oldkern += "64" - oldinit += "64" - -- if self.arch == "s390x": -+ if self.arch == "s390x" or \ -+ self.arch == "ppc64" or self.arch == "ppc64le": -+ - self._hvm_kernel_paths = [("boot/%s/linux" % self.arch, - "boot/%s/initrd" % self.arch)] -- # No Xen on s390x -+ # No Xen on s390x or ppc64 - self._xen_kernel_paths = [] - else: - # Tested with Opensuse >= 10.2, 11, and sles 10 diff --git a/virtinst-add-sle15-detection-support.patch b/virtinst-add-sle15-detection-support.patch index 0ca250ab..e4e62b7f 100644 --- a/virtinst-add-sle15-detection-support.patch +++ b/virtinst-add-sle15-detection-support.patch @@ -1,143 +1,20 @@ References: bsc#1054986 -With SLE15 and openSUSE 15 the content file has been removed from the media. -This file was used for SUSE distro version and arch detection. Now detection -must be done by parsing the .treeinfo file. -We must continue to keep the content parsing code for the older distros. -As a fallback, detection is also setup to look at the media.1/products and -media.1/build files. -Index: virt-manager-1.5.1/virtinst/urlfetcher.py +Index: virt-manager-2.0.0/virtinst/urldetect.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/urlfetcher.py -+++ virt-manager-1.5.1/virtinst/urlfetcher.py -@@ -416,7 +416,23 @@ def _distroFromSUSEContent(fetcher, arch - try: - cbuf = fetcher.acquireFileContent("content") - except ValueError: -- return None -+ 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.split(' ', 1)[1].strip() -+ # The media.1/products file naming convention changed between SLE11 and SLE12 -+ if pbuf.startswith('SLE'): -+ pbuf = pbuf.split(' ')[0] -+ pbuf = " ".join(re.split('(\d+)', pbuf, 1)) -+ cbuf = "\nDISTRO ," + pbuf.replace('-', ' ') -+ try: -+ bbuf = fetcher.acquireFileContent("media.1/build").split('-') -+ except: -+ bbuf = ["x86_64"] -+ cbuf = cbuf + "\n" + " ".join(bbuf) -+ except ValueError: -+ return None - - distribution = None - distro_version = None -@@ -489,7 +505,7 @@ def _distroFromSUSEContent(fetcher, arch - dclass = GenericDistro - if distribution: - if re.match(".*SUSE Linux Enterprise Server*", distribution[1]) or \ -- re.match(".*SUSE SLES*", distribution[1]): -+ re.match(".*SUSE SLES*", distribution[1]) or re.match("SLES*", distribution[1]): - dclass = SLESDistro - if distro_version is None: - distro_version = _parse_sle_distribution(distribution) -@@ -507,10 +523,13 @@ def _distroFromSUSEContent(fetcher, arch - if distro_version is None: - dparts = distribution[1].strip().rsplit(' ') - distro_version = ['VERSION', dparts[len(dparts)-1]] -- elif re.match(".*openSUSE.*", distribution[1]): -+ elif re.match(".*openSUSE.*", distribution[1]) or re.match("openSUSE *", distribution[1]): - dclass = OpensuseDistro - if distro_version is None: -- distro_version = ['VERSION', distribution[0].strip().rsplit(':')[4]] -+ if ':' in distribution[0]: -+ distro_version = ['VERSION', distribution[0].strip().rsplit(':')[4]] -+ else: -+ distro_version = ['VERSION', distribution[1].strip().rsplit(' ')[2]] - - if distro_version is None: - return None -@@ -1029,6 +1048,7 @@ class SLDistro(RHELDistro): - - class SuseDistro(Distro): - name = "SUSE" -+ uses_treeinfo = True - - _boot_iso_paths = ["boot/boot.iso"] - -@@ -1066,8 +1086,11 @@ class SuseDistro(Distro): - self._xen_kernel_paths = [("boot/%s/vmlinuz-xenpae" % self.arch, - "boot/%s/initrd-xenpae" % self.arch)] - else: -- self._xen_kernel_paths = [("boot/%s/vmlinuz-xen" % self.arch, -- "boot/%s/initrd-xen" % self.arch)] -+ self._xen_kernel_paths = [("boot/%s/loader/linux" % self.arch, -+ "boot/%s/loader/initrd" % self.arch)] -+ # By appending this gets searched for first -+ self._xen_kernel_paths.append(("boot/%s/vmlinuz-xen" % self.arch, -+ "boot/%s/initrd-xen" % self.arch)) - - def _variantFromVersion(self): - distro_version = self.version_from_content[1].strip() -@@ -1075,11 +1098,11 @@ class SuseDistro(Distro): - self.os_variant = self.urldistro - - sp_version = None -- if self.os_variant.startswith(("sles", "sled")): -+ if self.os_variant.startswith(("sle")): - if len(distro_version.split('.', 1)) == 2: - sp_version = 'sp' + distro_version.split('.', 1)[1].strip() - self.os_variant += version -- if sp_version: -+ if sp_version and sp_version != 'sp0': - self.os_variant += sp_version - elif self.os_variant.startswith("opensuse"): - if len(version) == 8: -@@ -1103,6 +1126,24 @@ class SuseDistro(Distro): - self.os_variant += "9" - - def isValidStore(self): -+ if self.treeinfo: -+ ret = False -+ if self.urldistro: -+ family = self.treeinfo.get("general", "family") -+ if "SUSE Linux Enterprise Server" in family and 'sles' in self.urldistro or \ -+ "SUSE Linux Enterprise Desktop" in family and 'sled' in self.urldistro or \ -+ "SUSE Linux Enterprise" in family and 'sle' in self.urldistro or \ -+ "SUSE Containers" in family and 'caasp' in self.urldistro or \ -+ "openSUSE" in family and 'opensuse' in self.urldistro or \ -+ "Open Enterprise" in family and 'oes' in self.urldistro: -+ ret = True -+ if ret: -+ version = self.treeinfo.get("general", "version") -+ distro_version = ['VERSION', version] -+ self.version_from_content = distro_version -+ self._variantFromVersion() -+ return ret -+ - # self.version_from_content is the VERSION line from the contents file - if (not self.version_from_content or - self.version_from_content[1] is None): -@@ -1138,6 +1179,10 @@ class SuseDistro(Distro): - return self.os_variant +--- virt-manager-2.0.0.orig/virtinst/urldetect.py ++++ virt-manager-2.0.0/virtinst/urldetect.py +@@ -627,6 +627,13 @@ class SuseDistro(Distro): + return "install" +class SLEDistro(SuseDistro): -+ urldistro = "sle" ++ PRETTY_NAME = "SLE" ++ _variant_prefix = "sle" ++ _suse_regex = ["SUSE Linux Enterprise$"] ++ famregex = "SUSE Linux Enterprise$" + + class SLESDistro(SuseDistro): - urldistro = "sles" - -@@ -1154,8 +1199,6 @@ class OESDistro(SuseDistro): - urldistro = "oes" - - --# Suse image store is harder - we fetch the kernel RPM and a helper --# RPM and then munge bits together to generate a initrd - class OpensuseDistro(SuseDistro): - urldistro = "opensuse" - + PRETTY_NAME = "SLES" + matching_distros = ["sles"] diff --git a/virtinst-check-date-format.patch b/virtinst-check-date-format.patch deleted file mode 100644 index 69ad905c..00000000 --- a/virtinst-check-date-format.patch +++ /dev/null @@ -1,21 +0,0 @@ -Fixes a bug caused by a bogus EOL date in an osinfo database file. -The bad date caused an exception in strptime. - -Index: virt-manager-1.4.2/virtinst/osdict.py -=================================================================== ---- virt-manager-1.4.2.orig/virtinst/osdict.py -+++ virt-manager-1.4.2/virtinst/osdict.py -@@ -363,8 +363,11 @@ class _OsVariant(object): - eol_date = self._os.get_eol_date_string() - - if eol_date: -- return (datetime.datetime.strptime(eol_date, "%Y-%m-%d") > -- datetime.datetime.now()) -+ try: -+ eol_valid = datetime.datetime.strptime(eol_date, "%Y-%m-%d") -+ return (eol_valid > datetime.datetime.now()) -+ except Exception: -+ pass - - if self.name == "fedora-unknown": - return False diff --git a/virtinst-default-xen-to-qcow2-format.patch b/virtinst-default-xen-to-qcow2-format.patch index 3650cc66..a4d9013d 100644 --- a/virtinst-default-xen-to-qcow2-format.patch +++ b/virtinst-default-xen-to-qcow2-format.patch @@ -1,15 +1,15 @@ Reference: bnc#885380 Allow Xen based VMs to default to using qcow2 -Index: virt-manager-1.4.3/virtinst/support.py +Index: virt-manager-2.0.0/virtinst/support.py =================================================================== ---- virt-manager-1.4.3.orig/virtinst/support.py -+++ virt-manager-1.4.3/virtinst/support.py -@@ -259,7 +259,7 @@ SUPPORT_CONN_DISK_SD = _make(version="1. +--- virt-manager-2.0.0.orig/virtinst/support.py ++++ virt-manager-2.0.0/virtinst/support.py +@@ -233,7 +233,7 @@ SUPPORT_CONN_WORKING_XEN_EVENTS = _make( + # This is an arbitrary check to say whether it's a good idea to # default to qcow2. It might be fine for xen or qemu older than the versions # here, but until someone tests things I'm going to be a bit conservative. - SUPPORT_CONN_DEFAULT_QCOW2 = _make( -- version="0.8.0", hv_version={"qemu": "1.2.0", "test": 0}) -+ version="0.8.0", hv_version={"qemu": "1.2.0", "all": 0}) - SUPPORT_CONN_DEFAULT_USB2 = _make( - version="0.9.7", hv_version={"qemu": "1.0.0", "test": 0}) - SUPPORT_CONN_CAN_ACPI = _make(hv_version={"xen": "3.1.0", "all": 0}) +-SUPPORT_CONN_DEFAULT_QCOW2 = _make(hv_version={"qemu": "1.2.0", "test": 0}) ++SUPPORT_CONN_DEFAULT_QCOW2 = _make(hv_version={"qemu": "1.2.0", "all": 0}) + SUPPORT_CONN_AUTOSOCKET = _make(hv_libvirt_version={"qemu": "1.0.6"}) + SUPPORT_CONN_PM_DISABLE = _make(hv_version={"qemu": "1.2.0", "test": 0}) + SUPPORT_CONN_QCOW2_LAZY_REFCOUNTS = _make( diff --git a/virtinst-detect-oes-distros.patch b/virtinst-detect-oes-distros.patch index 53bf53c4..b6166cb2 100644 --- a/virtinst-detect-oes-distros.patch +++ b/virtinst-detect-oes-distros.patch @@ -1,71 +1,29 @@ Enhancement to correctly detect Open Enterprise Server media is selected as the installation source. -Index: virt-manager-1.5.0/virtinst/urlfetcher.py +Index: virt-manager-2.0.0/virtinst/urldetect.py =================================================================== ---- virt-manager-1.5.0.orig/virtinst/urlfetcher.py -+++ virt-manager-1.5.0/virtinst/urlfetcher.py -@@ -482,6 +482,10 @@ def _distroFromSUSEContent(fetcher, arch - dclass = SLEDDistro - if distro_version is None: - distro_version = _parse_sle_distribution(distribution) -+ elif re.match(".*Open Enterprise Server*", distribution[1]): -+ dclass = OESDistro -+ if distro_version is None: -+ distro_version = _parse_sle_distribution(distribution) - elif re.match(".*openSUSE.*", distribution[1]): - dclass = OpensuseDistro - if distro_version is None: -@@ -1042,20 +1046,30 @@ class SuseDistro(Distro): - distro_version = self.version_from_content[1].strip() - version = distro_version.split('.', 1)[0].strip() - self.os_variant = self.urldistro -- if int(version) >= 10: -- if self.os_variant.startswith(("sles", "sled")): -- sp_version = None -- if len(distro_version.split('.', 1)) == 2: -- sp_version = 'sp' + distro_version.split('.', 1)[1].strip() -- self.os_variant += version -- if sp_version: -- self.os_variant += sp_version -+ -+ sp_version = None -+ if self.os_variant.startswith(("sles", "sled")): -+ if len(distro_version.split('.', 1)) == 2: -+ sp_version = 'sp' + distro_version.split('.', 1)[1].strip() -+ self.os_variant += version -+ if sp_version: -+ self.os_variant += sp_version -+ elif self.os_variant.startswith("opensuse"): -+ if len(version) == 8: -+ self.os_variant += "tumbleweed" - else: -- # Tumbleweed 8 digit date -- if len(version) == 8: -- self.os_variant += "tumbleweed" -- else: -- self.os_variant += distro_version -+ self.os_variant += distro_version -+ elif self.os_variant.startswith("oes"): -+ versions = distro_version.split('.') -+ major_version = versions[0] -+ if len(versions) == 3: -+ sp_version = versions[2] -+ elif len(versions) == 2: -+ sp_version = versions[1] -+ if sp_version: -+ self.os_variant += major_version + 'sp' + sp_version -+ else: -+ self.os_variant += major_version - else: - self.os_variant += "9" +--- virt-manager-2.0.0.orig/virtinst/urldetect.py ++++ virt-manager-2.0.0/virtinst/urldetect.py +@@ -570,7 +570,7 @@ class SuseDistro(Distro): + if int(version) < 10: + return self._variant_prefix + "9" + +- if str(self._variant_prefix).startswith(("sles", "sled")): ++ if str(self._variant_prefix).startswith(("sles", "sled", "oes")): + sp_version = "" + if len(distro_version.split('.', 1)) == 2: + sp_version = 'sp' + distro_version.split('.', 1)[1].strip() +@@ -642,6 +642,13 @@ class OpensuseDistro(SuseDistro): + famregex = ".*openSUSE.*" -@@ -1102,6 +1116,9 @@ class SLESDistro(SuseDistro): - class SLEDDistro(SuseDistro): - urldistro = "sled" +class OESDistro(SuseDistro): -+ urldistro = "oes" ++ PRETTY_NAME = "OES" ++ _variant_prefix = "oes" ++ _suse_regex = [".*Open Enterprise Server*"] ++ famregex = ".*Open Enterprise Server.*" + - - # Suse image store is harder - we fetch the kernel RPM and a helper - # RPM and then munge bits together to generate a initrd ++ + class DebianDistro(Distro): + # ex. http://ftp.egr.msu.edu/debian/dists/sarge/main/installer-i386/ + # daily builds: https://d-i.debian.org/daily-images/amd64/ diff --git a/virtinst-dont-use-special-copy-cpu-features.patch b/virtinst-dont-use-special-copy-cpu-features.patch index 9384f33e..e9523a03 100644 --- a/virtinst-dont-use-special-copy-cpu-features.patch +++ b/virtinst-dont-use-special-copy-cpu-features.patch @@ -12,13 +12,13 @@ It should be noted that selecting "Customize configuration before install" and "CPUs" -> "Copy host CPU definition" also inserts 'host-model' so this change mirrors what is already done there. -Index: virt-manager-1.5.0/virtinst/cpu.py +Index: virt-manager-2.0.0/virtinst/domain/cpu.py =================================================================== ---- virt-manager-1.5.0.orig/virtinst/cpu.py -+++ virt-manager-1.5.0/virtinst/cpu.py -@@ -98,12 +98,16 @@ class CPU(XMLBuilder): - SPECIAL_MODE_HOST_PASSTHROUGH, SPECIAL_MODE_CLEAR] - def set_special_mode(self, val): +--- virt-manager-2.0.0.orig/virtinst/domain/cpu.py ++++ virt-manager-2.0.0/virtinst/domain/cpu.py +@@ -88,12 +88,16 @@ class DomainCpu(XMLBuilder): + val = self.SPECIAL_MODE_HOST_MODEL + if (val == self.SPECIAL_MODE_HOST_MODEL or - val == self.SPECIAL_MODE_HOST_PASSTHROUGH): + val == self.SPECIAL_MODE_HOST_PASSTHROUGH or @@ -27,10 +27,10 @@ Index: virt-manager-1.5.0/virtinst/cpu.py self.vendor = None self.model_fallback = None for f in self.features: - self.remove_feature(f) + self.remove_child(f) + if val == self.SPECIAL_MODE_HOST_COPY: + val = self.SPECIAL_MODE_HOST_MODEL + self.match = "exact" self.mode = val elif val == self.SPECIAL_MODE_HOST_COPY: - self.copy_host_cpu() + self.copy_host_cpu(guest) diff --git a/virtinst-fix-sle-distro-parsing.patch b/virtinst-fix-sle-distro-parsing.patch deleted file mode 100644 index 9ff393a0..00000000 --- a/virtinst-fix-sle-distro-parsing.patch +++ /dev/null @@ -1,30 +0,0 @@ -References: bsc#1042709 - -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 -@@ -470,9 +470,20 @@ def _distroFromSUSEContent(fetcher, arch - arch = "ppc64le" - - def _parse_sle_distribution(d): -- sle_version = d[1].strip().rsplit(' ')[4] -- if len(d[1].strip().rsplit(' ')) > 5: -- sle_version = sle_version + '.' + d[1].strip().rsplit(' ')[5][2] -+ d_list = d[1].strip().rsplit(' ') -+ d_len = len(d_list) -+ sle_version = 12 -+ counter = 0 -+ while counter < d_len: -+ item = d_list[counter].strip() -+ if item.isdigit(): -+ sle_version = item -+ if counter+1 < d_len: -+ item = d_list[counter+1].strip() -+ if item[2].isdigit(): -+ sle_version = sle_version + '.' + item[2] -+ break -+ counter += 1 - return ['VERSION', sle_version] - - dclass = GenericDistro diff --git a/virtinst-handle-tumbleweed-treeinfo-file.patch b/virtinst-handle-tumbleweed-treeinfo-file.patch deleted file mode 100644 index db540030..00000000 --- a/virtinst-handle-tumbleweed-treeinfo-file.patch +++ /dev/null @@ -1,19 +0,0 @@ -References: bsc#1091113 -In Tumbleweed the .treeinfo file has no version as it is mostly meaningless. - -Index: virt-manager-1.5.1/virtinst/urlfetcher.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/urlfetcher.py -+++ virt-manager-1.5.1/virtinst/urlfetcher.py -@@ -1138,7 +1138,10 @@ class SuseDistro(Distro): - "Open Enterprise" in family and 'oes' in self.urldistro: - ret = True - if ret: -- version = self.treeinfo.get("general", "version") -+ if 'Tumbleweed' not in family: -+ version = self.treeinfo.get("general", "version") -+ else: -+ version = "tmblweed" - distro_version = ['VERSION', version] - self.version_from_content = distro_version - self._variantFromVersion() diff --git a/virtinst-keep-install-iso-attached.patch b/virtinst-keep-install-iso-attached.patch index d421c25a..7f3916b5 100644 --- a/virtinst-keep-install-iso-attached.patch +++ b/virtinst-keep-install-iso-attached.patch @@ -2,17 +2,17 @@ Older SLE guests have a two stage installation that need the ISO. Newer SLE PV guests hang when a cdrom device is attached without an ISO file. -Index: virt-manager-1.4.3/virtinst/guest.py +Index: virt-manager-2.0.0/virtinst/installer.py =================================================================== ---- virt-manager-1.4.3.orig/virtinst/guest.py -+++ virt-manager-1.4.3/virtinst/guest.py -@@ -805,7 +805,8 @@ class Guest(XMLBuilder): - # install. - if (dev.is_cdrom() and - getattr(dev, "installer_media", False) and -- not self._os_object.is_windows()): -+ not self._os_object.is_windows() and -+ not self.os_variant.startswith(("sles", "sled", "opensuse"))): - dev.path = None - - def _set_defaults(self): +--- virt-manager-2.0.0.orig/virtinst/installer.py ++++ virt-manager-2.0.0/virtinst/installer.py +@@ -103,7 +103,8 @@ class Installer(object): + return + if self.livecd: + return +- if guest.osinfo.is_windows(): ++ if (guest.osinfo.is_windows() or ++ guest.osinfo.name.startswith(("sles", "sled", "opensuse"))): + # Keep media attached for windows which has a multi stage install + return + self._install_cdrom_device.path = None diff --git a/virtinst-modify-gui-defaults.patch b/virtinst-modify-gui-defaults.patch index 8753a144..04ceb151 100644 --- a/virtinst-modify-gui-defaults.patch +++ b/virtinst-modify-gui-defaults.patch @@ -1,11 +1,11 @@ Enhancement for the following GUI wizard installation option. 1) If Xen, leave 'Architecture options' expanded so users know PV is the default -Index: virt-manager-1.4.2/virtManager/create.py +Index: virt-manager-2.0.0/virtManager/create.py =================================================================== ---- virt-manager-1.4.2.orig/virtManager/create.py -+++ virt-manager-1.4.2/virtManager/create.py -@@ -397,8 +397,20 @@ class vmmCreate(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/create.py ++++ virt-manager-2.0.0/virtManager/create.py +@@ -346,8 +346,20 @@ class vmmCreate(vmmGObjectUI): self.widget("method-local").set_active(True) self.widget("create-conn").set_active(-1) activeconn = self._populate_conn_list(urihint) diff --git a/virtinst-nfs-install-sanitize.patch b/virtinst-nfs-install-sanitize.patch deleted file mode 100644 index 8291dbc6..00000000 --- a/virtinst-nfs-install-sanitize.patch +++ /dev/null @@ -1,69 +0,0 @@ -Reference: bnc#888251 -A fix for accessing nfs mounted media. A comment in the code states, - "Convert RFC compliant NFS nfs://server/path/to/distro - to what mount/anaconda expect nfs:server:/path/to/distro - and carry the latter form around internally" -We need the RFC version to work correctly whereas redhat's anaconda -needs their own modified version. -Index: virt-manager-1.5.1/virtinst/util.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/util.py -+++ virt-manager-1.5.1/virtinst/util.py -@@ -369,3 +369,22 @@ def getInstallRepos(): - return (0, []) - return lookupZypperRepos(getHostInstallSource()) - -+def sanitize_url(url): -+ """ -+ Do nothing for http or ftp, but make sure nfs is in the expected format -+ """ -+ if url.startswith("nfs://"): -+ # Convert RFC compliant NFS nfs://server/path/to/distro -+ # to what mount/anaconda expect nfs:server:/path/to/distro -+ # and carry the latter form around internally -+ url = "nfs:" + url[6:] -+ -+ # If we need to add the : after the server -+ index = url.find("/", 4) -+ if index == -1: -+ raise ValueError(_("Invalid NFS format: No path specified.")) -+ if url[index - 1] != ":": -+ url = url[:index] + ":" + url[index:] -+ -+ return url -+ -Index: virt-manager-1.5.1/virtinst/distroinstaller.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/distroinstaller.py -+++ virt-manager-1.5.1/virtinst/distroinstaller.py -@@ -44,6 +44,8 @@ def _sanitize_url(url): - """ - Do nothing for http or ftp, but make sure nfs is in the expected format - """ -+ # This sanitize will be done later -+ return url - if url.startswith("nfs://"): - # Convert RFC compliant NFS nfs://server/path/to/distro - # to what mount/anaconda expect nfs:server:/path/to/distro -Index: virt-manager-1.5.1/virtinst/urlfetcher.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/urlfetcher.py -+++ virt-manager-1.5.1/virtinst/urlfetcher.py -@@ -33,6 +33,7 @@ import urlparse - import requests - - from .osdict import OSDB -+from virtinst import util - - - ######################################################################### -@@ -301,7 +302,8 @@ class _MountedURLFetcher(_LocalURLFetche - mountcmd = "/bin/mount" - - logging.debug("Preparing mount at " + self._srcdir) -- cmd = [mountcmd, "-o", "ro", self.location[4:], self._srcdir] -+ url = util.sanitize_url(self.location) -+ cmd = [mountcmd, "-o", "ro", url[4:], self._srcdir] - - logging.debug("mount cmd: %s", cmd) - if not self._in_test_suite: diff --git a/virtinst-no-usb-tablet-for-xenpv.patch b/virtinst-no-usb-tablet-for-xenpv.patch deleted file mode 100644 index 605a1651..00000000 --- a/virtinst-no-usb-tablet-for-xenpv.patch +++ /dev/null @@ -1,16 +0,0 @@ -With 1.4.2 the code no longer checks for xenpv when adding -a usb tablet which is only supported on xen hvm. - -Index: virt-manager-1.4.3/virtinst/guest.py -=================================================================== ---- virt-manager-1.4.3.orig/virtinst/guest.py -+++ virt-manager-1.4.3/virtinst/guest.py -@@ -660,7 +660,7 @@ class Guest(XMLBuilder): - - usb_tablet = False - usb_keyboard = False -- if self.os.is_x86(): -+ if self.os.is_x86() and not self.os.is_xenpv(): - usb_tablet = self._os_object.supports_usbtablet() - if self.os.is_arm_machvirt(): - usb_tablet = True diff --git a/virtinst-osdict-get_supported.patch b/virtinst-osdict-get_supported.patch index b6d42197..31594b3c 100644 --- a/virtinst-osdict-get_supported.patch +++ b/virtinst-osdict-get_supported.patch @@ -3,20 +3,16 @@ to be supported through LTSS contracts for others. Hence the EOL date in the osinfo-db file may be past but we want the distro to continue to show up in the list. -Index: virt-manager-1.5.1/virtinst/osdict.py +Index: virt-manager-2.0.0/virtinst/osdict.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/osdict.py -+++ virt-manager-1.5.1/virtinst/osdict.py -@@ -376,8 +376,11 @@ class _OsVariant(object): - # EOL date. So assume None == EOL, add some manual work arounds. - # We should fix this in a new libosinfo version, and then drop - # this hack -+ # SUSE: How to handle EOL distros that still have LTSS support - if self._is_related_to(["fedora24", "rhel7.0", "debian6", -- "ubuntu13.04", "win8", "win2k12", "mageia5", "centos7.0"], -+ "ubuntu13.04", "win8", "win2k12", "mageia5", "centos7.0", -+ "sle15", "sles12sp3", "sles12sp2", "sles12sp1", "sles11sp4", -+ "tumbleweed", "opensuse15", "opensuse42.3" ], - check_clones=False, check_derives=False): - return True +--- virt-manager-2.0.0.orig/virtinst/osdict.py ++++ virt-manager-2.0.0/virtinst/osdict.py +@@ -337,7 +337,7 @@ class _OsVariant(object): + + # If no EOL is present, assume EOL if release was > 5 years ago + if rel is not None: +- rel5 = _glib_to_datetime(rel) + datetime.timedelta(days=365 * 5) ++ rel5 = _glib_to_datetime(rel) + datetime.timedelta(days=365 * 10) + return now > rel5 return False + diff --git a/virtinst-pvgrub2-bootloader.patch b/virtinst-pvgrub2-bootloader.patch index 5f044187..035ae308 100644 --- a/virtinst-pvgrub2-bootloader.patch +++ b/virtinst-pvgrub2-bootloader.patch @@ -1,53 +1,29 @@ Reference: bnc#863821 grub.xen is required to boot PV VMs that use the BTRFS filesystem. This patch forces the use of grub.xen (instead of using pygrub) for -newer suse distros like SLE12 and openSUSE 13.2. -Index: virt-manager-1.4.3/virtinst/guest.py +suse distros SLE12GA, openSUSE 13.2, and newer. +Index: virt-manager-2.0.0/virtinst/installer.py =================================================================== ---- virt-manager-1.4.3.orig/virtinst/guest.py -+++ virt-manager-1.4.3/virtinst/guest.py -@@ -366,8 +366,20 @@ class Guest(XMLBuilder): - if (not install and - self.os.is_xenpv() and - not self.os.kernel): -- self.bootloader = "/usr/bin/pygrub" -- self.os.clear() -+ os_ver = self._get_os_variant() -+ if self.os.arch != 'x86_64' or os_ver.startswith("sles9") or \ +--- virt-manager-2.0.0.orig/virtinst/installer.py ++++ virt-manager-2.0.0/virtinst/installer.py +@@ -307,6 +307,20 @@ class Installer(object): + install_xml = None + if self.has_install_phase(): + install_xml = self._get_install_xml(guest) ++ if (guest.os.is_xenpv() and ++ not guest.os.kernel): ++ os_ver = guest.osinfo.name ++ if guest.os.arch != 'x86_64' or os_ver.startswith("sles9") or \ + os_ver.startswith("sles10") or os_ver.startswith("sled10") or \ + os_ver.startswith("opensuse10") or os_ver.startswith("opensuse11"): -+ self.bootloader = "pygrub" -+ self.os.clear() ++ guest.os.bootloader = "pygrub" + else: -+ self.installer._install_kernel = "/usr/lib/grub2/x86_64-xen/grub.xen" -+ self.installer._install_initrd = None -+ self.installer.extraargs = None -+ # alter_bootconfig won't update the osxml unless it thinks -+ # we are in an install phase. Add force_update param to call -+ self.installer.alter_bootconfig(self, True, True) ++ guest.os.bootloader = None ++ self._install_kernel = "/usr/lib/grub2/x86_64-xen/grub.xen" ++ self._install_initrd = None ++ self.extraargs = None + logging.info("Using grub.xen to boot guest") ++ self._alter_bootconfig(guest) + final_xml = guest.get_xml() - return self.get_xml_config() - -Index: virt-manager-1.4.3/virtinst/installer.py -=================================================================== ---- virt-manager-1.4.3.orig/virtinst/installer.py -+++ virt-manager-1.4.3/virtinst/installer.py -@@ -99,7 +99,7 @@ class Installer(object): - break - return bootorder - -- def alter_bootconfig(self, guest, isinstall): -+ def alter_bootconfig(self, guest, isinstall, force_update=False): - """ - Generate the portion of the guest xml that determines boot devices - and parameters. (typically the block) -@@ -110,7 +110,7 @@ class Installer(object): - 'post-install' phase. - @type isinstall: C{bool} - """ -- if isinstall and not self.has_install_phase(): -+ if isinstall and not force_update and not self.has_install_phase(): - return - - bootorder = guest.os.bootorder + logging.debug("Generated install XML: %s", diff --git a/virtinst-python2-to-python3-conversion.patch b/virtinst-python2-to-python3-conversion.patch index 40372b2c..999c73a3 100644 --- a/virtinst-python2-to-python3-conversion.patch +++ b/virtinst-python2-to-python3-conversion.patch @@ -1,270 +1,35 @@ -Index: virt-manager-1.5.1/virt-install +Index: virt-manager-2.0.0/virtinst/osdict.py =================================================================== ---- virt-manager-1.5.1.orig/virt-install -+++ virt-manager-1.5.1/virt-install -@@ -1,4 +1,4 @@ --#!/usr/bin/env python2 -+#!/usr/bin/python3 - # - # Copyright 2005-2014 Red Hat, Inc. - # -Index: virt-manager-1.5.1/virtinst/uri.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/uri.py -+++ virt-manager-1.5.1/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.1/virtinst/hostkeymap.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/hostkeymap.py -+++ virt-manager-1.5.1/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.1/virtinst/support.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/support.py -+++ virt-manager-1.5.1/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.1/virtinst/osdict.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/osdict.py -+++ virt-manager-1.5.1/virtinst/osdict.py -@@ -79,7 +79,7 @@ def _sort(tosort, sortpref=None, limit_p +--- virt-manager-2.0.0.orig/virtinst/osdict.py ++++ virt-manager-2.0.0/virtinst/osdict.py +@@ -51,7 +51,7 @@ def _sort(tosort): + distro_mappings = {} 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: -@@ -264,7 +264,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.1/virtinst/guest.py + sortby = _sortby(osinfo) +Index: virt-manager-2.0.0/virtinst/installertreemedia.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/guest.py -+++ virt-manager-1.5.1/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]) +--- virt-manager-2.0.0.orig/virtinst/installertreemedia.py ++++ virt-manager-2.0.0/virtinst/installertreemedia.py +@@ -22,7 +22,7 @@ from .osdict import OSDB + # Enum of the various install media types we can have + (MEDIA_DIR, + MEDIA_ISO, +- MEDIA_URL) = range(1, 4) ++ MEDIA_URL) = list(range(1, 4)) - if install_xml and install_xml != final_xml: - domain = self.conn.defineXML(final_xml) -@@ -1099,7 +1099,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.1/virtinst/distroinstaller.py + def _is_url(url): +Index: virt-manager-2.0.0/virtinst/xmlbuilder.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/distroinstaller.py -+++ virt-manager-1.5.1/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.1/virtinst/cli.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/cli.py -+++ virt-manager-1.5.1/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.1/virtinst/xmlbuilder.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/xmlbuilder.py -+++ virt-manager-1.5.1/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 -@@ -832,7 +832,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 = {} -@@ -846,7 +846,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) -@@ -888,7 +888,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]] -@@ -929,8 +929,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: -@@ -993,7 +993,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) -@@ -1028,7 +1028,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: -@@ -1087,7 +1087,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 -@@ -1110,7 +1110,7 @@ class XMLBuilder(object): - xpaths point at their particular element +--- virt-manager-2.0.0.orig/virtinst/xmlbuilder.py ++++ virt-manager-2.0.0/virtinst/xmlbuilder.py +@@ -625,7 +625,7 @@ class XMLBuilder(object): + whenever child objects are added or removed """ typecount = {} - for propname, xmlprop in self._all_child_props().items(): @@ -272,29 +37,11 @@ Index: virt-manager-1.5.1/virtinst/xmlbuilder.py for obj in util.listify(getattr(self, propname)): idxstr = "" if not xmlprop.is_single: -@@ -1168,7 +1168,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 -@@ -1183,7 +1183,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.1/virtinst/domcapabilities.py +Index: virt-manager-2.0.0/virtinst/domcapabilities.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/domcapabilities.py -+++ virt-manager-1.5.1/virtinst/domcapabilities.py -@@ -166,7 +166,7 @@ class DomainCapabilities(XMLBuilder): +--- virt-manager-2.0.0.orig/virtinst/domcapabilities.py ++++ virt-manager-2.0.0/virtinst/domcapabilities.py +@@ -202,7 +202,7 @@ class DomainCapabilities(XMLBuilder): return _("BIOS") return _("None") @@ -303,29 +50,11 @@ Index: virt-manager-1.5.1/virtinst/domcapabilities.py for pattern in patterns: if re.match(pattern, path): return (_("UEFI %(arch)s: %(path)s") % -@@ -178,7 +178,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.1/virtinst/devicedisk.py +Index: virt-manager-2.0.0/virtinst/devices/disk.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/devicedisk.py -+++ virt-manager-1.5.1/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): -@@ -455,7 +455,7 @@ class VirtualDisk(VirtualDevice): +--- virt-manager-2.0.0.orig/virtinst/devices/disk.py ++++ virt-manager-2.0.0/virtinst/devices/disk.py +@@ -327,7 +327,7 @@ class DeviceDisk(Device): digit = 1 seen_valid = True @@ -334,7 +63,7 @@ Index: virt-manager-1.5.1/virtinst/devicedisk.py return gen_t -@@ -1056,11 +1056,11 @@ class VirtualDisk(VirtualDevice): +@@ -918,11 +918,11 @@ class DeviceDisk(Device): def get_target(): first_found = None @@ -348,266 +77,11 @@ Index: virt-manager-1.5.1/virtinst/devicedisk.py for i in ran: postfix = self.num_to_target(i + 1) -Index: virt-manager-1.5.1/virtinst/storage.py +Index: virt-manager-2.0.0/virtinst/pollhelpers.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/storage.py -+++ virt-manager-1.5.1/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.1/virtinst/devicegraphics.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/devicegraphics.py -+++ virt-manager-1.5.1/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.1/virtinst/util.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/util.py -+++ virt-manager-1.5.1/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.1/virtinst/urlfetcher.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/urlfetcher.py -+++ virt-manager-1.5.1/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 - -@@ -358,6 +362,7 @@ class _ISOURLFetcher(_URLFetcher): - - logging.debug("Running isoinfo: %s", cmd) - output = subprocess.check_output(cmd) -+ output = output.decode() - - self._cache_file_list = output.splitlines(False) - -@@ -395,14 +400,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 +420,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 +435,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) -@@ -647,7 +655,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: -@@ -714,6 +722,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 - -@@ -783,15 +792,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": -@@ -1481,7 +1490,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.1/virtinst/diskbackend.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/diskbackend.py -+++ virt-manager-1.5.1/virtinst/diskbackend.py -@@ -404,7 +404,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" -@@ -424,7 +424,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.1/virtinst/progress.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/progress.py -+++ virt-manager-1.5.1/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.1/virtinst/pollhelpers.py -=================================================================== ---- virt-manager-1.5.1.orig/virtinst/pollhelpers.py -+++ virt-manager-1.5.1/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_ +--- virt-manager-2.0.0.orig/virtinst/pollhelpers.py ++++ virt-manager-2.0.0/virtinst/pollhelpers.py +@@ -131,7 +131,7 @@ def fetch_pools(backend, origmap, build_ for obj in objs: try: obj.refresh(0) @@ -616,21 +90,3 @@ Index: virt-manager-1.5.1/virtinst/pollhelpers.py 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): diff --git a/virtinst-refresh_before_fetch_pool.patch b/virtinst-refresh_before_fetch_pool.patch index ca052762..7218dde6 100644 --- a/virtinst-refresh_before_fetch_pool.patch +++ b/virtinst-refresh_before_fetch_pool.patch @@ -13,11 +13,11 @@ status affects the hypervisor connection. Signed-off-by: Chunyan Liu -Index: virt-manager-1.4.3/virtinst/pollhelpers.py +Index: virt-manager-2.0.0/virtinst/pollhelpers.py =================================================================== ---- virt-manager-1.4.3.orig/virtinst/pollhelpers.py -+++ virt-manager-1.4.3/virtinst/pollhelpers.py -@@ -133,6 +133,19 @@ def fetch_pools(backend, origmap, build_ +--- virt-manager-2.0.0.orig/virtinst/pollhelpers.py ++++ virt-manager-2.0.0/virtinst/pollhelpers.py +@@ -121,6 +121,19 @@ def fetch_pools(backend, origmap, build_ if backend.check_support( backend.SUPPORT_CONN_LISTALLSTORAGEPOOLS) and not FORCE_OLD_POLL: diff --git a/virtinst-s390x-disable-graphics.patch b/virtinst-s390x-disable-graphics.patch index 26bbe8fe..bb969e83 100644 --- a/virtinst-s390x-disable-graphics.patch +++ b/virtinst-s390x-disable-graphics.patch @@ -1,10 +1,10 @@ Reference: bnc#869024 Disable graphics on s390x -Index: virt-manager-1.5.0/virtinst/guest.py +Index: virt-manager-2.0.0/virtinst/guest.py =================================================================== ---- virt-manager-1.5.0.orig/virtinst/guest.py -+++ virt-manager-1.5.0/virtinst/guest.py -@@ -126,7 +126,10 @@ class Guest(XMLBuilder): +--- virt-manager-2.0.0.orig/virtinst/guest.py ++++ virt-manager-2.0.0/virtinst/guest.py +@@ -159,7 +159,10 @@ class Guest(XMLBuilder): self.skip_default_channel = False self.skip_default_sound = False self.skip_default_usbredir = False @@ -14,36 +14,9 @@ Index: virt-manager-1.5.0/virtinst/guest.py + else: + self.skip_default_graphics = False self.skip_default_rng = False - self.x86_cpu_default = self.cpu.SPECIAL_MODE_HOST_MODEL_ONLY + self.x86_cpu_default = self.cpu.SPECIAL_MODE_APP_DEFAULT -@@ -687,7 +690,7 @@ class Guest(XMLBuilder): - self.add_device(dev) - - def add_default_video_device(self): -- if self.os.is_container(): -+ if self.os.is_container() or self.os.is_s390x(): - return - if self.get_devices("video"): - return -@@ -742,6 +745,8 @@ class Guest(XMLBuilder): - dev.target_type = "virtio" - dev.target_name = dev.CHANNEL_NAME_QEMUGA - self.add_device(dev) -+ elif self.os.is_s390x(): -+ dev.target_type = "sclp" - - def add_default_graphics(self): - if self.skip_default_graphics: -@@ -750,7 +755,7 @@ class Guest(XMLBuilder): - return - if self.os.is_container() and not self.conn.is_vz(): - return -- if self.os.arch not in ["x86_64", "i686", "ppc64", "ppc64le"]: -+ if self.os.arch not in ["x86_64", "i686", "ppc64", "ppc64le", "s390x"]: - return - self.add_device(VirtualGraphics(self.conn)) - -@@ -1110,7 +1115,7 @@ class Guest(XMLBuilder): +@@ -289,7 +292,7 @@ class Guest(XMLBuilder): if not os_support: return False @@ -51,4 +24,22 @@ Index: virt-manager-1.5.0/virtinst/guest.py + if self.os.is_x86() or self.os.is_s390x(): return True - if (self.os.is_arm_vexpress() and + return False +@@ -592,7 +595,7 @@ class Guest(XMLBuilder): + self.add_device(dev) + + def _add_default_video_device(self): +- if self.os.is_container(): ++ if self.os.is_container() or self.os.is_s390x(): + return + if self.devices.video: + return +@@ -656,7 +659,7 @@ class Guest(XMLBuilder): + return + if self.os.is_container() and not self.conn.is_vz(): + return +- if self.os.arch not in ["x86_64", "i686", "ppc64", "ppc64le"]: ++ if self.os.arch not in ["x86_64", "i686", "ppc64", "ppc64le", "s390x"]: + return + self.add_device(DeviceGraphics(self.conn)) + diff --git a/virtinst-set-cache-mode-unsafe-for-install.patch b/virtinst-set-cache-mode-unsafe-for-install.patch index 3ae63a1e..390beec2 100644 --- a/virtinst-set-cache-mode-unsafe-for-install.patch +++ b/virtinst-set-cache-mode-unsafe-for-install.patch @@ -1,36 +1,28 @@ Set cache mode for target installation disk to unsafe for better performance. -Index: virt-manager-1.4.3/virtinst/guest.py +Index: virt-manager-2.0.0/virtinst/installer.py =================================================================== ---- virt-manager-1.4.3.orig/virtinst/guest.py -+++ virt-manager-1.4.3/virtinst/guest.py -@@ -362,6 +362,17 @@ class Guest(XMLBuilder): - - self._set_osxml_defaults() +--- virt-manager-2.0.0.orig/virtinst/installer.py ++++ virt-manager-2.0.0/virtinst/installer.py +@@ -294,10 +294,21 @@ class Installer(object): + guest.os.kernel_args, guest.on_reboot) = data + def _get_install_xml(self, guest): + # At install time set the target disk to 'unsafe' for + # better performance if the target is not a block device + saved_cache = "None" -+ if install: -+ disk_devices = self.get_devices("disk") -+ if disk_devices: -+ target_disk = self.get_devices("disk")[0] -+ saved_cache = target_disk.driver_cache -+ if target_disk.type != VirtualDisk.TYPE_BLOCK: -+ target_disk.driver_cache = VirtualDisk.CACHE_MODE_UNSAFE ++ if guest.devices.disk: ++ target_disk = guest.devices.disk[0] ++ saved_cache = target_disk.driver_cache ++ if target_disk.type != DeviceDisk.TYPE_BLOCK: ++ target_disk.driver_cache = DeviceDisk.CACHE_MODE_UNSAFE + - self.bootloader = None - if (not install and - self.os.is_xenpv() and -@@ -381,7 +392,10 @@ class Guest(XMLBuilder): - self.installer.alter_bootconfig(self, True, True) - logging.info("Using grub.xen to boot guest") - -- return self.get_xml_config() -+ xml_config = self.get_xml_config() -+ if install and saved_cache != "None": -+ target_disk.driver_cache = saved_cache -+ return xml_config - - - ########################### + data = self._prepare_get_install_xml(guest) + try: + self._alter_bootconfig(guest) + ret = guest.get_xml() ++ if saved_cache != "None": ++ target_disk.driver_cache = saved_cache + return ret + finally: + self._remove_install_cdrom_media(guest) diff --git a/virtinst-set-qemu-emulator.patch b/virtinst-set-qemu-emulator.patch deleted file mode 100644 index 100be628..00000000 --- a/virtinst-set-qemu-emulator.patch +++ /dev/null @@ -1,26 +0,0 @@ -Use the correct qemu emulator based on the architecture. -We want to get away from using the old qemu-dm emulator -for Xen HVM guests so default to qemu-system-i386. -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 -@@ -897,14 +897,11 @@ class Guest(XMLBuilder): - self.emulator = None - return - -- if self.emulator: -- return -- - if self.os.is_hvm() and self.type == "xen": -- if self.conn.caps.host.cpu.arch == "x86_64": -- self.emulator = "/usr/lib64/xen/bin/qemu-dm" -- else: -- self.emulator = "/usr/lib/xen/bin/qemu-dm" -+ # Force not using Xen's old qemu-dm except for remote -+ # connections where we don't know the Xen version -+ if not self.conn.is_remote() or not self.emulator: -+ self.emulator = "/usr/lib/xen/bin/qemu-system-i386" - - def _set_cpu_x86_kvm_default(self): - if self.os.arch != self.conn.caps.host.cpu.arch: diff --git a/virtinst-storage-ocfs2.patch b/virtinst-storage-ocfs2.patch deleted file mode 100644 index 6e160771..00000000 --- a/virtinst-storage-ocfs2.patch +++ /dev/null @@ -1,14 +0,0 @@ -Enhancement to add ocfs2 as a supported FS type -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 -@@ -460,7 +460,7 @@ class StoragePool(_StorageObject): - def list_formats(self): - if self.type == self.TYPE_FS: - return ["auto", "ext2", "ext3", "ext4", "ufs", "iso9660", "udf", -- "gfs", "gfs2", "vfat", "hfs+", "xfs"] -+ "gfs", "gfs2", "vfat", "hfs+", "xfs", "ocfs2"] - if self.type == self.TYPE_NETFS: - return ["auto", "nfs", "glusterfs"] - if self.type == self.TYPE_DISK: diff --git a/virtinst-use-latest-opensuse-version-when-unknown-media.patch b/virtinst-use-latest-opensuse-version-when-unknown-media.patch index 3a6f881f..6ef2f9f6 100644 --- a/virtinst-use-latest-opensuse-version-when-unknown-media.patch +++ b/virtinst-use-latest-opensuse-version-when-unknown-media.patch @@ -5,11 +5,11 @@ detect the version of openSUSE ISO media (it changes with every build). When 'opensuse-unknown' is detected, look up the most current version of openSUSE and default to that. This is the same way fedora does it. -Index: virt-manager-1.5.0/virtinst/osdict.py +Index: virt-manager-2.0.0/virtinst/osdict.py =================================================================== ---- virt-manager-1.5.0.orig/virtinst/osdict.py -+++ virt-manager-1.5.0/virtinst/osdict.py -@@ -241,6 +241,12 @@ class _OSDB(object): +--- virt-manager-2.0.0.orig/virtinst/osdict.py ++++ virt-manager-2.0.0/virtinst/osdict.py +@@ -214,6 +214,12 @@ class _OSDB(object): "Converting that to the latest fedora OS version=%s", location, osname) @@ -21,10 +21,10 @@ Index: virt-manager-1.5.0/virtinst/osdict.py + return osname - def list_types(self): -@@ -275,6 +281,16 @@ class _OSDB(object): - # First fedora* occurrence should be the newest - return osinfo.name + def list_os(self): +@@ -239,6 +245,16 @@ class _OSDB(object): + def latest_fedora_version(self): + return self.latest_regex("fedora[0-9]+") + def latest_opensuse_version(self): + os_info = None diff --git a/virtinst-use-qemu-for-cdrom-device.patch b/virtinst-use-qemu-for-cdrom-device.patch index d971ca20..3750f8aa 100644 --- a/virtinst-use-qemu-for-cdrom-device.patch +++ b/virtinst-use-qemu-for-cdrom-device.patch @@ -2,11 +2,11 @@ References: bsc#989639 When the device added is a cdrom device (/dev/sr0), don't use "phy" as the driver name but instead use "qemu". -Index: virt-manager-1.5.1/virtinst/devicedisk.py +Index: virt-manager-2.0.0/virtinst/devices/disk.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/devicedisk.py -+++ virt-manager-1.5.1/virtinst/devicedisk.py -@@ -563,7 +563,8 @@ class VirtualDisk(VirtualDevice): +--- virt-manager-2.0.0.orig/virtinst/devices/disk.py ++++ virt-manager-2.0.0/virtinst/devices/disk.py +@@ -435,7 +435,8 @@ class DeviceDisk(Device): # Recommended xen defaults from here: # https://bugzilla.redhat.com/show_bug.cgi?id=1171550#c9 # If type block, use name=phy. Otherwise do the same as qemu diff --git a/virtinst-use-xenpae-kernel-for-32bit.patch b/virtinst-use-xenpae-kernel-for-32bit.patch index 2525011c..5d625282 100644 --- a/virtinst-use-xenpae-kernel-for-32bit.patch +++ b/virtinst-use-xenpae-kernel-for-32bit.patch @@ -4,22 +4,25 @@ a non pae version. The sles10 sp4 32bit kernel will only boot para- virtualized if the pae kernel is selected. Note that sles12 and newer has no 32bit release. -Index: virt-manager-1.5.1/virtinst/urlfetcher.py +Index: virt-manager-2.0.0/virtinst/urldetect.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/urlfetcher.py -+++ virt-manager-1.5.1/virtinst/urlfetcher.py -@@ -1051,8 +1051,12 @@ class SuseDistro(Distro): - "boot/%s/initrd" % self.arch)) - +--- virt-manager-2.0.0.orig/virtinst/urldetect.py ++++ virt-manager-2.0.0/virtinst/urldetect.py +@@ -538,9 +538,14 @@ class SuseDistro(Distro): + self._kernel_paths = [] + if self.type == "xen": # Matches Opensuse > 10.2 and sles 10 -- self._xen_kernel_paths = [("boot/%s/vmlinuz-xen" % self.arch, -- "boot/%s/initrd-xen" % self.arch)] +- self._kernel_paths.append( +- ("boot/%s/vmlinuz-xen" % tree_arch, +- "boot/%s/initrd-xen" % tree_arch)) + if self.arch == "i386": -+ self._xen_kernel_paths = [("boot/%s/vmlinuz-xenpae" % self.arch, -+ "boot/%s/initrd-xenpae" % self.arch)] ++ self._kernel_paths.append( ++ ("boot/%s/vmlinuz-xen" % tree_arch, ++ "boot/%s/initrd-xen" % tree_arch)) + else: -+ self._xen_kernel_paths = [("boot/%s/vmlinuz-xen" % self.arch, -+ "boot/%s/initrd-xen" % self.arch)] ++ self._kernel_paths.append( ++ ("boot/%s/vmlinuz-xenpae" % tree_arch, ++ "boot/%s/initrd-xenpae" % tree_arch)) - def _variantFromVersion(self): - distro_version = self.version_from_content[1].strip() + if (tree_arch == "s390x" and + (self._os_variant == "sles11" or self._os_variant == "sled11")): diff --git a/virtinst-vol-default-nocow.patch b/virtinst-vol-default-nocow.patch index 930acf88..3a5532fa 100644 --- a/virtinst-vol-default-nocow.patch +++ b/virtinst-vol-default-nocow.patch @@ -4,33 +4,32 @@ issue on btrfs. Signed-off-by: Chunyan Liu -Index: virt-manager-1.5.0/virtinst/storage.py +Index: virt-manager-2.0.0/virtinst/storage.py =================================================================== ---- virt-manager-1.5.0.orig/virtinst/storage.py -+++ virt-manager-1.5.0/virtinst/storage.py -@@ -701,6 +701,12 @@ class StorageVolume(_StorageObject): +--- virt-manager-2.0.0.orig/virtinst/storage.py ++++ virt-manager-2.0.0/virtinst/storage.py +@@ -618,6 +618,11 @@ class StorageVolume(_StorageObject): return self._pool_xml.get_disk_type() file_type = property(_get_vol_type) + def _nocow_default_cb(self): + return self.conn.check_support( + self.conn.SUPPORT_CONN_NOCOW) -+ nocow = XMLProperty("./target/nocow", -+ is_bool=True, default_cb=_nocow_default_cb) ++ nocow = XMLProperty("./target/nocow", is_bool=True) + ################## # XML properties # -Index: virt-manager-1.5.0/virtinst/support.py +Index: virt-manager-2.0.0/virtinst/support.py =================================================================== ---- virt-manager-1.5.0.orig/virtinst/support.py -+++ virt-manager-1.5.0/virtinst/support.py -@@ -326,6 +326,8 @@ SUPPORT_CONN_USB3_PORTS = _make(version= +--- virt-manager-2.0.0.orig/virtinst/support.py ++++ virt-manager-2.0.0/virtinst/support.py +@@ -267,6 +267,8 @@ SUPPORT_CONN_USB3_PORTS = _make(version= SUPPORT_CONN_MACHVIRT_PCI_DEFAULT = _make(version="3.0.0") - SUPPORT_CONN_QEMU_XHCI = _make(version="3.3.0") + SUPPORT_CONN_QEMU_XHCI = _make(version="3.3.0", hv_version={"qemu": "2.9.0"}) SUPPORT_CONN_VNC_NONE_AUTH = _make(hv_version={"qemu": "2.9.0"}) +SUPPORT_CONN_NOCOW = _make( + version="1.2.18", hv_version={"qemu": "2.2.0", "test": 0}) - - # This is for disk . xen supports this, but it's + # We choose qemu 2.11.0 as the first version to target for q35 default. + # That's not really based on anything except reasonably modern at the diff --git a/virtinst-xen-drive-type.patch b/virtinst-xen-drive-type.patch index 55eb77b3..9c281cd8 100644 --- a/virtinst-xen-drive-type.patch +++ b/virtinst-xen-drive-type.patch @@ -2,12 +2,12 @@ Reference: bnc#813082 Virt-manager on Xen doesn't fill in any type thereby defaulting to 'raw'. This patch will generate the correct XML on Xen. -Index: virt-manager-1.5.1/virtinst/devicedisk.py +Index: virt-manager-2.0.0/virtinst/devices/disk.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/devicedisk.py -+++ virt-manager-1.5.1/virtinst/devicedisk.py -@@ -581,6 +581,10 @@ class VirtualDisk(VirtualDevice): - http://lists.gnu.org/archive/html/qemu-devel/2008-04/msg00675.html +--- virt-manager-2.0.0.orig/virtinst/devices/disk.py ++++ virt-manager-2.0.0/virtinst/devices/disk.py +@@ -453,6 +453,10 @@ class DeviceDisk(Device): + https://lists.gnu.org/archive/html/qemu-devel/2008-04/msg00675.html """ if self.driver_name != self.DRIVER_NAME_QEMU: + if self.driver_name and \ diff --git a/virtinst-xenbus-disk-index-fix.patch b/virtinst-xenbus-disk-index-fix.patch index ae9e720d..39317313 100644 --- a/virtinst-xenbus-disk-index-fix.patch +++ b/virtinst-xenbus-disk-index-fix.patch @@ -6,12 +6,12 @@ types (ide vs xen) it added xvda with hda. These disks were then passed to qemu where it error'ed out with the disks having the same index (in this case both are 0). -Index: virt-manager-1.5.1/virtinst/devicedisk.py +Index: virt-manager-2.0.0/virtinst/devices/disk.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/devicedisk.py -+++ virt-manager-1.5.1/virtinst/devicedisk.py -@@ -1038,6 +1038,17 @@ class VirtualDisk(VirtualDevice): - @rtype C{str} +--- virt-manager-2.0.0.orig/virtinst/devices/disk.py ++++ virt-manager-2.0.0/virtinst/devices/disk.py +@@ -900,6 +900,17 @@ class DeviceDisk(Device): + :returns: generated target """ prefix, maxnode = self.get_target_prefix(skip_targets) + postfix_targets = [] @@ -28,7 +28,7 @@ Index: virt-manager-1.5.1/virtinst/devicedisk.py skip_targets = [t for t in skip_targets if t and t.startswith(prefix)] skip_targets.sort() -@@ -1051,7 +1062,12 @@ class VirtualDisk(VirtualDevice): +@@ -913,7 +924,12 @@ class DeviceDisk(Device): ran = range(pref_ctrl * 7, (pref_ctrl + 1) * 7) for i in ran: diff --git a/virtman-add-connect-default.patch b/virtman-add-connect-default.patch deleted file mode 100644 index ec8cfcd0..00000000 --- a/virtman-add-connect-default.patch +++ /dev/null @@ -1,29 +0,0 @@ -Enhancement for when no hypervisor can be found locally it opens -the new connection dialog. -Index: virt-manager-1.5.0/virtManager/engine.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/engine.py -+++ virt-manager-1.5.0/virtManager/engine.py -@@ -239,9 +239,6 @@ class vmmEngine(vmmGObject): - except Exception: - logging.exception("Error talking to PackageKit") - -- if tryuri is None: -- tryuri = "qemu:///system" -- - warnmsg = _("The 'libvirtd' service will need to be started.\n\n" - "After that, virt-manager will connect to libvirt on\n" - "the next application start up.") -@@ -255,7 +252,11 @@ class vmmEngine(vmmGObject): - if not connected and do_start: - manager.err.ok(_("Libvirt service must be started"), warnmsg) - -- self.idle_add(idle_connect) -+ # If there is no default URI to be found, show the new connection dialog -+ if tryuri is None: -+ self._do_show_connect(self.windowManager) -+ else: -+ self.idle_add(idle_connect) - - - def load_stored_uris(self): diff --git a/virtman-allow-creating-i686-vm.patch b/virtman-allow-creating-i686-vm.patch index 3ac723c5..e5f73ba4 100644 --- a/virtman-allow-creating-i686-vm.patch +++ b/virtman-allow-creating-i686-vm.patch @@ -1,11 +1,11 @@ References: bsc#919692 Because openSUSE repos combine 32 and 64 bit sources we need to continue showing the 'Architecture' pop-up. -Index: virt-manager-1.5.0/virtManager/create.py +Index: virt-manager-2.0.0/virtManager/create.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/create.py -+++ virt-manager-1.5.0/virtManager/create.py -@@ -849,11 +849,6 @@ class vmmCreate(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/create.py ++++ virt-manager-2.0.0/virtManager/create.py +@@ -774,11 +774,6 @@ class vmmCreate(vmmGObjectUI): for guest in self.conn.caps.guests: if guest.os_type == self._capsinfo.os_type: archs.append(guest.arch) diff --git a/virtman-allow-destroy-from-shutdown-menu-of-crashed-vm.patch b/virtman-allow-destroy-from-shutdown-menu-of-crashed-vm.patch index 5cd3b256..9fa5b58e 100644 --- a/virtman-allow-destroy-from-shutdown-menu-of-crashed-vm.patch +++ b/virtman-allow-destroy-from-shutdown-menu-of-crashed-vm.patch @@ -6,11 +6,11 @@ Steps to get a KVM VM in the crashed state: 4) Edit the VM's /etc/default/grub file and remove the crashkernel information and then run grub2-mkconfig /boot/grub2/grub.cfg. 5) Start the VM and within the VM's terminal type "echo 'c' > /proc/sysrq-trigger" -Index: virt-manager-1.5.0/virtManager/manager.py +Index: virt-manager-2.0.0/virtManager/manager.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/manager.py -+++ virt-manager-1.5.0/virtManager/manager.py -@@ -844,7 +844,7 @@ class vmmManager(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/manager.py ++++ virt-manager-2.0.0/virtManager/manager.py +@@ -789,7 +789,7 @@ class vmmManager(vmmGObjectUI): show_pause = bool(vm and vm.is_unpauseable()) else: show_pause = bool(vm and vm.is_pauseable()) @@ -19,11 +19,11 @@ Index: virt-manager-1.5.0/virtManager/manager.py if vm and vm.managedsave_supported: self.change_run_text(vm.has_managed_save()) -Index: virt-manager-1.5.0/virtManager/vmmenu.py +Index: virt-manager-2.0.0/virtManager/vmmenu.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/vmmenu.py -+++ virt-manager-1.5.0/virtManager/vmmenu.py -@@ -31,6 +31,7 @@ class _VMMenu(Gtk.Menu): +--- virt-manager-2.0.0.orig/virtManager/vmmenu.py ++++ virt-manager-2.0.0/virtManager/vmmenu.py +@@ -21,6 +21,7 @@ class _VMMenu(Gtk.Menu): self._parent = src self._current_vm_cb = current_vm_cb self._show_open = show_open @@ -31,7 +31,7 @@ Index: virt-manager-1.5.0/virtManager/vmmenu.py self._init_state() -@@ -92,6 +93,7 @@ class VMShutdownMenu(_VMMenu): +@@ -84,6 +85,7 @@ class VMShutdownMenu(_VMMenu): name = getattr(child, "vmm_widget_name", None) if name in statemap: child.set_sensitive(statemap[name]) @@ -39,17 +39,17 @@ Index: virt-manager-1.5.0/virtManager/vmmenu.py if name == "reset": child.set_tooltip_text(None) -@@ -108,7 +110,8 @@ class VMActionMenu(_VMMenu): - self._add_action(_("_Pause"), "suspend", Gtk.STOCK_MEDIA_PAUSE) - self._add_action(_("R_esume"), "resume", Gtk.STOCK_MEDIA_PAUSE) - s = self._add_action(_("_Shut Down"), "shutdown", addcb=False) +@@ -106,7 +108,8 @@ class VMActionMenu(_VMMenu): + self._add_action(_("R_esume"), "resume", VMActionUI.resume, + Gtk.STOCK_MEDIA_PAUSE) + s = self._add_action(_("_Shut Down"), "shutdown", None) - s.set_submenu(VMShutdownMenu(self._parent, self._current_vm_cb)) + self._shutdown = VMShutdownMenu(self._parent, self._current_vm_cb) + s.set_submenu(self._shutdown) self.add(Gtk.SeparatorMenuItem()) - self._add_action(_("Clone..."), "clone", None) -@@ -124,7 +127,7 @@ class VMActionMenu(_VMMenu): + self._add_action(_("Clone..."), "clone", +@@ -126,7 +129,7 @@ class VMActionMenu(_VMMenu): def update_widget_states(self, vm): statemap = { "run": bool(vm and vm.is_runable()), @@ -58,7 +58,7 @@ Index: virt-manager-1.5.0/virtManager/vmmenu.py "suspend": bool(vm and vm.is_stoppable()), "resume": bool(vm and vm.is_paused()), "migrate": bool(vm and vm.is_stoppable()), -@@ -141,6 +144,8 @@ class VMActionMenu(_VMMenu): +@@ -143,6 +146,8 @@ class VMActionMenu(_VMMenu): child.get_submenu().update_widget_states(vm) if name in statemap: child.set_sensitive(statemap[name]) diff --git a/virtman-check-for-valid-display.patch b/virtman-check-for-valid-display.patch index c8ffe1cb..63906676 100644 --- a/virtman-check-for-valid-display.patch +++ b/virtman-check-for-valid-display.patch @@ -1,10 +1,10 @@ References: bnc#907958 Sanity check for those who forget '-X' on ssh and try to start virt-manager -Index: virt-manager-1.4.2/virt-manager +Index: virt-manager-2.0.0/virt-manager =================================================================== ---- virt-manager-1.4.2.orig/virt-manager -+++ virt-manager-1.4.2/virt-manager -@@ -81,8 +81,11 @@ def _import_gtk(leftovers): +--- virt-manager-2.0.0.orig/virt-manager ++++ virt-manager-2.0.0/virt-manager +@@ -66,8 +66,11 @@ def _import_gtk(leftovers): print("gtk3 3.14.0 or later is required.") sys.exit(1) @@ -15,6 +15,6 @@ Index: virt-manager-1.4.2/virt-manager + Gtk.Window() + else: + raise Exception("Error starting virt-manager: No graphical display found") - globals()["Gtk"] = Gtk - import virtManager.config + + # This ensures we can init gsettings correctly diff --git a/virtman-default-guest-from-host-os.patch b/virtman-default-guest-from-host-os.patch index 7a04ed81..5bf9d844 100644 --- a/virtman-default-guest-from-host-os.patch +++ b/virtman-default-guest-from-host-os.patch @@ -1,10 +1,10 @@ Enhancement to default to the host os version when creating a VM and media detection of the install source is turned off. -Index: virt-manager-1.5.1/virtManager/create.py +Index: virt-manager-2.0.0/virtManager/create.py =================================================================== ---- virt-manager-1.5.1.orig/virtManager/create.py -+++ virt-manager-1.5.1/virtManager/create.py -@@ -24,6 +24,9 @@ import pkgutil +--- virt-manager-2.0.0.orig/virtManager/create.py ++++ virt-manager-2.0.0/virtManager/create.py +@@ -10,6 +10,9 @@ import pkgutil import os import threading import time @@ -12,16 +12,16 @@ Index: virt-manager-1.5.1/virtManager/create.py +import os +import re - from gi.repository import GObject + from gi.repository import Gdk from gi.repository import Gtk -@@ -1511,6 +1514,63 @@ class vmmCreate(vmmGObjectUI): - def _cdrom_changed(self, src): - self._detectable_media_widget_changed(src) +@@ -1183,6 +1186,63 @@ class vmmCreate(vmmGObjectUI): + def _iso_activated_cb(self, mediacombo, entry): + self._detectable_media_widget_changed(entry, checkfocus=False) + def _lookup_host_os(self): + def _lookup_sp(line): + sp = "" -+ m = re.search(' SP[1234] ', line) ++ m = re.search(' SP[12345] ', line) + if m: + sp = m.group(0).strip().lower() + return sp @@ -44,7 +44,7 @@ Index: virt-manager-1.5.1/virtManager/create.py + if "SUSE Linux Enterprise Server 11" in line: + return 'linux', ('sles11' + _lookup_sp(line)) + if "SUSE Linux Enterprise Desktop 15" in line: -+ return 'linux', ('sle15' + _lookup_sp(line)) ++ return 'linux', ('sled15' + _lookup_sp(line)) + if "SUSE Linux Enterprise Desktop 12" in line: + return 'linux', ('sled12' + _lookup_sp(line)) + if "SUSE Linux Enterprise Desktop 11" in line: @@ -75,15 +75,15 @@ Index: virt-manager-1.5.1/virtManager/create.py + break + index += 1 + - def _toggle_detect_os(self, src): - dodetect = src.get_active() - -@@ -1523,6 +1583,8 @@ class vmmCreate(vmmGObjectUI): - self.widget("install-os-version-entry").set_text("") + def _detect_os_toggled_cb(self, src): + if not src.is_visible(): + return +@@ -1193,6 +1253,8 @@ class vmmCreate(vmmGObjectUI): + if dodetect: self._os_already_detected_for_media = False self._start_detect_os_if_needed() + else: + self.detect_host_os() - def _selected_os_row(self): - return uiutil.get_list_selected_row(self.widget("install-os-type")) + def _browse_oscontainer(self, ignore): + self._browse_file("install-oscontainer-fs", is_dir=True) diff --git a/virtman-default-to-xen-pv.patch b/virtman-default-to-xen-pv.patch index 6312fb1c..21b9cd60 100644 --- a/virtman-default-to-xen-pv.patch +++ b/virtman-default-to-xen-pv.patch @@ -1,9 +1,9 @@ Enhancement to default to PV instead of HVM on Xen host. -Index: virt-manager-1.5.0/virtManager/create.py +Index: virt-manager-2.0.0/virtManager/create.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/create.py -+++ virt-manager-1.5.0/virtManager/create.py -@@ -759,7 +759,12 @@ class vmmCreate(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/create.py ++++ virt-manager-2.0.0/virtManager/create.py +@@ -683,7 +683,12 @@ class vmmCreate(vmmGObjectUI): if gtype is None: # If none specified, prefer HVM so install options aren't limited # with a default PV choice. diff --git a/virtman-desktop.patch b/virtman-desktop.patch index 72478a53..bd3a18bc 100644 --- a/virtman-desktop.patch +++ b/virtman-desktop.patch @@ -1,7 +1,7 @@ -Index: virt-manager-1.4.0/data/virt-manager.desktop.in +Index: virt-manager-2.0.0/data/virt-manager.desktop.in =================================================================== ---- virt-manager-1.4.0.orig/data/virt-manager.desktop.in -+++ virt-manager-1.4.0/data/virt-manager.desktop.in +--- virt-manager-2.0.0.orig/data/virt-manager.desktop.in ++++ virt-manager-2.0.0/data/virt-manager.desktop.in @@ -1,8 +1,19 @@ [Desktop Entry] _Name=Virtual Machine Manager diff --git a/virtman-dont-allow-grub.xen-to-be-deleted.patch b/virtman-dont-allow-grub.xen-to-be-deleted.patch index ecf486be..0fe0c2b1 100644 --- a/virtman-dont-allow-grub.xen-to-be-deleted.patch +++ b/virtman-dont-allow-grub.xen-to-be-deleted.patch @@ -1,11 +1,11 @@ Reference: bnc#885094 grub.xen is required to boot Xen PV VMs using BTRFS. It belongs to the grub2-x86_64-xen RPM and should never be deleted. -Index: virt-manager-1.4.3/virtManager/delete.py +Index: virt-manager-2.0.0/virtManager/delete.py =================================================================== ---- virt-manager-1.4.3.orig/virtManager/delete.py -+++ virt-manager-1.4.3/virtManager/delete.py -@@ -241,7 +241,7 @@ def populate_storage_list(storage_list, +--- virt-manager-2.0.0.orig/virtManager/delete.py ++++ virt-manager-2.0.0/virtManager/delete.py +@@ -246,7 +246,7 @@ def populate_storage_list(storage_list, diskdata.append(("dtb", vm.get_xmlobj().os.dtb, True, False, True)) for target, path, ro, shared, is_media in diskdata: diff --git a/virtman-dont-specify-vte-version.patch b/virtman-dont-specify-vte-version.patch index 3a42a970..3ab76903 100644 --- a/virtman-dont-specify-vte-version.patch +++ b/virtman-dont-specify-vte-version.patch @@ -2,9 +2,11 @@ Creates a problem for gobject-introspection identifying what version of vte is really allowed. Vte 2.91 is installed on the host but the RPM is built requiring 2.90. ---- virt-manager-1.4.0/virtManager/serialcon.py.orig 2016-06-21 15:35:45.109272839 -0600 -+++ virt-manager-1.4.0/virtManager/serialcon.py 2016-06-21 15:35:56.637272738 -0600 -@@ -32,12 +32,12 @@ from gi.repository import Gtk +Index: virt-manager-2.0.0/virtManager/serialcon.py +=================================================================== +--- virt-manager-2.0.0.orig/virtManager/serialcon.py ++++ virt-manager-2.0.0/virtManager/serialcon.py +@@ -12,12 +12,12 @@ from gi.repository import Gtk # We can use either 2.91 or 2.90. This is just to silence runtime warnings # pylint: disable=wrong-import-position diff --git a/virtman-fix-missing-translations.patch b/virtman-fix-missing-translations.patch deleted file mode 100644 index 6e37df95..00000000 --- a/virtman-fix-missing-translations.patch +++ /dev/null @@ -1,23 +0,0 @@ -References: bsc#1081544 - -Index: virt-manager-1.5.1/po/de.po -=================================================================== ---- virt-manager-1.5.1.orig/po/de.po -+++ virt-manager-1.5.1/po/de.po -@@ -3922,7 +3922,6 @@ msgid "Storage Pools" - msgstr "Speicher-Pools" - - #: ../virtManager/storagelist.py:342 --#, fuzzy, python-format - msgid "%s Free / %s In Use" - msgstr "%s frei / %s belegt" - -@@ -6191,7 +6190,7 @@ msgstr "URL:" - - #: ../ui/create.ui.h:28 - msgid "Kerne_l options:" --msgstr "Kernel Options:" -+msgstr "Kernel-Optionen:" - - #: ../ui/create.ui.h:29 - msgid "URL _Options" diff --git a/virtman-increase-setKeepAlive-count.patch b/virtman-increase-setKeepAlive-count.patch index 93abb70d..e022b158 100644 --- a/virtman-increase-setKeepAlive-count.patch +++ b/virtman-increase-setKeepAlive-count.patch @@ -2,11 +2,11 @@ References: bnc#892003 For very large memory VMs Xen takes a long time scrubbing memory which causes the libvirt connection to timeout. Upstream was not interested in making this a preferences option (4/11/2015) -Index: virt-manager-1.4.3/virtManager/connection.py +Index: virt-manager-2.0.0/virtManager/connection.py =================================================================== ---- virt-manager-1.4.3.orig/virtManager/connection.py -+++ virt-manager-1.4.3/virtManager/connection.py -@@ -1088,7 +1088,7 @@ class vmmConnection(vmmGObject): +--- virt-manager-2.0.0.orig/virtManager/connection.py ++++ virt-manager-2.0.0/virtManager/connection.py +@@ -1059,7 +1059,7 @@ class vmmConnection(vmmGObject): self.caps.get_cpu_values(self.caps.host.cpu.arch) try: diff --git a/virtman-keycombo.patch b/virtman-keycombo.patch index 5b2c58c1..55eee003 100644 --- a/virtman-keycombo.patch +++ b/virtman-keycombo.patch @@ -1,9 +1,9 @@ Enhancement adding Send Keys for mostly NetWare and also Windows -Index: virt-manager-1.4.0/virtManager/console.py +Index: virt-manager-2.0.0/virtManager/console.py =================================================================== ---- virt-manager-1.4.0.orig/virtManager/console.py -+++ virt-manager-1.4.0/virtManager/console.py -@@ -218,6 +218,16 @@ class vmmConsolePages(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/console.py ++++ virt-manager-2.0.0/virtManager/console.py +@@ -204,6 +204,16 @@ class vmmConsolePages(vmmGObjectUI): make_item("Ctrl+Alt+_Backspace", ["Control_L", "Alt_L", "BackSpace"]) make_item("Ctrl+Alt+_Delete", ["Control_L", "Alt_L", "Delete"]) menu.add(Gtk.SeparatorMenuItem()) diff --git a/virtman-kvm.patch b/virtman-kvm.patch index 18a13675..5f4ac3f8 100644 --- a/virtman-kvm.patch +++ b/virtman-kvm.patch @@ -1,10 +1,10 @@ /usr/bin/kvm doesn't exist on suse distros so check instead for /usr/bin/qemu-system-x86_64 -Index: virt-manager-1.5.0/virtManager/connect.py +Index: virt-manager-2.0.0/virtManager/connect.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/connect.py -+++ virt-manager-1.5.0/virtManager/connect.py -@@ -117,7 +117,7 @@ class vmmConnect(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/connect.py ++++ virt-manager-2.0.0/virtManager/connect.py +@@ -66,7 +66,7 @@ class vmmConnect(vmmGObjectUI): if (os.path.exists("/usr/bin/qemu") or os.path.exists("/usr/bin/qemu-kvm") or diff --git a/virtman-libvirtd-not-running.patch b/virtman-libvirtd-not-running.patch deleted file mode 100644 index e1f97a4e..00000000 --- a/virtman-libvirtd-not-running.patch +++ /dev/null @@ -1,16 +0,0 @@ -Use the correct systemd to start libvirt. -Index: virt-manager-1.4.2/virtManager/packageutils.py -=================================================================== ---- virt-manager-1.4.2.orig/virtManager/packageutils.py -+++ virt-manager-1.4.2/virtManager/packageutils.py -@@ -145,8 +145,8 @@ def start_libvirtd(): - logging.debug("libvirtd not running, asking system-config-services " - "to start it") - scs = Gio.DBusProxy.new_sync(bus, 0, None, -- "org.fedoraproject.Config.Services", -- "/org/fedoraproject/Config/Services/systemd1", -+ "org.freedesktop.systemd1", -+ "/org/freedesktop/systemd1", - "org.freedesktop.systemd1.Manager", None) - scs.StartUnit("(ss)", unitname, "replace") - time.sleep(2) diff --git a/virtman-load-stored-uris.patch b/virtman-load-stored-uris.patch index a09f6528..46e6a0e9 100644 --- a/virtman-load-stored-uris.patch +++ b/virtman-load-stored-uris.patch @@ -1,27 +1,31 @@ -Index: virt-manager-1.5.0/virtManager/engine.py +If booted Xen, don't try connecting to local qemu +Likewise if booted native, don't try connecting to local xen + +Index: virt-manager-2.0.0/virtManager/connmanager.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/engine.py -+++ virt-manager-1.5.0/virtManager/engine.py -@@ -260,9 +260,22 @@ class vmmEngine(vmmGObject): +--- virt-manager-2.0.0.orig/virtManager/connmanager.py ++++ virt-manager-2.0.0/virtManager/connmanager.py +@@ -26,12 +26,23 @@ class vmmConnectionManager(vmmGObject): - def load_stored_uris(self): - uris = self.config.get_conn_uris() or [] + def __init__(self): + vmmGObject.__init__(self) ++ from .connect import vmmConnect + tryuri = vmmConnect.default_uri() -+ found_uri = None - for uri in uris: -+ # If booted Xen, don't try connecting to local qemu -+ # Likewise if booted native, don't try connecting to local xen ++ found_uri = False + + self._conns = {} + + # Load URIs from gsettings + for uri in self.config.get_conn_uris(): + if uri == 'xen:///' or uri == 'qemu:///system': + if tryuri and tryuri != uri: + logging.debug("Skipping %s because it is incompatible with local host", uri) + continue + found_uri = True - conn = self.make_conn(uri) - self.register_conn(conn, skip_config=True) -+ if tryuri and found_uri is None: -+ logging.debug("Didn't connect with anything, try default %s", tryuri) -+ conn = self.make_conn(tryuri) -+ self.register_conn(conn, skip_config=False) + self.add_conn(uri) ++ if tryuri and found_uri is False: ++ logging.debug("CEA:: Didn't connect with anything, use default %s", tryuri) ++ self.add_conn(tryuri) - def autostart_conns(self): - """ + def _cleanup(self): + for conn in self._conns.values(): diff --git a/virtman-packages.patch b/virtman-packages.patch deleted file mode 100644 index 8b5a803e..00000000 --- a/virtman-packages.patch +++ /dev/null @@ -1,108 +0,0 @@ -Reference: bnc#866287 -This patch is for when virt-manager is installed but not libvirt -This is not a normal situation on a suse distro. Split out required -libvirt packages (kvm vs xen). Only install those libvirt packages -for which the host is booted. This patch has a corresponding spec -file change (%define libvirt_kvm_packages and %define libvirt_xen_packages). -Index: virt-manager-1.5.0/setup.py -=================================================================== ---- virt-manager-1.5.0.orig/setup.py -+++ virt-manager-1.5.0/setup.py -@@ -308,8 +308,11 @@ class configure(distutils.core.Command): - ("prefix=", None, "installation prefix"), - ("qemu-user=", None, - "user libvirt uses to launch qemu processes (default=root)"), -- ("libvirt-package-names=", None, -- "list of libvirt distro packages virt-manager will check for on " -+ ("libvirt-kvm-package-names=", None, -+ "list of libvirt kvm distro packages virt-manager will check for on " -+ "first run. comma separated string (default=none)"), -+ ("libvirt-xen-package-names=", None, -+ "list of libvirt xen distro packages virt-manager will check for on " - "first run. comma separated string (default=none)"), - ("kvm-package-names=", None, - "recommended kvm packages virt-manager will check for on first run " -@@ -335,7 +338,8 @@ class configure(distutils.core.Command): - def initialize_options(self): - self.prefix = sysprefix - self.qemu_user = None -- self.libvirt_package_names = None -+ self.libvirt_kvm_package_names = None -+ self.libvirt_xen_package_names = None - self.kvm_package_names = None - self.askpass_package_names = None - self.preferred_distros = None -@@ -350,8 +354,10 @@ class configure(distutils.core.Command): - template += "prefix = %s\n" % self.prefix - if self.qemu_user is not None: - template += "default_qemu_user = %s\n" % self.qemu_user -- if self.libvirt_package_names is not None: -- template += "libvirt_packages = %s\n" % self.libvirt_package_names -+ if self.libvirt_kvm_package_names is not None: -+ template += "libvirt_kvm_packages = %s\n" % self.libvirt_kvm_package_names -+ if self.libvirt_xen_package_names is not None: -+ template += "libvirt_xen_packages = %s\n" % self.libvirt_xen_package_names - if self.kvm_package_names is not None: - template += "hv_packages = %s\n" % self.kvm_package_names - if self.askpass_package_names is not None: -Index: virt-manager-1.5.0/virtcli/cliconfig.py -=================================================================== ---- virt-manager-1.5.0.orig/virtcli/cliconfig.py -+++ virt-manager-1.5.0/virtcli/cliconfig.py -@@ -83,7 +83,8 @@ class _CLIConfig(object): - _get_param("preferred_distros", "")) - self.hv_packages = _split_list(_get_param("hv_packages", "")) - self.askpass_package = _split_list(_get_param("askpass_packages", "")) -- self.libvirt_packages = _split_list(_get_param("libvirt_packages", "")) -+ self.libvirt_kvm_packages = _split_list(_get_param("libvirt_kvm_packages", "")) -+ self.libvirt_xen_packages = _split_list(_get_param("libvirt_xen_packages", "")) - self.default_graphics = _get_param("default_graphics", "spice") - self.default_hvs = _split_list(_get_param("default_hvs", "")) - -Index: virt-manager-1.5.0/virtManager/config.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/config.py -+++ virt-manager-1.5.0/virtManager/config.py -@@ -183,7 +183,8 @@ class vmmConfig(object): - self.default_qemu_user = CLIConfig.default_qemu_user - self.preferred_distros = CLIConfig.preferred_distros - self.hv_packages = CLIConfig.hv_packages -- self.libvirt_packages = CLIConfig.libvirt_packages -+ self.libvirt_kvm_packages = CLIConfig.libvirt_kvm_packages -+ self.libvirt_xen_packages = CLIConfig.libvirt_xen_packages - self.askpass_package = CLIConfig.askpass_package - self.default_graphics_from_config = CLIConfig.default_graphics - self.default_hvs = CLIConfig.default_hvs -Index: virt-manager-1.5.0/virtManager/engine.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/engine.py -+++ virt-manager-1.5.0/virtManager/engine.py -@@ -229,22 +229,18 @@ class vmmEngine(vmmGObject): - - ret = None - try: -- libvirt_packages = self.config.libvirt_packages -- packages = self.config.hv_packages + libvirt_packages -+ tryuri = vmmConnect.default_uri() -+ if tryuri and tryuri.startswith('xen'): -+ packages = self.config.libvirt_xen_packages -+ else: -+ packages = self.config.libvirt_kvm_packages + self.config.hv_packages - - ret = packageutils.check_packagekit(manager, manager.err, packages) - except Exception: - logging.exception("Error talking to PackageKit") - -- tryuri = None -- if ret: -- tryuri = "qemu:///system" -- elif not self.config.test_first_run: -- tryuri = vmmConnect.default_uri() -- - if tryuri is None: -- manager.set_startup_error(msg) -- return -+ tryuri = "qemu:///system" - - warnmsg = _("The 'libvirtd' service will need to be started.\n\n" - "After that, virt-manager will connect to libvirt on\n" diff --git a/virtman-prevent-double-click-starting-vm-twice.patch b/virtman-prevent-double-click-starting-vm-twice.patch index b8f6ae08..161c2b99 100644 --- a/virtman-prevent-double-click-starting-vm-twice.patch +++ b/virtman-prevent-double-click-starting-vm-twice.patch @@ -3,17 +3,17 @@ When the 'Power on virtual machine' button is double clicked, virt-manager issues two start commands to start the VM which results in a failure. There is code elsewhere to desensitize the button but this patch does it earlier. -Index: virt-manager-1.4.3/virtManager/details.py +Index: virt-manager-2.0.0/virtManager/details.py =================================================================== ---- virt-manager-1.4.3.orig/virtManager/details.py -+++ virt-manager-1.4.3/virtManager/details.py -@@ -1449,6 +1449,9 @@ class vmmDetails(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/details.py ++++ virt-manager-2.0.0/virtManager/details.py +@@ -1489,6 +1489,9 @@ class vmmDetails(vmmGObjectUI): def control_vm_run(self, src_ignore): if self.has_unapplied_changes(self.get_hw_row()): return + # De-sensitize widget so a double click on the icon won't attempt to + # start the VM twice + self.widget("control-run").set_sensitive(False) - self.emit("action-run-domain", - self.vm.conn.get_uri(), self.vm.get_connkey()) + vmmenu.VMActionUI.run(self, self.vm) + def control_vm_shutdown(self, src_ignore): diff --git a/virtman-python2-to-python3-conversion.patch b/virtman-python2-to-python3-conversion.patch index 03ccda8d..4e8640ab 100644 --- a/virtman-python2-to-python3-conversion.patch +++ b/virtman-python2-to-python3-conversion.patch @@ -1,14 +1,8 @@ -Index: virt-manager-1.5.0/virt-manager +Index: virt-manager-2.0.0/virt-manager =================================================================== ---- virt-manager-1.5.0.orig/virt-manager -+++ virt-manager-1.5.0/virt-manager -@@ -1,4 +1,4 @@ --#!/usr/bin/env python2 -+#!/usr/bin/python3 - # - # Copyright (C) 2006, 2014 Red Hat, Inc. - # Copyright (C) 2006 Daniel P. Berrange -@@ -81,7 +81,7 @@ def _import_gtk(leftovers): +--- virt-manager-2.0.0.orig/virt-manager ++++ virt-manager-2.0.0/virt-manager +@@ -66,7 +66,7 @@ def _import_gtk(leftovers): print("gtk3 3.14.0 or later is required.") sys.exit(1) @@ -17,11 +11,11 @@ Index: virt-manager-1.5.0/virt-manager # This will error if Gtk wasn't correctly initialized Gtk.Window() else: -Index: virt-manager-1.5.0/virtManager/network.py +Index: virt-manager-2.0.0/virtManager/network.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/network.py -+++ virt-manager-1.5.0/virtManager/network.py -@@ -103,7 +103,7 @@ class vmmNetwork(vmmLibvirtObject): +--- virt-manager-2.0.0.orig/virtManager/network.py ++++ virt-manager-2.0.0/virtManager/network.py +@@ -110,7 +110,7 @@ class vmmNetwork(vmmLibvirtObject): def set_qos(self, **kwargs): xmlobj = self._make_xmlobj_to_define() q = xmlobj.bandwidth @@ -30,73 +24,11 @@ Index: virt-manager-1.5.0/virtManager/network.py setattr(q, key, val) self._redefine_xmlobj(xmlobj) -Index: virt-manager-1.5.0/virtManager/inspection.py +Index: virt-manager-2.0.0/virtManager/console.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/inspection.py -+++ virt-manager-1.5.0/virtManager/inspection.py -@@ -17,8 +17,9 @@ - # MA 02110-1301 USA. - # - --from Queue import Queue -+from queue import Queue - from threading import Thread -+import functools - import logging - - from guestfs import GuestFS # pylint: disable=import-error -@@ -212,7 +213,7 @@ class vmmInspection(vmmGObject): - return 0 - else: - return -1 -- mps.sort(compare) -+ mps.sort(key=functools.cmp_to_key(compare)) - - for mp_dev in mps: - try: -@@ -263,7 +264,7 @@ class vmmInspection(vmmGObject): - data.product_name = str(product_name) - data.product_variant = str(product_variant) - data.icon = icon -- data.applications = list(apps) -+ data.applications = apps if apps is None else list(apps) - data.error = False - - return data -Index: virt-manager-1.5.0/virtManager/systray.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/systray.py -+++ virt-manager-1.5.0/virtManager/systray.py -@@ -199,13 +199,13 @@ class vmmSystray(vmmGObject): - - def repopulate_menu_list(self): - # Build sorted connection list -- connsort = self.conn_menuitems.keys() -+ connsort = list(self.conn_menuitems.keys()) - connsort.sort() - connsort.reverse() - - # Empty conn list - for child in self.systray_menu.get_children(): -- if child in self.conn_menuitems.values(): -+ if child in list(self.conn_menuitems.values()): - self.systray_menu.remove(child) - - # Build sorted conn list -@@ -265,7 +265,7 @@ class vmmSystray(vmmGObject): - for vm in conn.list_vms(): - vm_mappings[vm.get_name()] = vm.get_connkey() - -- vm_names = vm_mappings.keys() -+ vm_names = list(vm_mappings.keys()) - vm_names.sort() - - if len(vm_names) == 0: -Index: virt-manager-1.5.0/virtManager/console.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/console.py -+++ virt-manager-1.5.0/virtManager/console.py -@@ -35,7 +35,7 @@ from .viewers import SpiceViewer, VNCVie +--- virt-manager-2.0.0.orig/virtManager/console.py ++++ virt-manager-2.0.0/virtManager/console.py +@@ -21,7 +21,7 @@ from .viewers import SpiceViewer, VNCVie (_CONSOLE_PAGE_UNAVAILABLE, _CONSOLE_PAGE_AUTHENTICATE, _CONSOLE_PAGE_SERIAL, @@ -105,11 +37,11 @@ Index: virt-manager-1.5.0/virtManager/console.py class _TimedRevealer(vmmGObject): -Index: virt-manager-1.5.0/virtManager/connection.py +Index: virt-manager-2.0.0/virtManager/connection.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/connection.py -+++ virt-manager-1.5.0/virtManager/connection.py -@@ -198,7 +198,7 @@ class vmmConnection(vmmGObject): +--- virt-manager-2.0.0.orig/virtManager/connection.py ++++ virt-manager-2.0.0/virtManager/connection.py +@@ -165,7 +165,7 @@ class vmmConnection(vmmGObject): (_STATE_DISCONNECTED, _STATE_CONNECTING, @@ -117,53 +49,12 @@ Index: virt-manager-1.5.0/virtManager/connection.py + _STATE_ACTIVE) = list(range(1, 4)) def __init__(self, uri): - vmmGObject.__init__(self) -@@ -1215,35 +1215,35 @@ class vmmConnection(vmmGObject): - def _update_nets(self, dopoll): - keymap = dict((o.get_connkey(), o) for o in self.list_nets()) - if not dopoll or not self.is_network_capable(): -- return [], [], keymap.values() -+ return [], [], list(keymap.values()) - return pollhelpers.fetch_nets(self._backend, keymap, - (lambda obj, key: vmmNetwork(self, obj, key))) - - def _update_pools(self, dopoll): - keymap = dict((o.get_connkey(), o) for o in self.list_pools()) - if not dopoll or not self.is_storage_capable(): -- return [], [], keymap.values() -+ return [], [], list(keymap.values()) - return pollhelpers.fetch_pools(self._backend, keymap, - (lambda obj, key: vmmStoragePool(self, obj, key))) - - def _update_interfaces(self, dopoll): - keymap = dict((o.get_connkey(), o) for o in self.list_interfaces()) - if not dopoll or not self.is_interface_capable(): -- return [], [], keymap.values() -+ return [], [], list(keymap.values()) - return pollhelpers.fetch_interfaces(self._backend, keymap, - (lambda obj, key: vmmInterface(self, obj, key))) - - def _update_nodedevs(self, dopoll): - keymap = dict((o.get_connkey(), o) for o in self.list_nodedevs()) - if not dopoll or not self.is_nodedev_capable(): -- return [], [], keymap.values() -+ return [], [], list(keymap.values()) - return pollhelpers.fetch_nodedevs(self._backend, keymap, - (lambda obj, key: vmmNodeDevice(self, obj, key))) - - def _update_vms(self, dopoll): - keymap = dict((o.get_connkey(), o) for o in self.list_vms()) - if not dopoll: -- return [], [], keymap.values() -+ return [], [], list(keymap.values()) - return pollhelpers.fetch_vms(self._backend, keymap, - (lambda obj, key: vmmDomain(self, obj, key))) - -Index: virt-manager-1.5.0/virtManager/addhardware.py + self._uri = uri +Index: virt-manager-2.0.0/virtManager/addhardware.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/addhardware.py -+++ virt-manager-1.5.0/virtManager/addhardware.py -@@ -57,7 +57,7 @@ from .addstorage import vmmAddStorage +--- virt-manager-2.0.0.orig/virtManager/addhardware.py ++++ virt-manager-2.0.0/virtManager/addhardware.py +@@ -41,7 +41,7 @@ from .addstorage import vmmAddStorage PAGE_USBREDIR, PAGE_TPM, PAGE_RNG, @@ -171,9 +62,9 @@ Index: virt-manager-1.5.0/virtManager/addhardware.py + PAGE_PANIC) = list(range(0, 17)) - class vmmAddHardware(vmmGObjectUI): -@@ -1164,7 +1164,7 @@ class vmmAddHardware(vmmGObjectUI): - self._dev = VirtualTPMDevice(self.conn.get_backend()) + def _build_combo(combo, values, default_value=None, sort=True): +@@ -877,7 +877,7 @@ class vmmAddHardware(vmmGObjectUI): + self._dev = DeviceTpm(self.conn.get_backend()) self._dev.type = devtype - for param_name, widget_name in tpm_widget_mappings.items(): @@ -181,84 +72,11 @@ Index: virt-manager-1.5.0/virtManager/addhardware.py make_visible = self._dev.supports_property(param_name) uiutil.set_grid_row_visible(self.widget(widget_name + "-label"), make_visible) -@@ -1218,7 +1218,7 @@ class vmmAddHardware(vmmGObjectUI): - self._dev = char_class(self.conn.get_backend()) - self._dev.type = devtype - -- for param_name, widget_name in char_widget_mappings.items(): -+ for param_name, widget_name in list(char_widget_mappings.items()): - make_visible = self._dev.supports_property(param_name) - uiutil.set_grid_row_visible(self.widget(widget_name + "-label"), - make_visible) -@@ -1671,7 +1671,7 @@ class vmmAddHardware(vmmGObjectUI): - try: - self._dev = devclass - -- for param_name, val in value_mappings.items(): -+ for param_name, val in list(value_mappings.items()): - if self._dev.supports_property(param_name) and val is not None: - setattr(self._dev, param_name, val) - -@@ -1752,7 +1752,7 @@ class vmmAddHardware(vmmGObjectUI): - try: - self._dev = VirtualTPMDevice(conn) - self._dev.type = typ -- for param_name, val in value_mappings.items(): -+ for param_name, val in list(value_mappings.items()): - if self._dev.supports_property(param_name): - setattr(self._dev, param_name, val) - except Exception as e: -@@ -1856,7 +1856,7 @@ class vmmAddHardware(vmmGObjectUI): - try: - self._dev = virtinst.VirtualRNGDevice(self.conn.get_backend()) - self._dev.type = rtype -- for param_name, val in value_mappings.items(): -+ for param_name, val in list(value_mappings.items()): - if self._dev.supports_property(param_name): - setattr(self._dev, param_name, val) - except Exception as e: -Index: virt-manager-1.5.0/virtManager/createinterface.py +Index: virt-manager-2.0.0/virtManager/snapshots.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/createinterface.py -+++ virt-manager-1.5.0/virtManager/createinterface.py -@@ -387,7 +387,7 @@ class vmmCreateInterface(vmmGObjectUI): - Interface.INTERFACE_TYPE_VLAN: "vlan", - } - -- for key, value in type_dict.items(): -+ for key, value in list(type_dict.items()): - do_show = (key == itype) - self.widget("%s-label" % value).set_visible(do_show) - self.widget("%s-box" % value).set_visible(do_show) -@@ -544,7 +544,7 @@ class vmmCreateInterface(vmmGObjectUI): - active, None, iface.get_mac()] - row_dict[name] = row - -- for name, row in nodedevs.items(): -+ for name, row in list(nodedevs.items()): - try: - key = Interface(self.conn.get_backend()) - key.type = Interface.INTERFACE_TYPE_ETHERNET -@@ -556,12 +556,12 @@ class vmmCreateInterface(vmmGObjectUI): - row[INTERFACE_ROW_KEY] = key - row_dict[name] = row - -- for row in row_dict.values(): -+ for row in list(row_dict.values()): - name = row[INTERFACE_ROW_NAME] - row[INTERFACE_ROW_IN_USE_BY] = self.iface_in_use_by(self.conn, - name) - -- for row in row_dict.values(): -+ for row in list(row_dict.values()): - model.append(row) - - def get_default_name(self): -Index: virt-manager-1.5.0/virtManager/snapshots.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/snapshots.py -+++ virt-manager-1.5.0/virtManager/snapshots.py -@@ -44,7 +44,7 @@ mimemap = { +--- virt-manager-2.0.0.orig/virtManager/snapshots.py ++++ virt-manager-2.0.0/virtManager/snapshots.py +@@ -30,7 +30,7 @@ mimemap = { def _mime_to_ext(val, reverse=False): @@ -267,250 +85,37 @@ Index: virt-manager-1.5.0/virtManager/snapshots.py if val == m and not reverse: return e if val == e and reverse: -@@ -507,7 +507,7 @@ class vmmSnapshotPage(vmmGObjectUI): - basesn = os.path.join(cachedir, "snap-screenshot-%s" % name) - - # Remove any pre-existing screenshots so we don't show stale data -- for ext in mimemap.values(): -+ for ext in list(mimemap.values()): - p = basesn + "." + ext - if os.path.exists(basesn + "." + ext): - os.unlink(p) -Index: virt-manager-1.5.0/virtManager/graphwidgets.py +Index: virt-manager-2.0.0/virtManager/engine.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/graphwidgets.py -+++ virt-manager-1.5.0/virtManager/graphwidgets.py -@@ -25,8 +25,8 @@ from gi.repository import Gtk - - def rect_print(name, rect): - # For debugging -- print("%s: height=%d, width=%d, x=%d, y=%d" % -- (name, rect.height, rect.width, rect.x, rect.y)) -+ print(("%s: height=%d, width=%d, x=%d, y=%d" % -+ (name, rect.height, rect.width, rect.x, rect.y))) - - - def _line_helper(cairo_ct, x, y, w, h, points, for_fill=False): -Index: virt-manager-1.5.0/virtManager/host.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/host.py -+++ virt-manager-1.5.0/virtManager/host.py -@@ -43,11 +43,11 @@ EDIT_NET_IDS = ( - EDIT_NET_NAME, - EDIT_NET_AUTOSTART, - EDIT_NET_QOS, --) = range(3) -+) = list(range(3)) - - EDIT_INTERFACE_IDS = ( - EDIT_INTERFACE_STARTMODE, --) = range(200, 201) -+) = list(range(200, 201)) - - - class vmmHost(vmmGObjectUI): -Index: virt-manager-1.5.0/virtManager/sshtunnels.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/sshtunnels.py -+++ virt-manager-1.5.0/virtManager/sshtunnels.py -@@ -20,7 +20,7 @@ - import functools - import logging - import os --import Queue -+import queue - import socket - import signal - import threading -@@ -125,7 +125,7 @@ class _TunnelScheduler(object): - """ - def __init__(self): - self._thread = None -- self._queue = Queue.Queue() -+ self._queue = queue.Queue() - self._lock = threading.Lock() - - def _handle_queue(self): -Index: virt-manager-1.5.0/virtManager/engine.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/engine.py -+++ virt-manager-1.5.0/virtManager/engine.py -@@ -20,7 +20,7 @@ - - import logging - import re --import Queue -+import queue - import threading - import traceback - -@@ -60,7 +60,7 @@ DETAILS_CONFIG = 2 - DETAILS_CONSOLE = 3 +--- virt-manager-2.0.0.orig/virtManager/engine.py ++++ virt-manager-2.0.0/virtManager/engine.py +@@ -21,7 +21,7 @@ from .inspection import vmmInspection + from .systray import vmmSystray (PRIO_HIGH, - PRIO_LOW) = range(1, 3) + PRIO_LOW) = list(range(1, 3)) - class vmmEngine(vmmGObject): -@@ -105,7 +105,7 @@ class vmmEngine(vmmGObject): - target=self._handle_tick_queue, - args=()) - self._tick_thread.daemon = True -- self._tick_queue = Queue.PriorityQueue(100) -+ self._tick_queue = queue.PriorityQueue(100) - - self.inspection = None - self._create_inspection_thread() -@@ -154,7 +154,7 @@ class vmmEngine(vmmGObject): - self._application.add_action(action) - - def _default_startup(self, skip_autostart, cliuri): -- uris = self.conns.keys() -+ uris = list(self.conns.keys()) - if not uris: - logging.debug("No stored URIs found.") - else: -@@ -282,15 +282,15 @@ class vmmEngine(vmmGObject): - """ - We serialize conn autostart, so polkit/ssh-askpass doesn't spam - """ -- queue = Queue.Queue() -+ local_queue = queue.Queue() - auto_conns = [uri for uri in self.conns - if self.conns[uri]["conn"].get_autoconnect()] - - def add_next_to_queue(): - if not auto_conns: -- queue.put(None) -+ local_queue.put(None) - else: -- queue.put(auto_conns.pop(0)) -+ local_queue.put(auto_conns.pop(0)) - - def state_change_cb(conn): - if conn.is_active(): -@@ -302,7 +302,7 @@ class vmmEngine(vmmGObject): - - def handle_queue(): - while True: -- uri = queue.get() -+ uri = local_queue.get() - if uri is None: - return - if uri not in self.conns: -@@ -339,7 +339,7 @@ class vmmEngine(vmmGObject): - - hvuri = conn.get_uri() - -- for connkey in self.conns[hvuri]["windowDetails"].keys(): -+ for connkey in list(self.conns[hvuri]["windowDetails"].keys()): - self.conns[hvuri]["windowDetails"][connkey].cleanup() - del(self.conns[hvuri]["windowDetails"][connkey]) - -@@ -524,10 +524,10 @@ class vmmEngine(vmmGObject): - focus, and use that - """ - windowlist = [self.windowManager] -- for conndict in self.conns.values(): -- windowlist.extend(conndict["windowDetails"].values()) -+ for conndict in list(self.conns.values()): -+ windowlist.extend(list(conndict["windowDetails"].values())) - windowlist.extend( -- [conndict["windowHost"] for conndict in self.conns.values()]) -+ [conndict["windowHost"] for conndict in list(self.conns.values())]) - - use_win = None - for window in windowlist: -@@ -603,7 +603,7 @@ class vmmEngine(vmmGObject): - self.conns[uri]["windowClone"].cleanup() - - details = self.conns[uri]["windowDetails"] -- for win in details.values(): -+ for win in list(details.values()): - win.cleanup() - - self.conns[uri]["conn"].cleanup() -@@ -623,7 +623,7 @@ class vmmEngine(vmmGObject): - handle_id = vmmGObject.connect(self, name, callback, *args) - - if name == "conn-added": -- for conn_dict in self.conns.values(): -+ for conn_dict in list(self.conns.values()): - self.emit("conn-added", conn_dict["conn"]) - - return handle_id -@@ -773,7 +773,7 @@ class vmmEngine(vmmGObject): - return self.connect_to_uri(uri, autoconnect, probe=True) - - def cancelled(src): -- if len(self.conns.keys()) == 0: -+ if len(list(self.conns.keys())) == 0: - self.exit_app(src) - - obj = vmmConnect() -Index: virt-manager-1.5.0/virtManager/mediacombo.py + def _show_startup_error(fn): +Index: virt-manager-2.0.0/virtManager/mediacombo.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/mediacombo.py -+++ virt-manager-1.5.0/virtManager/mediacombo.py -@@ -33,7 +33,7 @@ class vmmMediaCombo(vmmGObjectUI): - (OPTICAL_DEV_PATH, - OPTICAL_LABEL, - OPTICAL_HAS_MEDIA, -- OPTICAL_DEV_KEY) = range(OPTICAL_FIELDS) -+ OPTICAL_DEV_KEY) = list(range(OPTICAL_FIELDS)) +--- virt-manager-2.0.0.orig/virtManager/mediacombo.py ++++ virt-manager-2.0.0/virtManager/mediacombo.py +@@ -22,7 +22,7 @@ class vmmMediaCombo(vmmGObjectUI): + (MEDIA_FIELD_PATH, + MEDIA_FIELD_LABEL, + MEDIA_FIELD_HAS_MEDIA, +- MEDIA_FIELD_KEY) = range(MEDIA_FIELDS_NUM) ++ MEDIA_FIELD_KEY) = list(range(MEDIA_FIELDS_NUM)) - def __init__(self, conn, builder, topwin, media_type): + def __init__(self, conn, builder, topwin): vmmGObjectUI.__init__(self, None, None, builder=builder, topwin=topwin) -Index: virt-manager-1.5.0/virtManager/clone.py +Index: virt-manager-2.0.0/virtManager/manager.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/clone.py -+++ virt-manager-1.5.0/virtManager/clone.py -@@ -336,7 +336,7 @@ class vmmCloneVM(vmmGObjectUI): - - build_net_row(label, mac, newmac) - -- no_net = bool(len(self.net_list.keys()) == 0) -+ no_net = bool(len(list(self.net_list.keys())) == 0) - self.widget("clone-network-box").set_visible(not no_net) - self.widget("clone-no-net").set_visible(no_net) - -@@ -460,7 +460,7 @@ class vmmCloneVM(vmmGObjectUI): - if cd.clone_name == newname: - return - -- for row in self.storage_list.values(): -+ for row in list(self.storage_list.values()): - origpath = row[STORAGE_INFO_ORIG_PATH] - if row[STORAGE_INFO_MANUAL_PATH]: - continue -@@ -599,7 +599,7 @@ class vmmCloneVM(vmmGObjectUI): - # If any storage cannot be cloned or shared, don't allow cloning - clone = True - tooltip = "" -- for row in self.storage_list.values(): -+ for row in list(self.storage_list.values()): - can_clone = row[STORAGE_INFO_CAN_CLONE] - can_share = row[STORAGE_INFO_CAN_SHARE] - if not (can_clone or can_share): -Index: virt-manager-1.5.0/virtManager/netlist.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/netlist.py -+++ virt-manager-1.5.0/virtManager/netlist.py -@@ -197,7 +197,7 @@ class vmmNetworkList(vmmGObjectUI): - for slave in slave_names: - netdevs.pop(slave, None) - -- for name, is_bridge, slave_names in netdevs.values(): -+ for name, is_bridge, slave_names in list(netdevs.values()): - if ((name in vnet_taps) or - (name in [v + "-nic" for v in vnet_bridges]) or - (name in skip_ifaces)): -Index: virt-manager-1.5.0/virtManager/manager.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/manager.py -+++ virt-manager-1.5.0/virtManager/manager.py -@@ -48,7 +48,7 @@ ROW_IS_CONN_CONNECTED, +--- virt-manager-2.0.0.orig/virtManager/manager.py ++++ virt-manager-2.0.0/virtManager/manager.py +@@ -36,7 +36,7 @@ ROW_IS_CONN_CONNECTED, ROW_IS_VM, ROW_IS_VM_RUNNING, ROW_COLOR, @@ -519,7 +124,7 @@ Index: virt-manager-1.5.0/virtManager/manager.py # Columns in the tree view (COL_NAME, -@@ -56,7 +56,7 @@ COL_GUEST_CPU, +@@ -44,7 +44,7 @@ COL_GUEST_CPU, COL_HOST_CPU, COL_MEM, COL_DISK, @@ -528,28 +133,11 @@ Index: virt-manager-1.5.0/virtManager/manager.py def _style_get_prop(widget, propname): -Index: virt-manager-1.5.0/virtManager/keyring.py +Index: virt-manager-2.0.0/virtManager/addstorage.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/keyring.py -+++ virt-manager-1.5.0/virtManager/keyring.py -@@ -110,10 +110,10 @@ class vmmKeyring(object): - label = iface.get_cached_property("Label").unpack().strip("'") - dbusattrs = iface.get_cached_property("Attributes").unpack() - -- secret = u"".join([unichr(c) for c in secretbytes]) -+ secret = "".join([chr(c) for c in secretbytes]) - - attrs = {} -- for key, val in dbusattrs.items(): -+ for key, val in list(dbusattrs.items()): - if key not in ["hvuri", "uuid"]: - continue - attrs["%s" % key] = "%s" % val -Index: virt-manager-1.5.0/virtManager/addstorage.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/addstorage.py -+++ virt-manager-1.5.0/virtManager/addstorage.py -@@ -162,7 +162,7 @@ class vmmAddStorage(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/addstorage.py ++++ virt-manager-2.0.0/virtManager/addstorage.py +@@ -148,7 +148,7 @@ class vmmAddStorage(vmmGObjectUI): errmsg = _("Errors were encountered changing permissions for the " "following directories:") details = "" @@ -558,29 +146,20 @@ Index: virt-manager-1.5.0/virtManager/addstorage.py if p not in broken_paths: continue details += "%s : %s\n" % (p, error) -@@ -174,7 +174,7 @@ class vmmAddStorage(vmmGObjectUI): - _("Don't ask about these directories again.")) - - if chkres: -- src.config.add_perms_fix_ignore(errors.keys()) -+ src.config.add_perms_fix_ignore(list(errors.keys())) - - def reset_state(self): - self._update_host_space() -Index: virt-manager-1.5.0/virtManager/details.py +Index: virt-manager-2.0.0/virtManager/details.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/details.py -+++ virt-manager-1.5.0/virtManager/details.py -@@ -106,7 +106,7 @@ from .graphwidgets import Sparkline +--- virt-manager-2.0.0.orig/virtManager/details.py ++++ virt-manager-2.0.0/virtManager/details.py +@@ -101,7 +101,7 @@ from .storagebrowse import vmmStorageBro EDIT_FS, -- EDIT_HOSTDEV_ROMBAR) = range(1, 49) -+ EDIT_HOSTDEV_ROMBAR) = list(range(1, 49)) +- EDIT_HOSTDEV_ROMBAR) = range(1, 56) ++ EDIT_HOSTDEV_ROMBAR) = list(range(1, 56)) # Columns in hw list model -@@ -114,7 +114,7 @@ from .graphwidgets import Sparkline +@@ -109,7 +109,7 @@ from .storagebrowse import vmmStorageBro HW_LIST_COL_ICON_NAME, HW_LIST_COL_ICON_SIZE, HW_LIST_COL_TYPE, @@ -589,7 +168,7 @@ Index: virt-manager-1.5.0/virtManager/details.py # Types for the hw list model: numbers specify what order they will be listed (HW_LIST_TYPE_GENERAL, -@@ -138,7 +138,7 @@ from .graphwidgets import Sparkline +@@ -133,7 +133,7 @@ from .storagebrowse import vmmStorageBro HW_LIST_TYPE_REDIRDEV, HW_LIST_TYPE_TPM, HW_LIST_TYPE_RNG, @@ -598,7 +177,7 @@ Index: virt-manager-1.5.0/virtManager/details.py remove_pages = [HW_LIST_TYPE_NIC, HW_LIST_TYPE_INPUT, HW_LIST_TYPE_GRAPHICS, HW_LIST_TYPE_SOUND, HW_LIST_TYPE_CHAR, -@@ -153,12 +153,12 @@ remove_pages = [HW_LIST_TYPE_NIC, HW_LIS +@@ -148,12 +148,12 @@ remove_pages = [HW_LIST_TYPE_NIC, HW_LIS BOOT_LABEL, BOOT_ICON, BOOT_ACTIVE, @@ -611,49 +190,13 @@ Index: virt-manager-1.5.0/virtManager/details.py - DETAILS_PAGE_SNAPSHOTS) = range(3) + DETAILS_PAGE_SNAPSHOTS) = list(range(3)) - _remove_tooltip = _("Remove this device from the virtual machine") -@@ -744,7 +744,7 @@ class vmmDetails(vmmGObjectUI): - rmHW.connect("activate", self.remove_xml_dev) - self._addhwmenuitems = {"add": addHW, "remove": rmHW} -- for i in self._addhwmenuitems.values(): -+ for i in list(self._addhwmenuitems.values()): - self.addhwmenu.add(i) - - self.widget("hw-panel").set_show_tabs(False) -@@ -1519,7 +1519,7 @@ class vmmDetails(vmmGObjectUI): - 'tEXt::Generator Version': self.config.get_appversion(), - } - -- ret = image.save_to_bufferv('png', metadata.keys(), metadata.values()) -+ ret = image.save_to_bufferv('png', list(metadata.keys()), list(metadata.values())) - # On Fedora 19, ret is (bool, str) - # Someday the bindings might be fixed to just return the str, try - # and future proof it a bit -@@ -2835,7 +2835,7 @@ class vmmDetails(vmmGObjectUI): - set_visible("rng-bind-host", is_egd and (udp or bind)) - set_visible("rng-bind-service", is_egd and (udp or bind)) - -- for k, prop in values.items(): -+ for k, prop in list(values.items()): - val = "-" - if dev.supports_property(prop): - val = getattr(dev, prop) or "-" -@@ -3229,7 +3229,7 @@ class vmmDetails(vmmGObjectUI): - for dev in self.vm.get_panic_devices(): - update_hwlist(HW_LIST_TYPE_PANIC, dev) - -- devs = range(len(hw_list_model)) -+ devs = list(range(len(hw_list_model))) - devs.reverse() - for i in devs: - _iter = hw_list_model.iter_nth_child(None, i) -Index: virt-manager-1.5.0/virtManager/create.py +Index: virt-manager-2.0.0/virtManager/create.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/create.py -+++ virt-manager-1.5.0/virtManager/create.py -@@ -55,7 +55,7 @@ DEFAULT_MEM = 1024 +--- virt-manager-2.0.0.orig/virtManager/create.py ++++ virt-manager-2.0.0/virtManager/create.py +@@ -43,7 +43,7 @@ DEFAULT_MEM = 1024 PAGE_INSTALL, PAGE_MEM, PAGE_STORAGE, @@ -662,7 +205,7 @@ Index: virt-manager-1.5.0/virtManager/create.py (INSTALL_PAGE_ISO, INSTALL_PAGE_URL, -@@ -63,13 +63,13 @@ DEFAULT_MEM = 1024 +@@ -51,13 +51,13 @@ DEFAULT_MEM = 1024 INSTALL_PAGE_IMPORT, INSTALL_PAGE_CONTAINER_APP, INSTALL_PAGE_CONTAINER_OS, @@ -678,16 +221,7 @@ Index: virt-manager-1.5.0/virtManager/create.py ##################### -@@ -953,7 +953,7 @@ class vmmCreate(vmmGObjectUI): - model.clear() - - default = -1 -- for c in self.engine.conns.values(): -+ for c in list(self.engine.conns.values()): - connobj = c["conn"] - if not connobj.is_active(): - continue -@@ -2587,7 +2587,7 @@ class vmmCreate(vmmGObjectUI): +@@ -2153,7 +2153,7 @@ class vmmCreate(vmmGObjectUI): 'insecure': self._get_config_oscontainer_isecure, 'root_password': self._get_config_oscontainer_root_password, } @@ -696,11 +230,11 @@ Index: virt-manager-1.5.0/virtManager/create.py bootstrap_args[key] = getter() parentobj = self._customize_window or self -Index: virt-manager-1.5.0/virtManager/preferences.py +Index: virt-manager-2.0.0/virtManager/preferences.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/preferences.py -+++ virt-manager-1.5.0/virtManager/preferences.py -@@ -121,7 +121,7 @@ class vmmPreferences(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/preferences.py ++++ virt-manager-2.0.0/virtManager/preferences.py +@@ -127,7 +127,7 @@ class vmmPreferences(vmmGObjectUI): } model.append([-1, _("System default (%s)") % vals[self.config.default_console_resizeguest]]) @@ -709,11 +243,11 @@ Index: virt-manager-1.5.0/virtManager/preferences.py model.append([key, val]) combo.set_model(model) uiutil.init_combo_text_column(combo, 1) -Index: virt-manager-1.5.0/virtManager/migrate.py +Index: virt-manager-2.0.0/virtManager/migrate.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/migrate.py -+++ virt-manager-1.5.0/virtManager/migrate.py -@@ -36,7 +36,7 @@ from .domain import vmmDomain +--- virt-manager-2.0.0.orig/virtManager/migrate.py ++++ virt-manager-2.0.0/virtManager/migrate.py +@@ -23,7 +23,7 @@ from .domain import vmmDomain NUM_COLS = 3 (COL_LABEL, COL_URI, @@ -722,74 +256,11 @@ Index: virt-manager-1.5.0/virtManager/migrate.py class vmmMigrateDialog(vmmGObjectUI): -@@ -313,7 +313,7 @@ class vmmMigrateDialog(vmmGObjectUI): - model.clear() - - rows = [] -- for conn in self._conns.values(): -+ for conn in list(self._conns.values()): - rows.append(self._build_dest_row(conn)) - - if not any([row[COL_CAN_MIGRATE] for row in rows]): -Index: virt-manager-1.5.0/virtManager/connect.py +Index: virt-manager-2.0.0/virtManager/storagelist.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/connect.py -+++ virt-manager-1.5.0/virtManager/connect.py -@@ -22,7 +22,7 @@ import glob - import os - import logging - import socket --import urllib -+import urllib.request, urllib.parse, urllib.error - - from gi.repository import Gio - from gi.repository import GObject -@@ -37,11 +37,11 @@ HV_LXC, - HV_QEMU_SESSION, - HV_BHYVE, - HV_VZ, --HV_CUSTOM) = range(7) -+HV_CUSTOM) = list(range(7)) - - (CONN_SSH, - CONN_TCP, --CONN_TLS) = range(3) -+CONN_TLS) = list(range(3)) - - - def current_user(): -@@ -409,7 +409,7 @@ class vmmConnect(vmmGObjectUI): - - addrstr = "" - if user: -- addrstr += urllib.quote(user) + "@" -+ addrstr += urllib.parse.quote(user) + "@" - - if host.count(":") > 1: - host = "[%s]" % host -@@ -467,7 +467,7 @@ class vmmConnect(vmmGObjectUI): - if host.startswith("linux-"): - tmphost = host[6:] - try: -- long(tmphost) -+ int(tmphost) - host = "" - except ValueError: - pass -Index: virt-manager-1.5.0/virtManager/storagelist.py -=================================================================== ---- virt-manager-1.5.0.orig/virtManager/storagelist.py -+++ virt-manager-1.5.0/virtManager/storagelist.py -@@ -36,7 +36,7 @@ from .createvol import vmmCreateVolume - EDIT_POOL_IDS = ( - EDIT_POOL_NAME, - EDIT_POOL_AUTOSTART, --) = range(2) -+) = list(range(2)) - - VOL_NUM_COLUMNS = 7 - (VOL_COLUMN_KEY, -@@ -45,13 +45,13 @@ VOL_NUM_COLUMNS = 7 +--- virt-manager-2.0.0.orig/virtManager/storagelist.py ++++ virt-manager-2.0.0/virtManager/storagelist.py +@@ -30,13 +30,13 @@ VOL_NUM_COLUMNS = 7 VOL_COLUMN_SIZESTR, VOL_COLUMN_FORMAT, VOL_COLUMN_INUSEBY, @@ -805,11 +276,11 @@ Index: virt-manager-1.5.0/virtManager/storagelist.py ICON_RUNNING = "state_running" ICON_SHUTOFF = "state_shutoff" -Index: virt-manager-1.5.0/virtManager/createnet.py +Index: virt-manager-2.0.0/virtManager/createnet.py =================================================================== ---- virt-manager-1.5.0.orig/virtManager/createnet.py -+++ virt-manager-1.5.0/virtManager/createnet.py -@@ -35,7 +35,7 @@ from .baseclass import vmmGObjectUI +--- virt-manager-2.0.0.orig/virtManager/createnet.py ++++ virt-manager-2.0.0/virtManager/createnet.py +@@ -20,7 +20,7 @@ from .baseclass import vmmGObjectUI (PAGE_NAME, PAGE_IPV4, PAGE_IPV6, diff --git a/virtman-register-delete-event-for-details-dialog.patch b/virtman-register-delete-event-for-details-dialog.patch index 25ff168d..b5ffa856 100644 --- a/virtman-register-delete-event-for-details-dialog.patch +++ b/virtman-register-delete-event-for-details-dialog.patch @@ -6,11 +6,11 @@ it is not recognized as a top level dialog on python3 and therefore we explicitl need to set the connection event. Not getting the event to cleanup leaves us in a bad state for when the details dialog is reopened. -Index: virt-manager-1.4.3/virtManager/details.py +Index: virt-manager-2.0.0/virtManager/details.py =================================================================== ---- virt-manager-1.4.3.orig/virtManager/details.py -+++ virt-manager-1.4.3/virtManager/details.py -@@ -596,6 +596,9 @@ class vmmDetails(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/details.py ++++ virt-manager-2.0.0/virtManager/details.py +@@ -621,6 +621,9 @@ class vmmDetails(vmmGObjectUI): self.console.details_auth_login), }) diff --git a/virtman-show-suse-install-repos.patch b/virtman-show-suse-install-repos.patch index 191eeec2..5976d047 100644 --- a/virtman-show-suse-install-repos.patch +++ b/virtman-show-suse-install-repos.patch @@ -1,11 +1,11 @@ Enhancement that gets installation repos from zypper. These locations are then presented as potential installation sources when creating a VM. -Index: virt-manager-1.5.1/virtManager/create.py +Index: virt-manager-2.0.0/virtManager/create.py =================================================================== ---- virt-manager-1.5.1.orig/virtManager/create.py -+++ virt-manager-1.5.1/virtManager/create.py -@@ -424,7 +424,13 @@ class vmmCreate(vmmGObjectUI): +--- virt-manager-2.0.0.orig/virtManager/create.py ++++ virt-manager-2.0.0/virtManager/create.py +@@ -371,7 +371,13 @@ class vmmCreate(vmmGObjectUI): self.widget("install-url-entry").set_text("") self.widget("install-url-options").set_expanded(False) urlmodel = self.widget("install-url-combo").get_model() @@ -17,14 +17,14 @@ Index: virt-manager-1.5.1/virtManager/create.py + inst_repos.remove(u) + media_urllist = urllist + inst_repos + _populate_media_model(urlmodel, media_urllist) - self._set_distro_labels("-", "-") # Install import -Index: virt-manager-1.5.1/virtinst/util.py + self.widget("install-import-entry").set_text("") +Index: virt-manager-2.0.0/virtinst/util.py =================================================================== ---- virt-manager-1.5.1.orig/virtinst/util.py -+++ virt-manager-1.5.1/virtinst/util.py -@@ -23,9 +23,12 @@ import os +--- virt-manager-2.0.0.orig/virtinst/util.py ++++ virt-manager-2.0.0/virtinst/util.py +@@ -11,9 +11,12 @@ import os import random import re import sys @@ -37,7 +37,7 @@ Index: virt-manager-1.5.1/virtinst/util.py def listify(l): if l is None: -@@ -312,3 +315,57 @@ def make_meter(quiet): +@@ -292,3 +295,57 @@ def make_meter(quiet): if quiet: return progress.BaseMeter() return progress.TextMeter(fo=sys.stdout) diff --git a/virtmisc-python2-to-python3-conversion.patch b/virtmisc-python2-to-python3-conversion.patch deleted file mode 100644 index 4972e505..00000000 --- a/virtmisc-python2-to-python3-conversion.patch +++ /dev/null @@ -1,20 +0,0 @@ -Index: virt-manager-1.4.3/virt-clone -=================================================================== ---- virt-manager-1.4.3.orig/virt-clone -+++ virt-manager-1.4.3/virt-clone -@@ -1,4 +1,4 @@ --#!/usr/bin/env python2 -+#!/usr/bin/python3 - # - # Copyright(c) FUJITSU Limited 2007. - # -Index: virt-manager-1.4.3/virt-xml -=================================================================== ---- virt-manager-1.4.3.orig/virt-xml -+++ virt-manager-1.4.3/virt-xml -@@ -1,4 +1,4 @@ --#!/usr/bin/env python2 -+#!/usr/bin/python3 - # - # Copyright 2013-2014 Red Hat, Inc. - # Cole Robinson diff --git a/virttests-python2-to-python3-conversion.patch b/virttests-python2-to-python3-conversion.patch index 27f5ba67..a9fe3d91 100644 --- a/virttests-python2-to-python3-conversion.patch +++ b/virttests-python2-to-python3-conversion.patch @@ -1,111 +1,35 @@ -Index: virt-manager-1.5.0/tests/clitest.py +Index: virt-manager-2.0.0/tests/clitest.py =================================================================== ---- virt-manager-1.5.0.orig/tests/clitest.py -+++ virt-manager-1.5.0/tests/clitest.py -@@ -223,7 +223,7 @@ class Command(object): +--- virt-manager-2.0.0.orig/tests/clitest.py ++++ virt-manager-2.0.0/tests/clitest.py +@@ -176,7 +176,7 @@ class Command(object): try: conn = None - for idx in reversed(range(len(self.argv))): + for idx in reversed(list(range(len(self.argv)))): if self.argv[idx] == "--connect": - conn = utils.openconn(self.argv[idx + 1]) + conn = utils.URIs.openconn(self.argv[idx + 1]) break -Index: virt-manager-1.5.0/tests/uitests/utils.py +Index: virt-manager-2.0.0/tests/test_inject.py =================================================================== ---- virt-manager-1.5.0.orig/tests/uitests/utils.py -+++ virt-manager-1.5.0/tests/uitests/utils.py -@@ -1,4 +1,4 @@ --from __future__ import print_function -+ +--- virt-manager-2.0.0.orig/tests/test_inject.py ++++ virt-manager-2.0.0/tests/test_inject.py +@@ -15,7 +15,7 @@ FEDORA_URL = "http://dl.fedoraproject.or - import logging - import os -Index: virt-manager-1.5.0/tests/utils.py -=================================================================== ---- virt-manager-1.5.0.orig/tests/utils.py -+++ virt-manager-1.5.0/tests/utils.py -@@ -104,11 +104,11 @@ def openconn(uri): - conn.fetch_all_nodedevs() - - _conn_cache[uri] = {} -- for key, value in conn._fetch_cache.items(): -+ for key, value in list(conn._fetch_cache.items()): - _conn_cache[uri][key] = value[:] - - # Prime the internal connection cache -- for key, value in _conn_cache[uri].items(): -+ for key, value in list(_conn_cache[uri].items()): - conn._fetch_cache[key] = value[:] - - def cb_cache_new_pool(poolobj): -Index: virt-manager-1.5.0/tests/test_inject.py -=================================================================== ---- virt-manager-1.5.0.orig/tests/test_inject.py -+++ virt-manager-1.5.0/tests/test_inject.py -@@ -1,7 +1,7 @@ - #!/usr/bin/env python2 - # Copyright (C) 2013, 2014 Red Hat, Inc. - --from __future__ import print_function -+ - - import atexit - import os -@@ -30,7 +30,7 @@ FEDORA_URL = "http://dl.fedoraproject.or - - (WARN_RHEL4, - WARN_RHEL5, -- WARN_LATEST) = range(1, 4) -+ WARN_LATEST) = list(range(1, 4)) + (WARN_RHEL5, + WARN_DEBIAN, +- WARN_FEDORA) = range(1, 4) ++ WARN_FEDORA) = list(range(1, 4)) def prompt(): -@@ -186,7 +186,7 @@ def _make_tests(): +@@ -115,7 +115,7 @@ def _make_tests(): return lambda s: _test_distro(_d) idx = 0 - for dname, dobj in _alldistros.items(): + for dname, dobj in list(_alldistros.items()): idx += 1 - setattr(FetchTests, "testFetch%.3d_%s" % - (idx, dname.replace("-", "_")), _make_fetch_cb(dobj)) -Index: virt-manager-1.5.0/tests/test_urls.py -=================================================================== ---- virt-manager-1.5.0.orig/tests/test_urls.py -+++ virt-manager-1.5.0/tests/test_urls.py -@@ -253,7 +253,7 @@ def _make_tests(): - vals.get("testshortcircuit", "0") == "1") - urls[d.name] = d - -- keys = urls.keys() -+ keys = list(urls.keys()) - keys.sort() - for key in keys: - distroobj = urls[key] -Index: virt-manager-1.5.0/tests/virtconvtest.py -=================================================================== ---- virt-manager-1.5.0.orig/tests/virtconvtest.py -+++ virt-manager-1.5.0/tests/virtconvtest.py -@@ -15,7 +15,7 @@ - # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, - # MA 02110-1301 USA. - --from __future__ import print_function -+ - - import glob - import io -Index: virt-manager-1.5.0/tests/nodedev.py -=================================================================== ---- virt-manager-1.5.0.orig/tests/nodedev.py -+++ virt-manager-1.5.0/tests/nodedev.py -@@ -69,7 +69,7 @@ class TestNodeDev(unittest.TestCase): - - def _testCompare(self, devname, vals, devxml=None): - def _compare(dev, vals, root=""): -- for attr in vals.keys(): -+ for attr in list(vals.keys()): - expect = vals[attr] - actual = getattr(dev, attr) - if isinstance(expect, list): + setattr(InjectTests, "testInitrd%.3d_%s" % + (idx, dname.replace("-", "_")), _make_check_cb(dobj))