diff options
| author | Thomas Kriechbaumer <Kriechi@users.noreply.github.com> | 2017-02-02 17:23:11 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-02-02 17:23:11 +0100 | 
| commit | 3f4d472c80f707b3ffbc060123d811c6bcae2afd (patch) | |
| tree | 465ed866617e3d613078f1a682ff4eb5018c43f1 /test/conftest.py | |
| parent | c1bc1ea584d4bb47c1b754dfa7f10ab4dfc380a3 (diff) | |
| parent | 4f0b2bc4dec4eb3c4f0075bcebebeb126a5a6e88 (diff) | |
| download | mitmproxy-3f4d472c80f707b3ffbc060123d811c6bcae2afd.tar.gz mitmproxy-3f4d472c80f707b3ffbc060123d811c6bcae2afd.tar.bz2 mitmproxy-3f4d472c80f707b3ffbc060123d811c6bcae2afd.zip | |
Merge pull request #1980 from Kriechi/improve-tests
improve tests
Diffstat (limited to 'test/conftest.py')
| -rw-r--r-- | test/conftest.py | 50 | 
1 files changed, 49 insertions, 1 deletions
| diff --git a/test/conftest.py b/test/conftest.py index 4d779b01..c44aa461 100644 --- a/test/conftest.py +++ b/test/conftest.py @@ -1,6 +1,7 @@  import os  import pytest  import OpenSSL +import functools  import mitmproxy.net.tcp @@ -9,6 +10,53 @@ requires_alpn = pytest.mark.skipif(      not mitmproxy.net.tcp.HAS_ALPN,      reason='requires OpenSSL with ALPN support') +skip_windows = pytest.mark.skipif( +    os.name == "nt", +    reason='Skipping due to Windows' +) + +skip_not_windows = pytest.mark.skipif( +    os.name != "nt", +    reason='Skipping due to not Windows' +) + +skip_appveyor = pytest.mark.skipif( +    "APPVEYOR" in os.environ, +    reason='Skipping due to Appveyor' +) + + +original_pytest_raises = pytest.raises + + +def raises(exc, *args, **kwargs): +    functools.wraps(original_pytest_raises) +    if isinstance(exc, str): +        return RaisesContext(exc) +    else: +        return original_pytest_raises(exc, *args, **kwargs) + + +pytest.raises = raises + + +class RaisesContext: +    def __init__(self, expected_exception): +        self.expected_exception = expected_exception + +    def __enter__(self): +        return + +    def __exit__(self, exc_type, exc_val, exc_tb): +        if not exc_type: +            raise AssertionError("No exception raised.") +        else: +            if self.expected_exception.lower() not in str(exc_val).lower(): +                raise AssertionError( +                    "Expected %s, but caught %s" % (repr(self.expected_exception), repr(exc_val)) +                ) +        return True +  @pytest.fixture()  def disable_alpn(monkeypatch): @@ -68,7 +116,7 @@ def pytest_runtestloop(session):      prefix = os.getcwd()      excluded_files = [os.path.normpath(f) for f in pytest.config.option.no_full_cov]      measured_files = [os.path.normpath(os.path.relpath(f, prefix)) for f in cov.get_data().measured_files()] -    measured_files = [f for f in measured_files if f not in excluded_files] +    measured_files = [f for f in measured_files if not any(f.startswith(excluded_f) for excluded_f in excluded_files)]      for name in pytest.config.option.full_cov:          files = [f for f in measured_files if f.startswith(os.path.normpath(name))] | 
