From 53b24707b9212e83602eb5467cab12746d678086 Mon Sep 17 00:00:00 2001 From: Philip Guyton Date: Wed, 2 Oct 2019 15:00:45 +0100 Subject: [PATCH 1/2] [openSUSE] use zypper for package installs #2071 Includes - Contextual zypper calls replace equivalent yum ones when on openSUSE. - Refactoring: including function/procedure renaming. - Include Black code syntactic reformatting. - Fix prior hard wired x86-64 file name parsing. - Add rpm import of ROCKSTOR-GPG-KEY on openSUSE systems. - Add zypper addrepo/removerepo function along side existing yum counterparts for rockstor stable and testing channels. - Use zypper up/dup respectively for general Leap/Tumbleweed update/dist-upgrade. - Use --no-recommends to zypper up/dup commands to keep footprint small. - Add user text for no version/changelog available on openSUSE. - Move prior AT initiated delay to within external script and reduce from 1 minute to 10 seconds. - Move string formatting within pkg_mgmt.py from 'c' style to string.format(). - Avoid removing RPM package managed *.pyc files from ./eggs dir prior to rockstor rpm package install/upgrade. - Make user facing update dialog/tooltip text non yum specific. - Begin pkg management unit test coverage. --- src/rockstor/smart_manager/data_collector.py | 15 +- .../static/storageadmin/js/router.js | 8 +- .../templates/storageadmin/base.html | 2 +- src/rockstor/storageadmin/views/command.py | 6 +- src/rockstor/system/pkg_mgmt.py | 460 +++++++++++------- src/rockstor/system/tests/test_pkg_mgmt.py | 333 +++++++++++++ 6 files changed, 647 insertions(+), 177 deletions(-) create mode 100644 src/rockstor/system/tests/test_pkg_mgmt.py diff --git a/src/rockstor/smart_manager/data_collector.py b/src/rockstor/smart_manager/data_collector.py index 5f4d6b58b..e8f4a4dce 100644 --- a/src/rockstor/smart_manager/data_collector.py +++ b/src/rockstor/smart_manager/data_collector.py @@ -50,7 +50,7 @@ from smart_manager.models import Service # noqa E402 from system.services import service_status # noqa E402 from cli.api_wrapper import APIWrapper # noqa E402 -from system.pkg_mgmt import (update_check, yum_check) # noqa E402 +from system.pkg_mgmt import (rockstor_pkg_update_check, pkg_update_check) # noqa E402 import distro import logging # noqa E402 logger = logging.getLogger(__name__) @@ -948,7 +948,7 @@ def update_storage_state(self): def update_check(self): - uinfo = update_check() + uinfo = rockstor_pkg_update_check() self.emit('software_update', { 'key': 'sysinfo:software_update', @@ -958,16 +958,19 @@ def update_check(self): def yum_updates(self): while self.start: - rc, packages = yum_check() + packages = pkg_update_check() data = {} - data['yum_updates'] = True if rc == 100 else False + if packages: # Non empty lists are True. + data['yum_updates'] = True + else: + data['yum_updates'] = False data['packages'] = packages self.emit('yum_updates', { 'key': 'sysinfo:yum_updates', 'data': data }) - gevent.sleep(1800) + gevent.sleep(1800) # 1800 seconds = 30 mins def on_runyum(self, sid): @@ -985,7 +988,7 @@ def launch_yum(): 'data': data }) except Exception as e: - logger.error('Unable to perform Yum Updates: %s' + logger.error('Unable to perform Package Updates: %s' % e.__str__()) self.spawn(launch_yum, sid) diff --git a/src/rockstor/storageadmin/static/storageadmin/js/router.js b/src/rockstor/storageadmin/static/storageadmin/js/router.js index ae47b0a38..5507bee95 100644 --- a/src/rockstor/storageadmin/static/storageadmin/js/router.js +++ b/src/rockstor/storageadmin/static/storageadmin/js/router.js @@ -1124,7 +1124,7 @@ $(document).ready(function() { } }; - var yum_updating = false; //global var to check if yum is updating + var yum_updating = false; //global var to check if yum/zypper are updating var displayYumUpdates = function(data) { if (typeof data.yum_updating != 'undefined' && !data.yum_updating) { console.log('closing'); @@ -1133,7 +1133,7 @@ $(document).ready(function() { } if (data.yum_updates && !yum_updating) { $('#yum-msg').fadeIn(0); - $('#yum-msg a').html(''); + $('#yum-msg a').html(''); if ($('#yum_panels').is(':empty')) { _.each(data.packages, function(pkg) { var html = ''; @@ -1162,13 +1162,13 @@ $(document).ready(function() { }; $('#yum-run').click(function(event) { - var run_update = confirm('Do you want to procede with yum updates?'); + var run_update = confirm('Do you want to proceed with these updates?'); if (run_update) { RockStorSocket.sysinfo.emit('runyum'); $('#yum_modal').modal('hide'); yum_updating = true; $('#yum_panels').empty(); - $('#yum-msg a').html(''); + $('#yum-msg a').html(''); } }); diff --git a/src/rockstor/storageadmin/templates/storageadmin/base.html b/src/rockstor/storageadmin/templates/storageadmin/base.html index 9e48c9274..cc0b9de38 100644 --- a/src/rockstor/storageadmin/templates/storageadmin/base.html +++ b/src/rockstor/storageadmin/templates/storageadmin/base.html @@ -203,7 +203,7 @@