mirror of
https://github.com/aiogram/aiogram.git
synced 2025-12-12 18:19:34 +00:00
Three properties of the Bot class - parse_mode, disable_web_page_preview, and protect_content - have been marked as deprecated with proper warning messages. The associated tests have also been added to confirm the working of these deprecation warnings. Users are advised to use the updated alternatives specified in the warning messages.
196 lines
6.2 KiB
Python
196 lines
6.2 KiB
Python
import io
|
|
import os
|
|
from tempfile import mkstemp
|
|
from unittest.mock import AsyncMock, MagicMock, patch
|
|
|
|
import aiofiles
|
|
import pytest
|
|
from aresponses import ResponsesMockServer
|
|
|
|
from aiogram import Bot
|
|
from aiogram.client.session.aiohttp import AiohttpSession
|
|
from aiogram.client.telegram import TelegramAPIServer
|
|
from aiogram.methods import GetFile, GetMe
|
|
from aiogram.types import File, PhotoSize
|
|
from tests.deprecated import check_deprecated
|
|
from tests.mocked_bot import MockedBot
|
|
|
|
|
|
@pytest.fixture()
|
|
async def bot():
|
|
"""Override mocked bot fixture with real bot."""
|
|
async with Bot("42:TEST").context() as bot:
|
|
yield bot
|
|
|
|
|
|
@pytest.fixture()
|
|
def mocked_bot():
|
|
"""Mocked bot fixture."""
|
|
return MockedBot()
|
|
|
|
|
|
@pytest.fixture()
|
|
async def session():
|
|
"""Override session fixture."""
|
|
async with AiohttpSession() as session:
|
|
yield session
|
|
|
|
|
|
class TestBot:
|
|
def test_init(self):
|
|
bot = Bot("42:TEST")
|
|
assert isinstance(bot.session, AiohttpSession)
|
|
assert bot.id == 42
|
|
|
|
def test_init_default(self):
|
|
with check_deprecated(
|
|
max_version="3.5.0",
|
|
exception=TypeError,
|
|
):
|
|
bot = Bot(token="42:Test", parse_mode="HTML")
|
|
|
|
def test_deprecated_parse_mode(self):
|
|
with check_deprecated(
|
|
max_version="3.5.0",
|
|
exception=AttributeError,
|
|
):
|
|
bot = Bot(token="42:Test", parse_mode="HTML")
|
|
assert bot.parse_mode == "HTML"
|
|
|
|
def test_disable_web_page_preview(self):
|
|
with check_deprecated(
|
|
max_version="3.5.0",
|
|
exception=TypeError,
|
|
):
|
|
bot = Bot(token="42:Test", disable_web_page_preview=True)
|
|
assert bot.disable_web_page_preview is True
|
|
|
|
def test_deprecated_protect_content(self):
|
|
with check_deprecated(
|
|
max_version="3.5.0",
|
|
exception=AttributeError,
|
|
):
|
|
bot = Bot(token="42:Test", protect_content=True)
|
|
assert bot.protect_content is True
|
|
|
|
def test_hashable(self):
|
|
bot = Bot("42:TEST")
|
|
assert hash(bot) == hash("42:TEST")
|
|
|
|
def test_equals(self):
|
|
bot = Bot("42:TEST")
|
|
assert bot == Bot("42:TEST")
|
|
assert bot != "42:TEST"
|
|
|
|
async def test_emit(self, bot: Bot):
|
|
method = GetMe()
|
|
|
|
with patch(
|
|
"aiogram.client.session.aiohttp.AiohttpSession.make_request",
|
|
new_callable=AsyncMock,
|
|
) as mocked_make_request:
|
|
await bot(method)
|
|
mocked_make_request.assert_awaited_with(bot, method, timeout=None)
|
|
|
|
async def test_close(self, session: AiohttpSession):
|
|
bot = Bot("42:TEST", session=session)
|
|
await session.create_session()
|
|
|
|
with patch(
|
|
"aiogram.client.session.aiohttp.AiohttpSession.close", new_callable=AsyncMock
|
|
) as mocked_close:
|
|
await bot.session.close()
|
|
mocked_close.assert_awaited()
|
|
|
|
@pytest.mark.parametrize("close", [True, False])
|
|
async def test_context_manager(self, close: bool):
|
|
with patch(
|
|
target="aiogram.client.session.aiohttp.AiohttpSession.close",
|
|
new_callable=AsyncMock,
|
|
) as mocked_close:
|
|
session = AiohttpSession()
|
|
async with Bot("42:TEST", session=session).context(auto_close=close) as bot:
|
|
assert isinstance(bot, Bot)
|
|
|
|
if close:
|
|
mocked_close.assert_awaited()
|
|
else:
|
|
mocked_close.assert_not_awaited()
|
|
await session.close()
|
|
|
|
async def test_download_file(self, aresponses: ResponsesMockServer):
|
|
aresponses.add(
|
|
method_pattern="get",
|
|
response=aresponses.Response(status=200, body=b"\f" * 10),
|
|
)
|
|
|
|
# https://github.com/Tinche/aiofiles#writing-tests-for-aiofiles
|
|
aiofiles.threadpool.wrap.register(MagicMock)(
|
|
lambda *args, **kwargs: aiofiles.threadpool.binary.AsyncBufferedIOBase(*args, **kwargs)
|
|
)
|
|
|
|
mock_file = MagicMock()
|
|
|
|
async with Bot("42:TEST").context() as bot:
|
|
with patch("aiofiles.threadpool.sync_open", return_value=mock_file):
|
|
await bot.download_file("TEST", "file.png")
|
|
mock_file.write.assert_called_once_with(b"\f" * 10)
|
|
|
|
async def test_download_file_default_destination(
|
|
self,
|
|
bot: Bot,
|
|
aresponses: ResponsesMockServer,
|
|
):
|
|
aresponses.add(
|
|
method_pattern="get",
|
|
response=aresponses.Response(status=200, body=b"\f" * 10),
|
|
)
|
|
result = await bot.download_file("TEST")
|
|
|
|
assert isinstance(result, io.BytesIO)
|
|
assert result.read() == b"\f" * 10
|
|
|
|
async def test_download_file_custom_destination(
|
|
self,
|
|
bot: Bot,
|
|
aresponses: ResponsesMockServer,
|
|
):
|
|
aresponses.add(
|
|
method_pattern="get",
|
|
response=aresponses.Response(status=200, body=b"\f" * 10),
|
|
)
|
|
custom = io.BytesIO()
|
|
|
|
result = await bot.download_file("TEST", custom)
|
|
|
|
assert isinstance(result, io.BytesIO)
|
|
assert result is custom
|
|
assert result.read() == b"\f" * 10
|
|
|
|
async def test_download(self, mocked_bot: MockedBot):
|
|
mocked_bot.add_result_for(
|
|
GetFile, ok=True, result=File(file_id="file id", file_unique_id="file id")
|
|
)
|
|
mocked_bot.add_result_for(
|
|
GetFile, ok=True, result=File(file_id="file id", file_unique_id="file id")
|
|
)
|
|
|
|
assert await mocked_bot.download(File(file_id="file id", file_unique_id="file id"))
|
|
assert await mocked_bot.download("file id")
|
|
|
|
with pytest.raises(TypeError):
|
|
await mocked_bot.download(
|
|
[PhotoSize(file_id="file id", file_unique_id="file id", width=123, height=123)]
|
|
)
|
|
|
|
async def test_download_local_file(self, bot: MockedBot):
|
|
bot.session.api = TelegramAPIServer.from_base("http://localhost:8081", is_local=True)
|
|
fd, tmp = mkstemp(prefix="test-", suffix=".txt")
|
|
value = b"KABOOM"
|
|
try:
|
|
with open(fd, "wb") as f:
|
|
f.write(value)
|
|
content = await bot.download_file(tmp)
|
|
assert content.getvalue() == value
|
|
finally:
|
|
os.unlink(tmp)
|