Exemple #1
0
 def setUp(self):
     self.index_dict = {}
     self.index = Index(self.index_dict)
Exemple #2
0
                      metric=0.5)
        index.update(event)

    for i in range(num_expired):
        event = Event(host='host-%d' % i,
                      service='service',
                      state='up',
                      description='description',
                      time=CURRENT_TIME - random.randint(1, 300),
                      ttl=0,
                      metric=0.5)
        index.update(event)


if __name__ == '__main__':
    while True:
        now = time.time()
        index = Index()
        add_random_events(index, 1000000, 0.10)
        add_event_time = time.time() - now

        now = time.time()
        expired = index.expire(CURRENT_TIME)
        expired_event_time = time.time() - now
        num_expired = len(expired)

        print('Add: {:.4f} seconds '
              'Expire: {:.4f} seconds '
              'Expired: {} events'.format(add_event_time, expired_event_time,
                                          num_expired))
Exemple #3
0
 def test_default_constructor(self):
     self.index = Index()
     self.assertEquals(self.index.store, dict())
Exemple #4
0
class IndexTestCase(BaseTestCase):
    def setUp(self):
        self.index_dict = {}
        self.index = Index(self.index_dict)

    def test_default_constructor(self):
        self.index = Index()
        self.assertEquals(self.index.store, dict())

    def test_clear_empties_index(self):
        event = self.create_event()
        self.index.update(event)
        self.index.clear()
        self.assertEquals(self.index_dict, {})

    def test_clear_empties_deadlines(self):
        event = self.create_event()
        self.index.update(event)
        self.index.clear()
        self.assertEquals(self.index.deadlines, {})

    def test_delete(self):
        event = self.create_event()
        self.index.update(event)
        deleted_event = self.index.delete(event)
        self.assertEquals(self.index_dict, {})
        self.assertEquals(event, deleted_event)

    def test_delete_event_does_not_exist(self):
        event = self.create_event()
        deleted_event = self.index.delete(event)
        self.assertEquals(self.index_dict, {})
        self.assertEquals(deleted_event, None)

    def test_delete_removes_deadline(self):
        event = self.create_event()
        self.index.update(event)
        deleted_event = self.index.delete(event)
        self.assertTrue(all(len(deadlines) == 0
                            for deadlines in self.index.deadlines.values()))

    def test_update(self):
        event = self.create_event()
        updated_event = self.index.update(event)
        self.assertTrue((event.host, event.service) in self.index_dict)
        self.assertEquals(event, updated_event)

    def test_update_deadline(self):
        event = self.create_event(time=0.0, ttl=0)
        updated_event = self.index.update(event)
        self.assertTrue(
            (event.host, event.service) in self.index.deadlines[event.deadline])

    def test_update_expired_event(self):
        event = self.create_event(state='expired')
        updated_event = self.index.update(event)
        self.assertFalse((event.host, event.service) in self.index_dict)
        self.assertEquals(updated_event, None)

    def test_get_event_exists(self):
        event = self.create_event()
        self.index.update(event)

        event_key = (event.host, event.service)
        found_event = self.index.get(*event_key)
        self.assertEquals(event, found_event)

    def test_get_event_does_not_exist(self):
        event = self.create_event()
        event_key = (event.host, event.service)
        found_event = self.index.get(*event_key)
        self.assertEquals(found_event, None)

    def test_len(self):
        event = self.create_event()
        self.index.update(event)
        self.assertEquals(len(self.index), 1)

    def test_bool_empty(self):
        self.assertTrue(self.index)

    def test_bool_non_empty(self):
        event = self.create_event()
        self.index.update(event)
        self.assertTrue(self.index)

    @raises(NotImplementedError)
    def test_search(self):
        query_ast = []
        self.index.search(query_ast)
Exemple #5
0
class IndexExpireTestCase(BaseTestCase):
    CURRENT_TIME = 1000000000.0

    def setUp(self):
        self.index = Index()

    def assertExpiredEvents(self, time, expected):
        expired = self.index.expire(time)
        expired.sort()
        expected.sort()
        self.assertEquals(expired, expected)

    def test_no_events_in_index(self):
        self.assertExpiredEvents(self.CURRENT_TIME, [])

    def test_exipre_single_event(self):
        event = self.create_event(time=self.CURRENT_TIME, ttl=0)
        self.index.update(event)
        self.assertExpiredEvents(self.CURRENT_TIME, [event])

    def test_no_expired_events(self):
        event = self.create_event(time=self.CURRENT_TIME, ttl=1)
        self.index.update(event)
        self.assertExpiredEvents(self.CURRENT_TIME, [])

    def test_no_expired_events_subsecond(self):
        event = self.create_event(time=self.CURRENT_TIME + 0.05, ttl=0)
        self.index.update(event)
        self.assertExpiredEvents(self.CURRENT_TIME, [])

    def test_expire_multiple_events(self):
        expired_events = [
            self.create_event(
                host='test-%d' % i,
                service='expired',
                time=self.CURRENT_TIME,
                ttl=0)
            for i in range(100)
        ]
        fresh_events = [
            self.create_event(
                host='test-%d' % i,
                service='fresh',
                time=self.CURRENT_TIME,
                ttl=1)
            for i in range(100)
        ]
        for event in expired_events + fresh_events:
            self.index.update(event)
        self.assertExpiredEvents(self.CURRENT_TIME, expired_events)

    def test_expire_older_events(self):
        current_event = self.create_event(
            host='test-1',
            service='expired',
            time=self.CURRENT_TIME,
            ttl=0)
        self.index.update(current_event)
        older_event = self.create_event(
            host='test-2',
            service='expired',
            time=self.CURRENT_TIME - 1,
            ttl=0)
        self.index.update(older_event)
        self.assertExpiredEvents(
            self.CURRENT_TIME, [current_event, older_event])
Exemple #6
0
 def setUp(self):
     self.index = Index()
Exemple #7
0
 def test_factory(self):
     index = Index.factory()
     self.assertEqual(index, index.factory())
Exemple #8
0
        index.update(event)

    for i in range(num_expired):
        event = Event(
            host='host-%d' % i,
            service='service',
            state='up',
            description='description',
            time=CURRENT_TIME - random.randint(1, 300),
            ttl=0,
            metric=0.5)
        index.update(event)


if __name__ == '__main__':
    while True:
        now = time.time()
        index = Index()
        add_random_events(index, 1000000, 0.10)
        add_event_time = time.time() - now

        now = time.time()
        expired = index.expire(CURRENT_TIME)
        expired_event_time = time.time() - now
        num_expired = len(expired)

        print ('Add: {:.4f} seconds '
               'Expire: {:.4f} seconds '
               'Expired: {} events'.format(
                   add_event_time, expired_event_time, num_expired))
Exemple #9
0
 def setUp(self):
     self.index_dict = {}
     self.index = Index(self.index_dict)
Exemple #10
0
class IndexTestCase(BaseTestCase):
    def setUp(self):
        self.index_dict = {}
        self.index = Index(self.index_dict)

    def test_default_constructor(self):
        self.index = Index()
        self.assertEquals(self.index.store, dict())

    def test_clear_empties_index(self):
        event = self.create_event()
        self.index.update(event)
        self.index.clear()
        self.assertEquals(self.index_dict, {})

    def test_clear_empties_deadlines(self):
        event = self.create_event()
        self.index.update(event)
        self.index.clear()
        self.assertEquals(self.index.deadlines, {})

    def test_delete(self):
        event = self.create_event()
        self.index.update(event)
        deleted_event = self.index.delete(event)
        self.assertEquals(self.index_dict, {})
        self.assertEquals(event, deleted_event)

    def test_delete_event_does_not_exist(self):
        event = self.create_event()
        deleted_event = self.index.delete(event)
        self.assertEquals(self.index_dict, {})
        self.assertEquals(deleted_event, None)

    def test_delete_removes_deadline(self):
        event = self.create_event()
        self.index.update(event)
        deleted_event = self.index.delete(event)
        self.assertTrue(
            all(
                len(deadlines) == 0
                for deadlines in self.index.deadlines.values()))

    def test_update(self):
        event = self.create_event()
        updated_event = self.index.update(event)
        self.assertTrue((event.host, event.service) in self.index_dict)
        self.assertEquals(event, updated_event)

    def test_update_deadline(self):
        event = self.create_event(time=0.0, ttl=0)
        updated_event = self.index.update(event)
        self.assertTrue(
            (event.host,
             event.service) in self.index.deadlines[event.deadline])

    def test_update_expired_event(self):
        event = self.create_event(state='expired')
        updated_event = self.index.update(event)
        self.assertFalse((event.host, event.service) in self.index_dict)
        self.assertEquals(updated_event, None)

    def test_get_event_exists(self):
        event = self.create_event()
        self.index.update(event)

        event_key = (event.host, event.service)
        found_event = self.index.get(*event_key)
        self.assertEquals(event, found_event)

    def test_get_event_does_not_exist(self):
        event = self.create_event()
        event_key = (event.host, event.service)
        found_event = self.index.get(*event_key)
        self.assertEquals(found_event, None)

    def test_len(self):
        event = self.create_event()
        self.index.update(event)
        self.assertEquals(len(self.index), 1)

    def test_bool_empty(self):
        self.assertTrue(self.index)

    def test_bool_non_empty(self):
        event = self.create_event()
        self.index.update(event)
        self.assertTrue(self.index)

    @raises(NotImplementedError)
    def test_search(self):
        query_ast = []
        self.index.search(query_ast)
Exemple #11
0
 def test_default_constructor(self):
     self.index = Index()
     self.assertEquals(self.index.store, dict())
Exemple #12
0
 def setUp(self):
     self.index = Index()
Exemple #13
0
class IndexExpireTestCase(BaseTestCase):
    CURRENT_TIME = 1000000000.0

    def setUp(self):
        self.index = Index()

    def assertExpiredEvents(self, time, expected):
        expired = self.index.expire(time)
        expired.sort()
        expected.sort()
        self.assertEquals(expired, expected)

    def test_no_events_in_index(self):
        self.assertExpiredEvents(self.CURRENT_TIME, [])

    def test_exipre_single_event(self):
        event = self.create_event(time=self.CURRENT_TIME, ttl=0)
        self.index.update(event)
        self.assertExpiredEvents(self.CURRENT_TIME, [event])

    def test_no_expired_events(self):
        event = self.create_event(time=self.CURRENT_TIME, ttl=1)
        self.index.update(event)
        self.assertExpiredEvents(self.CURRENT_TIME, [])

    def test_no_expired_events_subsecond(self):
        event = self.create_event(time=self.CURRENT_TIME + 0.05, ttl=0)
        self.index.update(event)
        self.assertExpiredEvents(self.CURRENT_TIME, [])

    def test_expire_multiple_events(self):
        expired_events = [
            self.create_event(host='test-%d' % i,
                              service='expired',
                              time=self.CURRENT_TIME,
                              ttl=0) for i in range(100)
        ]
        fresh_events = [
            self.create_event(host='test-%d' % i,
                              service='fresh',
                              time=self.CURRENT_TIME,
                              ttl=1) for i in range(100)
        ]
        for event in expired_events + fresh_events:
            self.index.update(event)
        self.assertExpiredEvents(self.CURRENT_TIME, expired_events)

    def test_expire_older_events(self):
        current_event = self.create_event(host='test-1',
                                          service='expired',
                                          time=self.CURRENT_TIME,
                                          ttl=0)
        self.index.update(current_event)
        older_event = self.create_event(host='test-2',
                                        service='expired',
                                        time=self.CURRENT_TIME - 1,
                                        ttl=0)
        self.index.update(older_event)
        self.assertExpiredEvents(self.CURRENT_TIME,
                                 [current_event, older_event])