Merge remote-tracking branch 'qubesos/pr/51' into core3-devel

* qubesos/pr/51:
  Make pylint happy ♥ qubes.storage.lvm
  Fix lvm AppVM startup from lvm
  qubes.storage.lvm.qubes_lvm use debug not info
  Fix qvm-create lvm based AppVM
  qvm-block & qvm-pool add better Exception handling
  Remove unexpected property
  qvm-start --debug don't catch exceptions
This commit is contained in:
Marek Marczykowski-Górecki 2016-09-04 21:02:19 +02:00
commit 6cb624daf3
No known key found for this signature in database
GPG Key ID: 063938BA42CFA724
5 changed files with 34 additions and 12 deletions

View File

@ -43,7 +43,7 @@ class ThinPool(qubes.storage.Pool):
self.log = logging.getLogger('qube.storage.lvm.%s' % self._pool_id) self.log = logging.getLogger('qube.storage.lvm.%s' % self._pool_id)
def clone(self, source, target): def clone(self, source, target):
cmd = ['clone', source.vid, target.vid] cmd = ['clone', str(source), str(target)]
qubes_lvm(cmd, self.log) qubes_lvm(cmd, self.log)
return target return target
@ -217,8 +217,10 @@ class ThinPool(qubes.storage.Pool):
def stop(self, volume): def stop(self, volume):
if volume.save_on_stop: if volume.save_on_stop:
self._commit(volume) self._commit(volume)
if volume._is_snapshot:
if volume._is_volatile: cmd = ['remove', volume._vid_snap]
qubes_lvm(cmd, self.log)
elif volume._is_volatile:
cmd = ['remove', volume.vid] cmd = ['remove', volume.vid]
qubes_lvm(cmd, self.log) qubes_lvm(cmd, self.log)
else: else:
@ -227,6 +229,12 @@ class ThinPool(qubes.storage.Pool):
return volume return volume
def _snapshot(self, volume): def _snapshot(self, volume):
try:
cmd = ['remove', volume._vid_snap]
qubes_lvm(cmd, self.log)
except: # pylint: disable=bare-except
pass
if volume.source is None: if volume.source is None:
cmd = ['clone', volume.vid, volume._vid_snap] cmd = ['clone', volume.vid, volume._vid_snap]
else: else:
@ -342,7 +350,7 @@ def qubes_lvm(cmd, log=logging.getLogger('qube.storage.lvm')):
out, err = p.communicate() out, err = p.communicate()
return_code = p.returncode return_code = p.returncode
if out: if out:
log.info(out) log.debug(out)
if return_code == 0 and err: if return_code == 0 and err:
log.warning(err) log.warning(err)
elif return_code != 0: elif return_code != 0:

View File

@ -229,8 +229,13 @@ def get_parser():
def main(args=None): def main(args=None):
'''Main routine of :program:`qvm-block`.''' '''Main routine of :program:`qvm-block`.'''
args = get_parser().parse_args(args) parser = get_parser()
args.func(args) try:
args = parser.parse_args(args)
args.func(args)
except qubes.exc.QubesException as e:
parser.print_error(e.message)
return 1
if __name__ == '__main__': if __name__ == '__main__':

View File

@ -187,7 +187,12 @@ def main(args=None):
command line. command line.
''' '''
parser = get_parser() parser = get_parser()
args = parser.parse_args(args) try:
args = parser.parse_args(args)
except qubes.exc.QubesException as e:
parser.print_error(e.message)
return 1
if args.command is None or args.command == 'list': if args.command is None or args.command == 'list':
list_pools(args.app) list_pools(args.app)
elif args.command == 'add': elif args.command == 'add':

View File

@ -133,13 +133,17 @@ def main(args=None):
if args.debug: if args.debug:
vm.debug = args.debug vm.debug = args.debug
try: if args.debug:
vm.start( vm.start(
preparing_dvm=args.preparing_dvm, preparing_dvm=args.preparing_dvm,
start_guid=args.start_guid) start_guid=args.start_guid)
except qubes.exc.QubesException as e: else:
parser.error_runtime('Qubes error: {!r}'.format(e)) try:
vm.start(
preparing_dvm=args.preparing_dvm,
start_guid=args.start_guid)
except qubes.exc.QubesException as e:
parser.error_runtime('Qubes error: {!r}'.format(e))
return 0 return 0

View File

@ -164,7 +164,7 @@ class NetVMMixin(qubes.events.Emitter):
pass pass
try: try:
vm.attach_network(wait=False) vm.attach_network()
except qubes.exc.QubesException: except qubes.exc.QubesException:
vm.log.warning('Cannot attach network', exc_info=1) vm.log.warning('Cannot attach network', exc_info=1)