diff options
| author | Christian Ehrhardt <christian.ehrhardt@canonical.com> | 2016-06-09 10:35:39 +0200 | 
|---|---|---|
| committer | Christian Ehrhardt <christian.ehrhardt@canonical.com> | 2016-06-09 10:35:39 +0200 | 
| commit | 0e734b63c64c5534813d7647d33870c9fc3d3a0c (patch) | |
| tree | 3a6c5732f2abd228c51374eb9cfc7d8661209551 | |
| parent | 108511d93b336e0b8e0807fbe876bad4cc07277f (diff) | |
| download | vyos-cloud-init-0e734b63c64c5534813d7647d33870c9fc3d3a0c.tar.gz vyos-cloud-init-0e734b63c64c5534813d7647d33870c9fc3d3a0c.zip | |
mock is_resolvable in mirrorfail tests to remove dependency to external net
| -rw-r--r-- | tests/unittests/helpers.py | 17 | ||||
| -rw-r--r-- | tests/unittests/test_handler/test_handler_apt_configure_sources_list.py | 43 | 
2 files changed, 24 insertions, 36 deletions
| diff --git a/tests/unittests/helpers.py b/tests/unittests/helpers.py index 59361215..50b2bd72 100644 --- a/tests/unittests/helpers.py +++ b/tests/unittests/helpers.py @@ -344,20 +344,3 @@ except AttributeError:                      print(reason, file=sys.stderr)              return wrapper          return decorator - -# on SkipTest: -#  - unittest SkipTest is first preference, but it's only available -#    for >= 2.7 -#  - unittest2 SkipTest is second preference for older pythons.  This -#    mirrors logic for choosing SkipTest exception in testtools -#  - if none of the above, provide custom class -try: -    from unittest.case import SkipTest -except ImportError: -    try: -        from unittest2.case import SkipTest -    except ImportError: -        class SkipTest(Exception): -            """Raise this exception to mark a test as skipped. -            """ -            pass diff --git a/tests/unittests/test_handler/test_handler_apt_configure_sources_list.py b/tests/unittests/test_handler/test_handler_apt_configure_sources_list.py index 83e2e0cc..acde0863 100644 --- a/tests/unittests/test_handler/test_handler_apt_configure_sources_list.py +++ b/tests/unittests/test_handler/test_handler_apt_configure_sources_list.py @@ -5,7 +5,6 @@ import logging  import os  import shutil  import tempfile -import socket  try:      from unittest import mock @@ -126,30 +125,36 @@ class TestAptSourceConfigSourceList(t_help.FilesystemMockingTestCase):          self.apt_source_list('ubuntu', 'http://archive.ubuntu.com/ubuntu/')      @staticmethod -    def check_connectivity(target): -        """Check for required connectivity, if not skip this test""" -        testsock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) -        testsock.settimeout(10) -        try: -            testsock.connect((target, 80)) -            testsock.close() -        except socket.error: -            raise t_help.SkipTest("Test skipped: no network connectivity to %s" -                                  % target) +    def myresolve(name): +        """Fake util.is_resolvable for mirrorfail tests""" +        if name == "does.not.exist": +            print("Faking FAIL for '%s'" % name) +            return False +        else: +            print("Faking SUCCESS for '%s'" % name) +            return True      def test_apt_srcl_debian_mirrorfail(self):          """Test rendering of a source.list from template for debian""" -        self.check_connectivity('httpredir.debian.org') -        self.apt_source_list('debian', ['http://does.not.exist', -                                        'http://httpredir.debian.org/debian'], -                             'http://httpredir.debian.org/debian') +        with mock.patch.object(util, 'is_resolvable', +                               side_effect=self.myresolve) as mockresolve: +            self.apt_source_list('debian', +                                 ['http://does.not.exist', +                                  'http://httpredir.debian.org/debian'], +                                 'http://httpredir.debian.org/debian') +        mockresolve.assert_any_call("does.not.exist") +        mockresolve.assert_any_call("httpredir.debian.org")      def test_apt_srcl_ubuntu_mirrorfail(self):          """Test rendering of a source.list from template for ubuntu""" -        self.check_connectivity('archive.ubuntu.com') -        self.apt_source_list('ubuntu', ['http://does.not.exist', -                                        'http://archive.ubuntu.com/ubuntu/'], -                             'http://archive.ubuntu.com/ubuntu/') +        with mock.patch.object(util, 'is_resolvable', +                               side_effect=self.myresolve) as mockresolve: +            self.apt_source_list('ubuntu', +                                 ['http://does.not.exist', +                                  'http://archive.ubuntu.com/ubuntu/'], +                                 'http://archive.ubuntu.com/ubuntu/') +        mockresolve.assert_any_call("does.not.exist") +        mockresolve.assert_any_call("archive.ubuntu.com")      def test_apt_srcl_custom(self):          """Test rendering from a custom source.list template""" | 
