def update(self, object):
        """
        This is overridden to forward changes in the AppEngine connection
        information to the daemons

        param object: the hook that is called when objects are changed in ZODB
        """
        from Products.ZenModel.DeviceClass import DeviceClass
        if isinstance(object, DeviceClass):
            if hasattr( object, 'zAppEngineInstanceApplication') and \
                object.__primary_parent__.id == 'AppEngine':
                procrastinator = Procrastinate(
                    self.updateEndpointConfiguration)
                procrastinator.doLater(object.id)
        HubService.update(self, object)
예제 #2
0
class TestHubService(TestCase):
    def setUp(self):
        self.dmd = Mock(name='dmd')
        self.instance = Mock(name='instance')

        self.hub_service = HubService(self.dmd, self.instance)

    def test_init(self):
        self.assertIsInstance(self.hub_service, pb.Referenceable)

        # Validate attributes created by __init__
        self.assertEqual(self.hub_service.log, logging.getLogger('zen.hub'))
        self.assertEqual(self.hub_service.fqdn, socket.getfqdn())
        self.assertEqual(self.hub_service.dmd, self.dmd)
        self.assertEqual(self.hub_service.zem, self.dmd.ZenEventManager)
        self.assertEqual(self.hub_service.instance, self.instance)
        self.assertEqual(self.hub_service.listeners, [])
        self.assertEqual(self.hub_service.listenerOptions, {})
        self.assertEqual(self.hub_service.callTime, 0)

    def test_getPerformanceMonitor(self):
        out = self.hub_service.getPerformanceMonitor()

        self.dmd.Monitors.getPerformanceMonitor.assert_called_with(
            self.instance)
        self.assertEqual(out,
                         self.dmd.Monitors.getPerformanceMonitor.return_value)

    @patch(
        '{HubService}.pb.Referenceable.remoteMessageReceived'.format(**PATH),
        autospec=True,
        spec_set=True)
    @patch('{HubService}.time.time'.format(**PATH),
           autospec=True,
           spec_set=True)
    def test_remoteMessageReceived(self, time, remoteMessageReceived):
        Broker = Mock(name='pb.Broker')
        broker = Broker()
        message = 'message'
        args = []
        kw = {}
        times = [3, 5]
        time.side_effect = times

        out = self.hub_service.remoteMessageReceived(broker, message, args, kw)

        pb.Referenceable.remoteMessageReceived.assert_called_with(
            self.hub_service, broker, message, args, kw)
        self.assertEqual(out,
                         pb.Referenceable.remoteMessageReceived.return_value)
        self.assertEqual(self.hub_service.callTime, times[1] - times[0])

    def test_update_is_deprecated(self):
        self.hub_service.update('object')
        # Deprecated function with no output or side-effects

    def test_deleted_is_deprecated(self):
        self.hub_service.deleted('object')
        # Deprecated function with no output or side-effects

    def test_name(self):
        out = self.hub_service.name()
        self.assertEqual(out, self.hub_service.__class__.__name__)

    def test_addListener(self):
        remote = Mock(name='remote')
        options = Mock(name='options')

        self.hub_service.addListener(remote, options=options)

        remote.notifyOnDisconnect.assert_called_with(
            self.hub_service.removeListener)
        self.assertIn(remote, self.hub_service.listeners)
        self.assertEqual(self.hub_service.listenerOptions[remote], options)

    def test_removeListener(self):
        listener = Mock(name='listener')
        options = Mock(name='options')
        self.hub_service.listeners = [listener]
        self.hub_service.listenerOptions[listener] = options

        self.hub_service.removeListener(listener)

        self.assertNotIn(listener, self.hub_service.listeners)
        self.assertNotIn(listener, self.hub_service.listenerOptions.keys())

    def test_sendEvents(self):
        events = ['evt1', 'evt2', 'evt3']
        self.hub_service.sendEvent = create_autospec(
            self.hub_service.sendEvent, name='HubService.sendEvent')

        self.hub_service.sendEvents(events)
        self.hub_service.sendEvent.assert_has_calls([call(x) for x in events])

    @patch('Products.ZenEvents.Event.Event', autospec=True, spec_set=True)
    def test_sendEvent(self, Event):
        # This should accept an Products.ZenEvents.Event.Event object, but
        # currently only accepts a dict, which is converted to an Event later
        event = {}
        kw = {'kwarg_a': 'kwarg_1', 'kwarg_b': 'kwarg_2'}

        self.hub_service.sendEvent(event, **kw)

        sent_event = {
            'agent': 'zenhub',
            'monitor': self.hub_service.instance,
            'manager': self.hub_service.fqdn,
            'kwarg_a': kw['kwarg_a'],
            'kwarg_b': kw['kwarg_b'],
        }

        self.hub_service.zem.sendEvent.assert_called_with(sent_event)
예제 #3
0
class TestHubService(TestCase):

    def setUp(self):
        self.dmd = Mock(name='dmd')
        self.instance = Mock(name='instance')

        self.hub_service = HubService(self.dmd, self.instance)

    def test_init(self):
        self.assertIsInstance(self.hub_service, pb.Referenceable)

        # Validate attributes created by __init__
        self.assertEqual(self.hub_service.log, logging.getLogger('zen.hub'))
        self.assertEqual(self.hub_service.fqdn, socket.getfqdn())
        self.assertEqual(self.hub_service.dmd, self.dmd)
        self.assertEqual(self.hub_service.zem, self.dmd.ZenEventManager)
        self.assertEqual(self.hub_service.instance, self.instance)
        self.assertEqual(self.hub_service.listeners, [])
        self.assertEqual(self.hub_service.listenerOptions, {})
        self.assertEqual(self.hub_service.callTime, 0)

    def test_getPerformanceMonitor(self):
        out = self.hub_service.getPerformanceMonitor()

        self.dmd.Monitors.getPerformanceMonitor.assert_called_with(
            self.instance
        )
        self.assertEqual(
            out,
            self.dmd.Monitors.getPerformanceMonitor.return_value
        )

    @patch(
        '{HubService}.pb.Referenceable.remoteMessageReceived'.format(**PATH),
        autospec=True, spec_set=True
    )
    @patch(
        '{HubService}.time.time'.format(**PATH),
        autospec=True, spec_set=True
    )
    def test_remoteMessageReceived(self, time, remoteMessageReceived):
        Broker = Mock(name='pb.Broker')
        broker = Broker()
        message = 'message'
        args = []
        kw = {}
        times = [3, 5]
        time.side_effect = times

        out = self.hub_service.remoteMessageReceived(broker, message, args, kw)

        pb.Referenceable.remoteMessageReceived.assert_called_with(
            self.hub_service, broker, message, args, kw
        )
        self.assertEqual(
            out,
            pb.Referenceable.remoteMessageReceived.return_value
        )
        self.assertEqual(
            self.hub_service.callTime,
            times[1] - times[0]
        )

    def test_update_is_deprecated(self):
        self.hub_service.update('object')
        # Deprecated function with no output or side-effects

    def test_deleted_is_deprecated(self):
        self.hub_service.deleted('object')
        # Deprecated function with no output or side-effects

    def test_name(self):
        out = self.hub_service.name()
        self.assertEqual(out, self.hub_service.__class__.__name__)

    def test_addListener(self):
        remote = Mock(name='remote')
        options = Mock(name='options')

        self.hub_service.addListener(remote, options=options)

        remote.notifyOnDisconnect.assert_called_with(
            self.hub_service.removeListener
        )
        self.assertIn(remote, self.hub_service.listeners)
        self.assertEqual(self.hub_service.listenerOptions[remote], options)

    def test_removeListener(self):
        listener = Mock(name='listener')
        options = Mock(name='options')
        self.hub_service.listeners = [listener]
        self.hub_service.listenerOptions[listener] = options

        self.hub_service.removeListener(listener)

        self.assertNotIn(listener, self.hub_service.listeners)
        self.assertNotIn(listener, self.hub_service.listenerOptions.keys())

    def test_sendEvents(self):
        events = ['evt1', 'evt2', 'evt3']
        self.hub_service.sendEvent = create_autospec(
            self.hub_service.sendEvent, name='HubService.sendEvent'
        )

        self.hub_service.sendEvents(events)
        self.hub_service.sendEvent.assert_has_calls([call(x) for x in events])

    @patch('Products.ZenEvents.Event.Event', autospec=True, spec_set=True)
    def test_sendEvent(self, Event):
        # This should accept an Products.ZenEvents.Event.Event object, but
        # currently only accepts a dict, which is converted to an Event later
        event = {}
        kw = {'kwarg_a': 'kwarg_1', 'kwarg_b': 'kwarg_2'}

        self.hub_service.sendEvent(event, **kw)

        sent_event = {
            'agent': 'zenhub',
            'monitor': self.hub_service.instance,
            'manager': self.hub_service.fqdn,
            'kwarg_a': kw['kwarg_a'],
            'kwarg_b': kw['kwarg_b'],
        }

        self.hub_service.zem.sendEvent.assert_called_with(sent_event)