2019-11-18 17:44:07 +02:00
|
|
|
from collections import deque
|
2020-01-22 22:54:29 +05:00
|
|
|
from typing import TYPE_CHECKING, AsyncGenerator, Deque, Optional, Type
|
2019-11-18 17:44:07 +02:00
|
|
|
|
|
|
|
|
from aiogram import Bot
|
2021-01-26 21:20:52 +02:00
|
|
|
from aiogram.client.session.base import BaseSession
|
|
|
|
|
from aiogram.methods import TelegramMethod
|
2021-05-25 00:56:44 +03:00
|
|
|
from aiogram.methods.base import Request, Response, TelegramType
|
|
|
|
|
from aiogram.types import UNSET, ResponseParameters
|
2019-11-18 17:44:07 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class MockedSession(BaseSession):
|
|
|
|
|
def __init__(self):
|
|
|
|
|
super(MockedSession, self).__init__()
|
2021-05-25 00:56:44 +03:00
|
|
|
self.responses: Deque[Response[TelegramType]] = deque()
|
2019-11-18 17:52:35 +02:00
|
|
|
self.requests: Deque[Request] = deque()
|
2019-11-18 17:44:07 +02:00
|
|
|
|
2021-05-25 00:56:44 +03:00
|
|
|
def add_result(self, response: Response[TelegramType]) -> Response[TelegramType]:
|
2019-11-18 17:44:07 +02:00
|
|
|
self.responses.append(response)
|
|
|
|
|
return response
|
|
|
|
|
|
|
|
|
|
def get_request(self) -> Request:
|
|
|
|
|
return self.requests.pop()
|
|
|
|
|
|
|
|
|
|
async def close(self):
|
|
|
|
|
pass
|
|
|
|
|
|
2020-06-14 17:14:10 +03:00
|
|
|
async def make_request(
|
2021-05-25 00:56:44 +03:00
|
|
|
self, bot: Bot, method: TelegramMethod[TelegramType], timeout: Optional[int] = UNSET
|
|
|
|
|
) -> TelegramType:
|
2020-06-14 18:18:29 +03:00
|
|
|
self.requests.append(method.build_request(bot))
|
2021-05-25 00:56:44 +03:00
|
|
|
response: Response[TelegramType] = self.responses.pop()
|
|
|
|
|
self.check_response(
|
|
|
|
|
method=method, status_code=response.error_code, content=response.json()
|
|
|
|
|
)
|
2019-11-18 17:52:35 +02:00
|
|
|
return response.result # type: ignore
|
2019-11-18 17:44:07 +02:00
|
|
|
|
2020-01-22 22:54:29 +05:00
|
|
|
async def stream_content(
|
|
|
|
|
self, url: str, timeout: int, chunk_size: int
|
|
|
|
|
) -> AsyncGenerator[bytes, None]: # pragma: no cover
|
|
|
|
|
yield b""
|
|
|
|
|
|
2019-11-18 17:44:07 +02:00
|
|
|
|
|
|
|
|
class MockedBot(Bot):
|
2019-11-18 17:52:35 +02:00
|
|
|
if TYPE_CHECKING:
|
|
|
|
|
session: MockedSession
|
|
|
|
|
|
2019-12-26 01:35:21 +02:00
|
|
|
def __init__(self, **kwargs):
|
|
|
|
|
super(MockedBot, self).__init__("42:TEST", session=MockedSession(), **kwargs)
|
2019-11-18 17:44:07 +02:00
|
|
|
|
|
|
|
|
def add_result_for(
|
|
|
|
|
self,
|
2021-05-25 00:56:44 +03:00
|
|
|
method: Type[TelegramMethod[TelegramType]],
|
2019-11-18 17:44:07 +02:00
|
|
|
ok: bool,
|
2021-05-25 00:56:44 +03:00
|
|
|
result: TelegramType = None,
|
2019-11-18 17:44:07 +02:00
|
|
|
description: Optional[str] = None,
|
|
|
|
|
error_code: Optional[int] = None,
|
|
|
|
|
migrate_to_chat_id: Optional[int] = None,
|
|
|
|
|
retry_after: Optional[int] = None,
|
2021-05-25 00:56:44 +03:00
|
|
|
) -> Response[TelegramType]:
|
2019-11-18 17:52:35 +02:00
|
|
|
response = Response[method.__returning__]( # type: ignore
|
2019-11-18 17:44:07 +02:00
|
|
|
ok=ok,
|
|
|
|
|
result=result,
|
|
|
|
|
description=description,
|
|
|
|
|
error_code=error_code,
|
2021-05-25 00:56:44 +03:00
|
|
|
parameters=ResponseParameters(
|
|
|
|
|
migrate_to_chat_id=migrate_to_chat_id,
|
|
|
|
|
retry_after=retry_after,
|
|
|
|
|
),
|
2019-11-18 17:44:07 +02:00
|
|
|
)
|
|
|
|
|
self.session.add_result(response)
|
|
|
|
|
return response
|
|
|
|
|
|
|
|
|
|
def get_request(self) -> Request:
|
|
|
|
|
return self.session.get_request()
|