Encoding fixes and tests

This commit is contained in:
Ujjwal Verma
2017-02-05 18:59:01 +05:30
parent 2316c0fb74
commit c622622c59
3 changed files with 56 additions and 23 deletions

View File

@@ -21,16 +21,14 @@ def test_identity(encoder):
'deflate',
])
def test_encoders(encoder):
assert "" == encoding.decode("", encoder)
"""
This test is for testing byte->byte encoding/decoding
"""
assert encoding.decode(None, encoder) is None
assert encoding.encode(None, encoder) is None
assert b"" == encoding.decode(b"", encoder)
assert "string" == encoding.decode(
encoding.encode(
"string",
encoder
),
encoder
)
assert b"string" == encoding.decode(
encoding.encode(
b"string",
@@ -39,10 +37,41 @@ def test_encoders(encoder):
encoder
)
with pytest.raises(TypeError):
encoding.encode("string", encoder)
with pytest.raises(TypeError):
encoding.decode("string", encoder)
with pytest.raises(ValueError):
encoding.decode(b"foobar", encoder)
@pytest.mark.parametrize("encoder", [
'utf8',
'latin-1'
])
def test_encoders_strings(encoder):
"""
This test is for testing byte->str decoding
and str->byte encoding
"""
assert "" == encoding.decode(b"", encoder)
assert "string" == encoding.decode(
encoding.encode(
"string",
encoder
),
encoder
)
with pytest.raises(TypeError):
encoding.encode(b"string", encoder)
with pytest.raises(TypeError):
encoding.decode("foobar", encoder)
def test_cache():
decode_gzip = mock.MagicMock()
decode_gzip.return_value = b"decoded"