Merge remote-tracking branch 'origin/pull/58/head' into core3-devel

This commit is contained in:
Wojtek Porczyk 2016-10-11 11:37:15 +02:00
commit c6c0a545e6
3 changed files with 31 additions and 3 deletions

View File

@ -33,7 +33,7 @@ import qubes.vm.adminvm
import qubes.ext.r3compatibility
class AppVM(qubes.vm.appvm.AppVM):
class AppVM(qubes.vm.appvm.AppVM): # pylint: disable=too-many-ancestors
"""core2 compatibility AppVM class, with variable dir_path"""
dir_path = qubes.property('dir_path',
# pylint: disable=undefined-variable
@ -46,7 +46,8 @@ class AppVM(qubes.vm.appvm.AppVM):
return False
class StandaloneVM(qubes.vm.standalonevm.StandaloneVM):
"""core2 compatibility StandaloneVM class, with variable dir_path"""
"""core2 compatibility StandaloneVM class, with variable dir_path
""" # pylint: disable=too-many-ancestors
dir_path = qubes.property('dir_path',
# pylint: disable=undefined-variable
default=(lambda self: super(StandaloneVM, self).dir_path),

View File

@ -135,7 +135,10 @@ class Emitter(object):
for cls in order:
if not hasattr(cls, '__handlers__'):
continue
for func in sorted(cls.__handlers__[event],
handlers = cls.__handlers__[event]
if '*' in cls.__handlers__:
handlers = cls.__handlers__['*'] | handlers
for func in sorted(handlers,
key=(lambda handler: hasattr(handler, 'ha_bound')),
reverse=True):
effect = func(self, event, *args, **kwargs)

View File

@ -82,3 +82,27 @@ class TC_00_Emitter(qubes.tests.QubesTestCase):
self.assertItemsEqual(effect,
('testvalue1', 'testvalue2', 'testvalue3', 'testvalue4'))
def test_004_catch_all(self):
# need something mutable
testevent_fired = [0]
def on_all(subject, event, *args, **kwargs):
# pylint: disable=unused-argument
testevent_fired[0] += 1
def on_foo(subject, event, *args, **kwargs):
# pylint: disable=unused-argument
testevent_fired[0] += 1
emitter = qubes.events.Emitter()
emitter.add_handler('*', on_all)
emitter.add_handler('foo', on_foo)
emitter.events_enabled = True
emitter.fire_event('testevent')
self.assertEqual(testevent_fired[0], 1)
emitter.fire_event('foo')
# now catch-all and foo should be executed
self.assertEqual(testevent_fired[0], 3)
emitter.fire_event('bar')
self.assertEqual(testevent_fired[0], 4)