2023-07-09 22:16:55 +03:00
|
|
|
from typing import Tuple
|
|
|
|
|
|
|
|
from pytest import raises
|
|
|
|
from telethon._impl.mtproto.transport.full import Full
|
|
|
|
|
|
|
|
|
2023-08-30 17:37:04 +03:00
|
|
|
class Output(bytearray):
|
|
|
|
__slots__ = ()
|
|
|
|
|
|
|
|
def __call__(self, data: bytes) -> None:
|
|
|
|
self += data
|
|
|
|
|
|
|
|
|
2023-07-09 22:16:55 +03:00
|
|
|
def setup_pack(n: int) -> Tuple[Full, bytes, bytearray]:
|
|
|
|
input = bytes(x & 0xFF for x in range(n))
|
2023-08-30 17:37:04 +03:00
|
|
|
return Full(), input, Output()
|
2023-07-09 22:16:55 +03:00
|
|
|
|
|
|
|
|
|
|
|
def setup_unpack(n: int) -> Tuple[bytes, Full, bytes, bytearray]:
|
|
|
|
transport, expected_output, input = setup_pack(n)
|
|
|
|
transport.pack(expected_output, input)
|
|
|
|
|
|
|
|
return expected_output, Full(), input, bytearray()
|
|
|
|
|
|
|
|
|
|
|
|
def test_pack_empty() -> None:
|
|
|
|
transport, input, output = setup_pack(0)
|
|
|
|
transport.pack(input, output)
|
|
|
|
|
|
|
|
assert output == b"\x0c\x00\x00\x00\x00\x00\x00\x00&\xca\x8d2"
|
|
|
|
|
|
|
|
|
|
|
|
def test_pack_non_padded() -> None:
|
|
|
|
transport, input, output = setup_pack(7)
|
|
|
|
with raises(AssertionError):
|
|
|
|
transport.pack(input, output)
|
|
|
|
|
|
|
|
|
|
|
|
def test_pack_normal() -> None:
|
|
|
|
transport, input, output = setup_pack(128)
|
|
|
|
transport.pack(input, output)
|
|
|
|
|
|
|
|
assert output[:4] == b"\x8c\0\0\0"
|
|
|
|
assert output[4:8] == b"\0\0\0\0"
|
|
|
|
assert output[8 : 8 + len(input)] == input
|
|
|
|
assert output[8 + len(input) :] == b"\x86s\x957"
|
|
|
|
|
|
|
|
|
|
|
|
def test_pack_twice() -> None:
|
|
|
|
transport, input, output = setup_pack(128)
|
|
|
|
transport.pack(input, output)
|
|
|
|
output.clear()
|
|
|
|
transport.pack(input, output)
|
|
|
|
|
|
|
|
assert output[:4] == b"\x8c\0\0\0"
|
|
|
|
assert output[4:8] == b"\x01\0\0\0"
|
|
|
|
assert output[8 : 8 + len(input)] == input
|
|
|
|
assert output[8 + len(input) :] == b"\x96\t\xf0J"
|
|
|
|
|
|
|
|
|
|
|
|
def test_unpack_small() -> None:
|
|
|
|
transport = Full()
|
|
|
|
input = b"\0\x01\x02"
|
|
|
|
output = bytearray()
|
|
|
|
with raises(ValueError) as e:
|
|
|
|
transport.unpack(input, output)
|
|
|
|
e.match("missing bytes")
|
|
|
|
|
|
|
|
|
|
|
|
def test_unpack_normal() -> None:
|
|
|
|
expected_output, transport, input, output = setup_unpack(128)
|
|
|
|
transport.unpack(input, output)
|
|
|
|
assert output == expected_output
|
|
|
|
|
|
|
|
|
|
|
|
def test_unpack_twice() -> None:
|
|
|
|
transport, input, packed = setup_pack(128)
|
|
|
|
unpacked = bytearray()
|
|
|
|
transport.pack(input, packed)
|
|
|
|
transport.unpack(packed, unpacked)
|
|
|
|
assert input == unpacked
|
|
|
|
|
|
|
|
packed.clear()
|
|
|
|
unpacked.clear()
|
|
|
|
transport.pack(input, packed)
|
|
|
|
transport.unpack(packed, unpacked)
|
|
|
|
assert input == unpacked
|
|
|
|
|
|
|
|
|
|
|
|
def test_unpack_bad_crc() -> None:
|
|
|
|
_, transport, input, output = setup_unpack(128)
|
|
|
|
input = input[:-1] + bytes((input[-1] ^ 0xFF,))
|
|
|
|
with raises(ValueError) as e:
|
|
|
|
transport.unpack(input, output)
|
|
|
|
e.match("bad crc")
|
|
|
|
e.match("expected: 932541318")
|
|
|
|
e.match("got: 3365237638")
|
|
|
|
|
|
|
|
|
|
|
|
def test_unpack_bad_seq() -> None:
|
|
|
|
transport, input, packed = setup_pack(128)
|
|
|
|
unpacked = bytearray()
|
|
|
|
transport.pack(input, packed)
|
|
|
|
packed.clear()
|
|
|
|
transport.pack(input, packed)
|
|
|
|
with raises(ValueError) as e:
|
|
|
|
transport.unpack(packed, unpacked)
|
|
|
|
e.match("bad seq")
|
|
|
|
e.match("expected: 0")
|
|
|
|
e.match("got: 1")
|