aboutsummaryrefslogtreecommitdiffstats
path: root/test/netlib/http/test_encoding.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/netlib/http/test_encoding.py')
-rw-r--r--test/netlib/http/test_encoding.py73
1 files changed, 0 insertions, 73 deletions
diff --git a/test/netlib/http/test_encoding.py b/test/netlib/http/test_encoding.py
deleted file mode 100644
index 89600709..00000000
--- a/test/netlib/http/test_encoding.py
+++ /dev/null
@@ -1,73 +0,0 @@
-import mock
-import pytest
-
-from netlib.http import encoding
-from mitmproxy.test import tutils
-
-
-@pytest.mark.parametrize("encoder", [
- 'identity',
- 'none',
-])
-def test_identity(encoder):
- assert b"string" == encoding.decode(b"string", encoder)
- assert b"string" == encoding.encode(b"string", encoder)
- with tutils.raises(ValueError):
- encoding.encode(b"string", "nonexistent encoding")
-
-
-@pytest.mark.parametrize("encoder", [
- 'gzip',
- 'br',
- 'deflate',
-])
-def test_encoders(encoder):
- assert "" == encoding.decode("", encoder)
- assert b"" == encoding.decode(b"", encoder)
-
- assert "string" == encoding.decode(
- encoding.encode(
- "string",
- encoder
- ),
- encoder
- )
- assert b"string" == encoding.decode(
- encoding.encode(
- b"string",
- encoder
- ),
- encoder
- )
-
- with tutils.raises(ValueError):
- encoding.decode(b"foobar", encoder)
-
-
-def test_cache():
- decode_gzip = mock.MagicMock()
- decode_gzip.return_value = b"decoded"
- encode_gzip = mock.MagicMock()
- encode_gzip.return_value = b"encoded"
-
- with mock.patch.dict(encoding.custom_decode, gzip=decode_gzip):
- with mock.patch.dict(encoding.custom_encode, gzip=encode_gzip):
- assert encoding.decode(b"encoded", "gzip") == b"decoded"
- assert decode_gzip.call_count == 1
-
- # should be cached
- assert encoding.decode(b"encoded", "gzip") == b"decoded"
- assert decode_gzip.call_count == 1
-
- # the other way around as well
- assert encoding.encode(b"decoded", "gzip") == b"encoded"
- assert encode_gzip.call_count == 0
-
- # different encoding
- decode_gzip.return_value = b"bar"
- assert encoding.encode(b"decoded", "deflate") != b"decoded"
- assert encode_gzip.call_count == 0
-
- # This is not in the cache anymore
- assert encoding.encode(b"decoded", "gzip") == b"encoded"
- assert encode_gzip.call_count == 1