Skip to content
Snippets Groups Projects
Select Git revision
  • c50c9b38e354c0eb5e3ffda08b08eb5dc6bf90bb
  • python3 default protected
  • feature/exabgp_support2
  • feature/exabgp_support2.bgpextcommunity
  • feature/exabgp_support2.django4.2
  • fix/existingcheck_honor_fragtype
  • feature/python3-authz_netmask
  • feature/authz_netmask
  • fix/wrong_ratelimit_stats
  • feature/requirements_version_update2024-01
  • feature/split_celery
  • feature/improved-warning-mails
  • fix/reenable_expireset_via_restapi
  • feature/admin_user_delete_with_owned_rule_reassigning1
  • feature/admin_user_delete_with_owned_rule_reassigning
  • feature/branded_doc
  • fix/forked_snmp_polling_worker_exit_issue
  • fix/false_user_activation_error
  • feature/exabgp_with_docker-compose
  • fix/prefix_overlap_handling
  • fix/js_security_issues-a
  • save1
  • rpm-1.5-7
  • working1
  • myv1.6
  • t12b1
  • v1.5_newnew2
  • merged_final
  • v1.5_newnew
  • startstop_old
  • myadd2
  • tomas3
  • merge_jra2t6_and_RESTAPI
  • mytomas2
  • mynew1
  • new_jra2t6
  • v1.5_final
  • fod16_ruleroutes-merged_old
  • merged_new
  • v1.6_new_old
  • v1.5_new_old_follower
41 results

cron_fetch_networks.py

Blame
  • test_monitoring.py 2.09 KiB
    import contextlib
    import json
    import os
    from unittest import mock
    from inventory_provider.tasks import monitor
    from inventory_provider.tasks.common import _get_redis
    
    CONNECTION_FINGERPRINT = "SDF@#$@#"
    
    TEST_MANAGEMENT_EVENTS = [
        {'type': 'task-aaaa', 'uuid': 'AAAA', 'clock': 999},
        {'type': 'task-infox', 'uuid': 'AAAA', 'clock': 999}
    ]
    
    TEST_LOG_EVENTS = [
        {'type': 'task-info', 'uuid': 'AAAA', 'clock': 99},
        {'type': 'task-info', 'uuid': 'AAAA', 'clock': 999},
        {'type': 'task-warning', 'uuid': 'AAAA', 'clock': 88},
        {'type': 'task-warning', 'uuid': 'AAAA', 'clock': 888},
        {'type': 'task-error', 'uuid': 'AAAA', 'clock': 77},
        {'type': 'task-error', 'uuid': 'AAAA', 'clock': 777}
    ]
    
    
    @contextlib.contextmanager
    def mocked_connection():
        yield CONNECTION_FINGERPRINT
    
    
    class MockedState():
        def __init__(self):
            pass
    
        def event(self, e):
            pass
    
    
    class MockedReceiver():
        def __init__(self, connection, handlers):
            assert connection == CONNECTION_FINGERPRINT
            self.handlers = handlers
    
        def capture(self, **kwargs):
            # write test events to log, check in the test case
            for e in TEST_MANAGEMENT_EVENTS + TEST_LOG_EVENTS:
                self.handlers['*'](e)
    
    
    def backend_db():
        return _get_redis({
            'redis': {
                'hostname': None,
                'port': None
            },
            'redis-databases': [0, 7]
        }).db
    
    
    @mock.patch('inventory_provider.tasks.monitor.app.events.State', MockedState)
    @mock.patch(
        'inventory_provider.tasks.monitor.app.connection', mocked_connection)
    @mock.patch(
        'inventory_provider.tasks.monitor.app.events.Receiver', MockedReceiver)
    def test_latchdb(data_config_filename, mocked_redis):
    
        os.environ['INVENTORY_PROVIDER_CONFIG_FILENAME'] = data_config_filename
        monitor.run()
    
        db = backend_db()
    
        for e in TEST_MANAGEMENT_EVENTS:
            expected_key = f'joblog:{e["uuid"]}:{e["type"]}'
            assert e == json.loads(db[expected_key])
    
        for e in TEST_LOG_EVENTS:
            expected_key = f'joblog:{e["uuid"]}:{e["type"]}:{e["clock"]}'
            assert e == json.loads(db[expected_key])