A nice progress bar when installing our long running pips/pkgs
This commit is contained in:
parent
fa09f94879
commit
5e33d025a3
@ -188,9 +188,11 @@ class PkgInstallComponent(ComponentBase):
|
|||||||
if pkgs:
|
if pkgs:
|
||||||
pkg_names = set([p['name'] for p in pkgs])
|
pkg_names = set([p['name'] for p in pkgs])
|
||||||
LOG.info("Setting up %s packages (%s)" % (len(pkg_names), ", ".join(pkg_names)))
|
LOG.info("Setting up %s packages (%s)" % (len(pkg_names), ", ".join(pkg_names)))
|
||||||
for p in pkgs:
|
with utils.progress_bar('Packages', len(pkgs)) as p_bar:
|
||||||
|
for (i, p) in enumerate(pkgs):
|
||||||
self.tracewriter.package_installed(p)
|
self.tracewriter.package_installed(p)
|
||||||
self.packager.install(p)
|
self.packager.install(p)
|
||||||
|
p_bar.update(i + 1)
|
||||||
else:
|
else:
|
||||||
LOG.info('No packages to install for %s',
|
LOG.info('No packages to install for %s',
|
||||||
self.component_name)
|
self.component_name)
|
||||||
@ -298,9 +300,11 @@ class PythonInstallComponent(PkgInstallComponent):
|
|||||||
if pips:
|
if pips:
|
||||||
pip_names = set([p['name'] for p in pips])
|
pip_names = set([p['name'] for p in pips])
|
||||||
LOG.info("Setting up %s pips (%s)", len(pip_names), ", ".join(pip_names))
|
LOG.info("Setting up %s pips (%s)", len(pip_names), ", ".join(pip_names))
|
||||||
for p in pips:
|
with utils.progress_bar('Pips', len(pips)) as p_bar:
|
||||||
|
for (i, p) in enumerate(pips):
|
||||||
self.tracewriter.pip_installed(p)
|
self.tracewriter.pip_installed(p)
|
||||||
pip.install(p, self.distro)
|
pip.install(p, self.distro)
|
||||||
|
p_bar.update(i + 1)
|
||||||
|
|
||||||
def _install_python_setups(self):
|
def _install_python_setups(self):
|
||||||
pydirs = self._get_python_directories()
|
pydirs = self._get_python_directories()
|
||||||
|
@ -17,14 +17,17 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import distutils.version
|
|
||||||
import json
|
import json
|
||||||
import netifaces
|
|
||||||
import os
|
import os
|
||||||
import random
|
import random
|
||||||
import re
|
import re
|
||||||
import socket
|
import socket
|
||||||
import sys
|
import sys
|
||||||
|
import contextlib
|
||||||
|
|
||||||
|
import distutils.version
|
||||||
|
import netifaces
|
||||||
|
import progressbar
|
||||||
import termcolor
|
import termcolor
|
||||||
|
|
||||||
from devstack import colorlog
|
from devstack import colorlog
|
||||||
@ -139,6 +142,21 @@ def to_bytes(text):
|
|||||||
return byte_val
|
return byte_val
|
||||||
|
|
||||||
|
|
||||||
|
@contextlib.contextmanager
|
||||||
|
def progress_bar(name, max_am):
|
||||||
|
widgets = [
|
||||||
|
'%s: ' % (name), progressbar.Percentage(),
|
||||||
|
' ', progressbar.Bar(),
|
||||||
|
' ', progressbar.ETA(),
|
||||||
|
]
|
||||||
|
p_bar = progressbar.ProgressBar(maxval=max_am, widgets=widgets)
|
||||||
|
p_bar.start()
|
||||||
|
try:
|
||||||
|
yield p_bar
|
||||||
|
finally:
|
||||||
|
p_bar.finish()
|
||||||
|
|
||||||
|
|
||||||
def import_module(module_name, quiet=True):
|
def import_module(module_name, quiet=True):
|
||||||
try:
|
try:
|
||||||
__import__(module_name)
|
__import__(module_name)
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
netifaces
|
netifaces
|
||||||
termcolor
|
termcolor
|
||||||
pyyaml # reading data files
|
pyyaml # reading data files
|
||||||
|
progressbar
|
||||||
|
|
||||||
# Testing
|
# Testing
|
||||||
nose # for test discovery and console feedback
|
nose # for test discovery and console feedback
|
||||||
|
Loading…
Reference in New Issue
Block a user