コード例 #1
0
ファイル: nettestlib.py プロジェクト: rexhsu/vdsm-debian
 def _ifDown(self):
     with monitor.Monitor(groups=('link', ), timeout=2) as mon:
         check_call([EXT_IP, "link", "set", self.devName, "down"])
         for event in mon:
             if (event.get('name') == self.devName
                     and event.get('state') == 'down'):
                 return
コード例 #2
0
ファイル: nettestlib.py プロジェクト: borisroman/vdsm
 def _down(self):
     with monitor.Monitor(groups=('link', ), timeout=2) as mon:
         linkSet(self.devName, ['down'])
         for event in mon:
             if (event.get('name') == self.devName
                     and event.get('state') == 'down'):
                 return
コード例 #3
0
    def test_stopped(self):
        with monitor.Monitor(timeout=self.TIMEOUT) as mon:
            dummy_name = dummy.create()
            dummy.remove(dummy_name)

        found = any(event.get('name') == dummy_name for event in mon)
        self.assertTrue(found, 'Expected event was not caught.')
コード例 #4
0
ファイル: netlinkTests.py プロジェクト: zofuthan/vdsm
    def test_events_keys(self):
        def _expected_events(nic, address, cidr):
            return deque([
                {'event': 'new_link', 'name': nic},
                {'event': 'new_addr', 'address': address + '/' + cidr},
                {'event': 'new_link', 'name': nic},
                {'event': 'new_link', 'name': nic},
                {'event': 'new_addr', 'family': 'inet6'},
                {'event': 'new_link', 'name': nic},
                {'event': 'del_neigh'},
                {'event': 'del_addr', 'family': 'inet6'},
                {'address': address + '/' + cidr, 'event': 'del_addr'},
                {'destination': address, 'event': 'del_route'},
                {'event': 'del_link', 'name': nic}])

        with monitor.Monitor(timeout=self.TIMEOUT,
                             silent_timeout=True) as mon:
            dummy_name = dummy.create()
            dummy.setIP(dummy_name, IP_ADDRESS, IP_CIDR)
            dummy.setLinkUp(dummy_name)
            dummy.remove(dummy_name)

            expected_events = _expected_events(dummy_name, IP_ADDRESS, IP_CIDR)

            expected = expected_events.popleft()
            for event in mon:
                if _is_subdict(expected, event):
                    expected = expected_events.popleft()
                    if len(expected_events) == 0:
                        break

        self.assertEqual(0, len(expected_events), '%d expected events have not'
                         ' been caught (in the right order)'
                         % (1 + len(expected_events)))
コード例 #5
0
 def test_iterate_after_events(self):
     with monitor.Monitor(timeout=self.TIMEOUT) as mon:
         dummy_name = dummy.create()
         dummy.remove(dummy_name)
         for event in mon:
             if event.get('name') == dummy_name:
                 break
コード例 #6
0
ファイル: netlinkTests.py プロジェクト: zofuthan/vdsm
    def test_event_groups(self):
        with monitor.Monitor(timeout=self.TIMEOUT,
                             groups=('ipv4-ifaddr',)) as mon_a:
            with monitor.Monitor(timeout=self.TIMEOUT,
                                 groups=('link', 'ipv4-route')) as mon_l_r:
                dummy_name = dummy.create()
                dummy.setIP(dummy_name, IP_ADDRESS, IP_CIDR)
                dummy.setLinkUp(dummy_name)
                dummy.remove(dummy_name)

        for event in mon_a:
            self.assertIn('_addr', event['event'], "Caught event '%s' is not "
                          "related to address." % event['event'])

        for event in mon_l_r:
            link_or_route = ('_link' in event['event'] or
                             '_route' in event['event'])
            self.assertTrue(link_or_route, "Caught event '%s' is not related "
                            "to link or route." % event['event'])
コード例 #7
0
    def test_timeout_not_triggered(self):
        time_start = monotonic_time()
        with monitor.Monitor(timeout=self.TIMEOUT) as mon:
            dummy_name = dummy.create()
            dummy.remove(dummy_name)

            for event in mon:
                break

        self.assertTrue((monotonic_time() - time_start) <= self.TIMEOUT)
        self.assertTrue(mon.is_stopped())
コード例 #8
0
    def test_timeout(self):
        with self.assertRaises(monitor.MonitorError):
            try:
                with monitor.Monitor(timeout=.01) as mon:
                    for event in mon:
                        pass
            except monitor.MonitorError as e:
                self.assertEquals(e[0], monitor.E_TIMEOUT)
                raise

        self.assertTrue(mon.is_stopped())
コード例 #9
0
    def test_iteration(self):
        with monitor.Monitor(timeout=self.TIMEOUT) as mon:
            iterator = iter(mon)

            # Generate events to avoid blocking
            dummy_name = dummy.create()
            iterator.next()

            dummy.remove(dummy_name)
            iterator.next()

        with self.assertRaises(StopIteration):
            while True:
                iterator.next()
コード例 #10
0
ファイル: __init__.py プロジェクト: fancyKai/vdsm
def wait_for_device(name, timeout=1):
    """
    Wait for a network device to appear in a given timeout. If the device is
    not created by then, raise a ConfigNetworkError.
    """
    with monitor.Monitor(timeout=timeout, groups=('link',),
                         silent_timeout=True) as mon:
        if name in (link.name for link in ipwrapper.getLinks()):
            return
        for event in mon:
            if event.get('name') == name and event.get('event') == 'new_link':
                return
    raise ConfigNetworkError(ERR_FAILED_IFUP, 'Device %s was not created '
                             'during a %ss timeout.' % (name, timeout))
コード例 #11
0
ファイル: netlinkTests.py プロジェクト: zofuthan/vdsm
    def test_iterate_while_events(self):
        """Tests if monitor is able to catch event while iterating. Before the
        iteration we start _set_and_remove_device, which is delayed for .2
        seconds. Then iteration starts and wait for new dummy.
        """
        dummy_name = dummy.create()

        def _set_and_remove_device():
            time.sleep(.2)
            dummy.setLinkUp(dummy_name)
            dummy.remove(dummy_name)
        add_device_thread = threading.Thread(target=_set_and_remove_device)

        with monitor.Monitor(timeout=self.TIMEOUT) as mon:
            add_device_thread.start()
            for event in mon:
                if event.get('name') == dummy_name:
                    break
            add_device_thread.join()
コード例 #12
0
def _wait_for_event(iface, expected_event, timeout=10):
    with monitor.Monitor(groups=('ipv4-ifaddr', 'ipv6-ifaddr'),
                         timeout=timeout) as mon:
        try:
            yield
        finally:
            caught_events = []
            try:
                for event in mon:
                    caught_events.append(event)
                    if _is_subdict(expected_event, event):
                        mon.stop()
            except monitor.MonitorError as e:
                if e[0] == monitor.E_TIMEOUT:
                    logging.warning('Expected event "%s" of interface "%s" '
                                    'was not caught within the given timeout. '
                                    'Caught events: %s', expected_event, iface,
                                    caught_events)
                else:
                    raise
コード例 #13
0
    def test_timeout_silent(self):
        with monitor.Monitor(timeout=.01, silent_timeout=True) as mon:
            for event in mon:
                pass

        self.assertTrue(mon.is_stopped())
コード例 #14
0
 def test_passing_invalid_groups(self):
     with self.assertRaises(AttributeError):
         monitor.Monitor(groups=('blablabla', ))
     with self.assertNotRaises():
         monitor.Monitor(groups=('link', ))
コード例 #15
0
    def test_events_keys(self):
        def _simplify_event(event):
            """ Strips event keys except event, address, name, destination,
            family.
            """
            allow = set(['event', 'address', 'name', 'destination', 'family'])
            return {k: v for (k, v) in event.items() if k in allow}

        def _expected_events(nic, address, cidr):
            events_add = [{
                'event': 'new_link',
                'name': nic
            }, {
                'event': 'new_addr',
                'address': address + '/' + cidr
            }, {
                'event': 'new_link',
                'name': nic
            }]
            events_del = [{
                'address': address + '/' + cidr,
                'event': 'del_addr'
            }, {
                'destination': address,
                'event': 'del_route'
            }, {
                'event': 'del_link',
                'name': nic
            }]
            events_ipv6 = [{
                'event': 'new_addr',
                'family': 'inet6'
            }, {
                'event': 'del_neigh'
            }, {
                'event': 'del_addr',
                'family': 'inet6'
            }]
            if is_disabled_ipv6():
                return deque(events_add + events_del)
            else:
                return deque(events_add + events_ipv6 + events_del)

        with monitor.Monitor(timeout=self.TIMEOUT, silent_timeout=True) as mon:
            dummy = Dummy()
            dummy_name = dummy.create()
            dummy.set_ip(IP_ADDRESS, IP_CIDR)
            dummy.up()
            dummy.remove()

            expected_events = _expected_events(dummy_name, IP_ADDRESS, IP_CIDR)
            _expected = list(expected_events)
            _caught = []

            expected = expected_events.popleft()
            for event in mon:
                _caught.append(event)
                if _is_subdict(expected, event):
                    expected = expected_events.popleft()
                    if len(expected_events) == 0:
                        break

        self.assertEqual(
            0, len(expected_events), 'Expected events have not '
            'been caught (in the right order).\n'
            'Expected:\n%s.\nCaught:\n%s.' %
            ('\n'.join([str(d) for d in _expected]), '\n'.join(
                [str(_simplify_event(d)) for d in _caught])))