mirror of
https://github.com/python-telegram-bot/python-telegram-bot.git
synced 2025-01-23 08:47:14 +01:00
Add new conftest file in _files/
This commit is contained in:
parent
2ca1ce2762
commit
cb5425652d
15 changed files with 169 additions and 170 deletions
|
@ -66,7 +66,7 @@ markers = [
|
||||||
"no_req",
|
"no_req",
|
||||||
"req",
|
"req",
|
||||||
]
|
]
|
||||||
asyncio_mode = "auto"
|
# asyncio_mode = "auto"
|
||||||
log_format = "%(funcName)s - Line %(lineno)d - %(message)s"
|
log_format = "%(funcName)s - Line %(lineno)d - %(message)s"
|
||||||
# log_level = "DEBUG" # uncomment to see DEBUG logs
|
# log_level = "DEBUG" # uncomment to see DEBUG logs
|
||||||
|
|
||||||
|
|
106
tests/_files/conftest.py
Normal file
106
tests/_files/conftest.py
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
#
|
||||||
|
# A library that provides a Python interface to the Telegram Bot API
|
||||||
|
# Copyright (C) 2015-2024
|
||||||
|
# Leandro Toledo de Souza <devs@python-telegram-bot.org>
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Lesser Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU Lesser Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Lesser Public License
|
||||||
|
# along with this program. If not, see [http://www.gnu.org/licenses/].
|
||||||
|
"""Module to provide fixtures most of which are used in test_inputmedia.py."""
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
from tests.auxil.files import data_file
|
||||||
|
from tests.auxil.networking import expect_bad_request
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def animation_file():
|
||||||
|
with data_file("game.gif").open("rb") as f:
|
||||||
|
yield f
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
async def animation(bot, chat_id, aiolib):
|
||||||
|
with data_file("game.gif").open("rb") as f, data_file("thumb.jpg").open("rb") as thumb:
|
||||||
|
return (
|
||||||
|
await bot.send_animation(chat_id, animation=f, read_timeout=50, thumbnail=thumb)
|
||||||
|
).animation
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def audio_file():
|
||||||
|
with data_file("telegram.mp3").open("rb") as f:
|
||||||
|
yield f
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
async def audio(bot, chat_id, aiolib):
|
||||||
|
with data_file("telegram.mp3").open("rb") as f, data_file("thumb.jpg").open("rb") as thumb:
|
||||||
|
return (await bot.send_audio(chat_id, audio=f, read_timeout=50, thumbnail=thumb)).audio
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def document_file():
|
||||||
|
with data_file("telegram.png").open("rb") as f:
|
||||||
|
yield f
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
async def document(bot, chat_id, aiolib):
|
||||||
|
with data_file("telegram.png").open("rb") as f:
|
||||||
|
return (await bot.send_document(chat_id, document=f, read_timeout=50)).document
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def photo_file():
|
||||||
|
with data_file("telegram.jpg").open("rb") as f:
|
||||||
|
yield f
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
async def photolist(bot, chat_id, aiolib):
|
||||||
|
async def func():
|
||||||
|
with data_file("telegram.jpg").open("rb") as f:
|
||||||
|
return (await bot.send_photo(chat_id, photo=f, read_timeout=50)).photo
|
||||||
|
|
||||||
|
return await expect_bad_request(
|
||||||
|
func, "Type of file mismatch", "Telegram did not accept the file."
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
def thumb(photolist):
|
||||||
|
return photolist[0]
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
def photo(photolist):
|
||||||
|
return photolist[-1]
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def video_file():
|
||||||
|
with data_file("telegram.mp4").open("rb") as f:
|
||||||
|
yield f
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
async def video(bot, chat_id, aiolib):
|
||||||
|
with data_file("telegram.mp4").open("rb") as f:
|
||||||
|
return (await bot.send_video(chat_id, video=f, read_timeout=50)).video
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def video_sticker_file():
|
||||||
|
with data_file("telegram_video_sticker.webm").open("rb") as f:
|
||||||
|
yield f
|
|
@ -37,20 +37,6 @@ from tests.auxil.files import data_file
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
|
||||||
def animation_file():
|
|
||||||
with data_file("game.gif").open("rb") as f:
|
|
||||||
yield f
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
|
||||||
async def animation(bot, chat_id):
|
|
||||||
with data_file("game.gif").open("rb") as f, data_file("thumb.jpg").open("rb") as thumb:
|
|
||||||
return (
|
|
||||||
await bot.send_animation(chat_id, animation=f, read_timeout=50, thumbnail=thumb)
|
|
||||||
).animation
|
|
||||||
|
|
||||||
|
|
||||||
class TestAnimationBase:
|
class TestAnimationBase:
|
||||||
animation_file_id = "CgADAQADngIAAuyVeEez0xRovKi9VAI"
|
animation_file_id = "CgADAQADngIAAuyVeEez0xRovKi9VAI"
|
||||||
animation_file_unique_id = "adc3145fd2e84d95b64d68eaa22aa33e"
|
animation_file_unique_id = "adc3145fd2e84d95b64d68eaa22aa33e"
|
||||||
|
|
|
@ -37,18 +37,6 @@ from tests.auxil.files import data_file
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
|
||||||
def audio_file():
|
|
||||||
with data_file("telegram.mp3").open("rb") as f:
|
|
||||||
yield f
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
|
||||||
async def audio(bot, chat_id):
|
|
||||||
with data_file("telegram.mp3").open("rb") as f, data_file("thumb.jpg").open("rb") as thumb:
|
|
||||||
return (await bot.send_audio(chat_id, audio=f, read_timeout=50, thumbnail=thumb)).audio
|
|
||||||
|
|
||||||
|
|
||||||
class TestAudioBase:
|
class TestAudioBase:
|
||||||
caption = "Test *audio*"
|
caption = "Test *audio*"
|
||||||
performer = "Leandro Toledo"
|
performer = "Leandro Toledo"
|
||||||
|
|
|
@ -37,18 +37,6 @@ from tests.auxil.files import data_file
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
|
||||||
def document_file():
|
|
||||||
with data_file("telegram.png").open("rb") as f:
|
|
||||||
yield f
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
|
||||||
async def document(bot, chat_id):
|
|
||||||
with data_file("telegram.png").open("rb") as f:
|
|
||||||
return (await bot.send_document(chat_id, document=f, read_timeout=50)).document
|
|
||||||
|
|
||||||
|
|
||||||
class TestDocumentBase:
|
class TestDocumentBase:
|
||||||
caption = "DocumentTest - *Caption*"
|
caption = "DocumentTest - *Caption*"
|
||||||
document_file_url = "https://python-telegram-bot.org/static/testfiles/telegram.gif"
|
document_file_url = "https://python-telegram-bot.org/static/testfiles/telegram.gif"
|
||||||
|
|
|
@ -36,32 +36,14 @@ from telegram import (
|
||||||
ReplyParameters,
|
ReplyParameters,
|
||||||
)
|
)
|
||||||
from telegram.constants import InputMediaType, ParseMode
|
from telegram.constants import InputMediaType, ParseMode
|
||||||
|
|
||||||
# noinspection PyUnresolvedReferences
|
|
||||||
from telegram.error import BadRequest
|
from telegram.error import BadRequest
|
||||||
from telegram.request import RequestData
|
from telegram.request import RequestData
|
||||||
from tests._files.test_animation import animation, animation_file # noqa: F401
|
|
||||||
from tests.auxil.files import data_file
|
from tests.auxil.files import data_file
|
||||||
from tests.auxil.networking import expect_bad_request
|
from tests.auxil.networking import expect_bad_request
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
# noinspection PyUnresolvedReferences
|
|
||||||
from tests.test_forum import emoji_id, real_topic # noqa: F401
|
|
||||||
|
|
||||||
from ..auxil.build_messages import make_message
|
from ..auxil.build_messages import make_message
|
||||||
|
|
||||||
# noinspection PyUnresolvedReferences
|
|
||||||
from .test_audio import audio, audio_file # noqa: F401
|
|
||||||
|
|
||||||
# noinspection PyUnresolvedReferences
|
|
||||||
from .test_document import document, document_file # noqa: F401
|
|
||||||
|
|
||||||
# noinspection PyUnresolvedReferences
|
|
||||||
from .test_photo import photo, photo_file, photolist, thumb # noqa: F401
|
|
||||||
|
|
||||||
# noinspection PyUnresolvedReferences
|
|
||||||
from .test_video import video, video_file # noqa: F401
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
@pytest.fixture(scope="module")
|
||||||
def input_media_video(class_thumb_file):
|
def input_media_video(class_thumb_file):
|
||||||
|
@ -183,7 +165,7 @@ class TestInputMediaVideoWithoutRequest(TestInputMediaVideoBase):
|
||||||
assert input_media_video_dict["supports_streaming"] == input_media_video.supports_streaming
|
assert input_media_video_dict["supports_streaming"] == input_media_video.supports_streaming
|
||||||
assert input_media_video_dict["has_spoiler"] == input_media_video.has_spoiler
|
assert input_media_video_dict["has_spoiler"] == input_media_video.has_spoiler
|
||||||
|
|
||||||
def test_with_video(self, video): # noqa: F811
|
def test_with_video(self, video):
|
||||||
# fixture found in test_video
|
# fixture found in test_video
|
||||||
input_media_video = InputMediaVideo(video, caption="test 3")
|
input_media_video = InputMediaVideo(video, caption="test 3")
|
||||||
assert input_media_video.type == self.type_
|
assert input_media_video.type == self.type_
|
||||||
|
@ -193,7 +175,7 @@ class TestInputMediaVideoWithoutRequest(TestInputMediaVideoBase):
|
||||||
assert input_media_video.duration == video.duration
|
assert input_media_video.duration == video.duration
|
||||||
assert input_media_video.caption == "test 3"
|
assert input_media_video.caption == "test 3"
|
||||||
|
|
||||||
def test_with_video_file(self, video_file): # noqa: F811
|
def test_with_video_file(self, video_file):
|
||||||
# fixture found in test_video
|
# fixture found in test_video
|
||||||
input_media_video = InputMediaVideo(video_file, caption="test 3")
|
input_media_video = InputMediaVideo(video_file, caption="test 3")
|
||||||
assert input_media_video.type == self.type_
|
assert input_media_video.type == self.type_
|
||||||
|
@ -267,14 +249,14 @@ class TestInputMediaPhotoWithoutRequest(TestInputMediaPhotoBase):
|
||||||
]
|
]
|
||||||
assert input_media_photo_dict["has_spoiler"] == input_media_photo.has_spoiler
|
assert input_media_photo_dict["has_spoiler"] == input_media_photo.has_spoiler
|
||||||
|
|
||||||
def test_with_photo(self, photo): # noqa: F811
|
def test_with_photo(self, photo):
|
||||||
# fixture found in test_photo
|
# fixture found in test_photo
|
||||||
input_media_photo = InputMediaPhoto(photo, caption="test 2")
|
input_media_photo = InputMediaPhoto(photo, caption="test 2")
|
||||||
assert input_media_photo.type == self.type_
|
assert input_media_photo.type == self.type_
|
||||||
assert input_media_photo.media == photo.file_id
|
assert input_media_photo.media == photo.file_id
|
||||||
assert input_media_photo.caption == "test 2"
|
assert input_media_photo.caption == "test 2"
|
||||||
|
|
||||||
def test_with_photo_file(self, photo_file): # noqa: F811
|
def test_with_photo_file(self, photo_file):
|
||||||
# fixture found in test_photo
|
# fixture found in test_photo
|
||||||
input_media_photo = InputMediaPhoto(photo_file, caption="test 2")
|
input_media_photo = InputMediaPhoto(photo_file, caption="test 2")
|
||||||
assert input_media_photo.type == self.type_
|
assert input_media_photo.type == self.type_
|
||||||
|
@ -332,14 +314,14 @@ class TestInputMediaAnimationWithoutRequest(TestInputMediaAnimationBase):
|
||||||
assert input_media_animation_dict["duration"] == input_media_animation.duration
|
assert input_media_animation_dict["duration"] == input_media_animation.duration
|
||||||
assert input_media_animation_dict["has_spoiler"] == input_media_animation.has_spoiler
|
assert input_media_animation_dict["has_spoiler"] == input_media_animation.has_spoiler
|
||||||
|
|
||||||
def test_with_animation(self, animation): # noqa: F811
|
def test_with_animation(self, animation):
|
||||||
# fixture found in test_animation
|
# fixture found in test_animation
|
||||||
input_media_animation = InputMediaAnimation(animation, caption="test 2")
|
input_media_animation = InputMediaAnimation(animation, caption="test 2")
|
||||||
assert input_media_animation.type == self.type_
|
assert input_media_animation.type == self.type_
|
||||||
assert input_media_animation.media == animation.file_id
|
assert input_media_animation.media == animation.file_id
|
||||||
assert input_media_animation.caption == "test 2"
|
assert input_media_animation.caption == "test 2"
|
||||||
|
|
||||||
def test_with_animation_file(self, animation_file): # noqa: F811
|
def test_with_animation_file(self, animation_file):
|
||||||
# fixture found in test_animation
|
# fixture found in test_animation
|
||||||
input_media_animation = InputMediaAnimation(animation_file, caption="test 2")
|
input_media_animation = InputMediaAnimation(animation_file, caption="test 2")
|
||||||
assert input_media_animation.type == self.type_
|
assert input_media_animation.type == self.type_
|
||||||
|
@ -400,7 +382,7 @@ class TestInputMediaAudioWithoutRequest(TestInputMediaAudioBase):
|
||||||
ce.to_dict() for ce in input_media_audio.caption_entities
|
ce.to_dict() for ce in input_media_audio.caption_entities
|
||||||
]
|
]
|
||||||
|
|
||||||
def test_with_audio(self, audio): # noqa: F811
|
def test_with_audio(self, audio):
|
||||||
# fixture found in test_audio
|
# fixture found in test_audio
|
||||||
input_media_audio = InputMediaAudio(audio, caption="test 3")
|
input_media_audio = InputMediaAudio(audio, caption="test 3")
|
||||||
assert input_media_audio.type == self.type_
|
assert input_media_audio.type == self.type_
|
||||||
|
@ -410,7 +392,7 @@ class TestInputMediaAudioWithoutRequest(TestInputMediaAudioBase):
|
||||||
assert input_media_audio.title == audio.title
|
assert input_media_audio.title == audio.title
|
||||||
assert input_media_audio.caption == "test 3"
|
assert input_media_audio.caption == "test 3"
|
||||||
|
|
||||||
def test_with_audio_file(self, audio_file): # noqa: F811
|
def test_with_audio_file(self, audio_file):
|
||||||
# fixture found in test_audio
|
# fixture found in test_audio
|
||||||
input_media_audio = InputMediaAudio(audio_file, caption="test 3")
|
input_media_audio = InputMediaAudio(audio_file, caption="test 3")
|
||||||
assert input_media_audio.type == self.type_
|
assert input_media_audio.type == self.type_
|
||||||
|
@ -471,14 +453,14 @@ class TestInputMediaDocumentWithoutRequest(TestInputMediaDocumentBase):
|
||||||
== input_media_document.disable_content_type_detection
|
== input_media_document.disable_content_type_detection
|
||||||
)
|
)
|
||||||
|
|
||||||
def test_with_document(self, document): # noqa: F811
|
def test_with_document(self, document):
|
||||||
# fixture found in test_document
|
# fixture found in test_document
|
||||||
input_media_document = InputMediaDocument(document, caption="test 3")
|
input_media_document = InputMediaDocument(document, caption="test 3")
|
||||||
assert input_media_document.type == self.type_
|
assert input_media_document.type == self.type_
|
||||||
assert input_media_document.media == document.file_id
|
assert input_media_document.media == document.file_id
|
||||||
assert input_media_document.caption == "test 3"
|
assert input_media_document.caption == "test 3"
|
||||||
|
|
||||||
def test_with_document_file(self, document_file): # noqa: F811
|
def test_with_document_file(self, document_file):
|
||||||
# fixture found in test_document
|
# fixture found in test_document
|
||||||
input_media_document = InputMediaDocument(document_file, caption="test 3")
|
input_media_document = InputMediaDocument(document_file, caption="test 3")
|
||||||
assert input_media_document.type == self.type_
|
assert input_media_document.type == self.type_
|
||||||
|
@ -494,7 +476,7 @@ class TestInputMediaDocumentWithoutRequest(TestInputMediaDocumentBase):
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
@pytest.fixture(scope="module")
|
||||||
def media_group(photo, thumb): # noqa: F811
|
def media_group(photo, thumb):
|
||||||
return [
|
return [
|
||||||
InputMediaPhoto(photo, caption="*photo* 1", parse_mode="Markdown"),
|
InputMediaPhoto(photo, caption="*photo* 1", parse_mode="Markdown"),
|
||||||
InputMediaPhoto(thumb, caption="<b>photo</b> 2", parse_mode="HTML"),
|
InputMediaPhoto(thumb, caption="<b>photo</b> 2", parse_mode="HTML"),
|
||||||
|
@ -505,12 +487,12 @@ def media_group(photo, thumb): # noqa: F811
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
@pytest.fixture(scope="module")
|
||||||
def media_group_no_caption_args(photo, thumb): # noqa: F811
|
def media_group_no_caption_args(photo, thumb):
|
||||||
return [InputMediaPhoto(photo), InputMediaPhoto(thumb), InputMediaPhoto(photo)]
|
return [InputMediaPhoto(photo), InputMediaPhoto(thumb), InputMediaPhoto(photo)]
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
@pytest.fixture(scope="module")
|
||||||
def media_group_no_caption_only_caption_entities(photo, thumb): # noqa: F811
|
def media_group_no_caption_only_caption_entities(photo, thumb):
|
||||||
return [
|
return [
|
||||||
InputMediaPhoto(photo, caption_entities=[MessageEntity(MessageEntity.BOLD, 0, 5)]),
|
InputMediaPhoto(photo, caption_entities=[MessageEntity(MessageEntity.BOLD, 0, 5)]),
|
||||||
InputMediaPhoto(photo, caption_entities=[MessageEntity(MessageEntity.BOLD, 0, 5)]),
|
InputMediaPhoto(photo, caption_entities=[MessageEntity(MessageEntity.BOLD, 0, 5)]),
|
||||||
|
@ -518,7 +500,7 @@ def media_group_no_caption_only_caption_entities(photo, thumb): # noqa: F811
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
@pytest.fixture(scope="module")
|
||||||
def media_group_no_caption_only_parse_mode(photo, thumb): # noqa: F811
|
def media_group_no_caption_only_parse_mode(photo, thumb):
|
||||||
return [
|
return [
|
||||||
InputMediaPhoto(photo, parse_mode="Markdown"),
|
InputMediaPhoto(photo, parse_mode="Markdown"),
|
||||||
InputMediaPhoto(thumb, parse_mode="HTML"),
|
InputMediaPhoto(thumb, parse_mode="HTML"),
|
||||||
|
@ -549,10 +531,10 @@ class TestSendMediaGroupWithoutRequest:
|
||||||
self,
|
self,
|
||||||
bot,
|
bot,
|
||||||
chat_id,
|
chat_id,
|
||||||
photo_file, # noqa: F811
|
photo_file,
|
||||||
animation_file, # noqa: F811
|
animation_file,
|
||||||
audio_file, # noqa: F811
|
audio_file,
|
||||||
video_file, # noqa: F811
|
video_file,
|
||||||
monkeypatch,
|
monkeypatch,
|
||||||
):
|
):
|
||||||
async def make_assertion(url, request_data: RequestData, *args, **kwargs):
|
async def make_assertion(url, request_data: RequestData, *args, **kwargs):
|
||||||
|
@ -576,7 +558,7 @@ class TestSendMediaGroupWithoutRequest:
|
||||||
await bot.send_media_group(chat_id, media)
|
await bot.send_media_group(chat_id, media)
|
||||||
|
|
||||||
async def test_send_media_group_with_thumbs(
|
async def test_send_media_group_with_thumbs(
|
||||||
self, bot, chat_id, video_file, photo_file, monkeypatch # noqa: F811
|
self, bot, chat_id, video_file, photo_file, monkeypatch
|
||||||
):
|
):
|
||||||
async def make_assertion(method, url, request_data: RequestData, *args, **kwargs):
|
async def make_assertion(method, url, request_data: RequestData, *args, **kwargs):
|
||||||
nonlocal input_video
|
nonlocal input_video
|
||||||
|
@ -594,7 +576,7 @@ class TestSendMediaGroupWithoutRequest:
|
||||||
await bot.send_media_group(chat_id, [input_video, input_video])
|
await bot.send_media_group(chat_id, [input_video, input_video])
|
||||||
|
|
||||||
async def test_edit_message_media_with_thumb(
|
async def test_edit_message_media_with_thumb(
|
||||||
self, bot, chat_id, video_file, photo_file, monkeypatch # noqa: F811
|
self, bot, chat_id, video_file, photo_file, monkeypatch
|
||||||
):
|
):
|
||||||
async def make_assertion(
|
async def make_assertion(
|
||||||
method: str, url: str, request_data: Optional[RequestData] = None, *args, **kwargs
|
method: str, url: str, request_data: Optional[RequestData] = None, *args, **kwargs
|
||||||
|
@ -663,9 +645,7 @@ class TestSendMediaGroupWithRequest:
|
||||||
mes.caption_entities == (MessageEntity(MessageEntity.BOLD, 0, 5),) for mes in messages
|
mes.caption_entities == (MessageEntity(MessageEntity.BOLD, 0, 5),) for mes in messages
|
||||||
)
|
)
|
||||||
|
|
||||||
async def test_send_media_group_new_files(
|
async def test_send_media_group_new_files(self, bot, chat_id, video_file, photo_file):
|
||||||
self, bot, chat_id, video_file, photo_file # noqa: F811
|
|
||||||
):
|
|
||||||
async def func():
|
async def func():
|
||||||
return await bot.send_media_group(
|
return await bot.send_media_group(
|
||||||
chat_id,
|
chat_id,
|
||||||
|
@ -701,7 +681,7 @@ class TestSendMediaGroupWithRequest:
|
||||||
assert all(mes.media_group_id == messages[0].media_group_id for mes in messages)
|
assert all(mes.media_group_id == messages[0].media_group_id for mes in messages)
|
||||||
|
|
||||||
async def test_send_media_group_with_message_thread_id(
|
async def test_send_media_group_with_message_thread_id(
|
||||||
self, bot, real_topic, forum_group_id, media_group # noqa: F811
|
self, bot, real_topic, forum_group_id, media_group
|
||||||
):
|
):
|
||||||
messages = await bot.send_media_group(
|
messages = await bot.send_media_group(
|
||||||
forum_group_id,
|
forum_group_id,
|
||||||
|
@ -800,9 +780,7 @@ class TestSendMediaGroupWithRequest:
|
||||||
)
|
)
|
||||||
assert all(mes.has_protected_content for mes in messages)
|
assert all(mes.has_protected_content for mes in messages)
|
||||||
|
|
||||||
async def test_send_media_group_with_spoiler(
|
async def test_send_media_group_with_spoiler(self, bot, chat_id, photo_file, video_file):
|
||||||
self, bot, chat_id, photo_file, video_file # noqa: F811
|
|
||||||
):
|
|
||||||
# Media groups can't contain Animations, so that is tested in test_animation.py
|
# Media groups can't contain Animations, so that is tested in test_animation.py
|
||||||
media = [
|
media = [
|
||||||
InputMediaPhoto(photo_file, has_spoiler=True),
|
InputMediaPhoto(photo_file, has_spoiler=True),
|
||||||
|
@ -945,11 +923,11 @@ class TestSendMediaGroupWithRequest:
|
||||||
chat_id,
|
chat_id,
|
||||||
default_bot,
|
default_bot,
|
||||||
media_type,
|
media_type,
|
||||||
animation, # noqa: F811
|
animation,
|
||||||
document, # noqa: F811
|
document,
|
||||||
audio, # noqa: F811
|
audio,
|
||||||
photo, # noqa: F811
|
photo,
|
||||||
video, # noqa: F811
|
video,
|
||||||
):
|
):
|
||||||
html_caption = "<b>bold</b> <i>italic</i> <code>code</code>"
|
html_caption = "<b>bold</b> <i>italic</i> <code>code</code>"
|
||||||
markdown_caption = "*bold* _italic_ `code`"
|
markdown_caption = "*bold* _italic_ `code`"
|
||||||
|
|
|
@ -21,7 +21,6 @@ import pytest
|
||||||
|
|
||||||
from telegram import InputSticker, MaskPosition
|
from telegram import InputSticker, MaskPosition
|
||||||
from telegram._files.inputfile import InputFile
|
from telegram._files.inputfile import InputFile
|
||||||
from tests._files.test_sticker import video_sticker_file # noqa: F401
|
|
||||||
from tests.auxil.files import data_file
|
from tests.auxil.files import data_file
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
|
@ -77,7 +76,7 @@ class TestInputStickerWithoutRequest(TestInputStickerBase):
|
||||||
assert input_sticker_dict["keywords"] == list(input_sticker.keywords)
|
assert input_sticker_dict["keywords"] == list(input_sticker.keywords)
|
||||||
assert input_sticker_dict["format"] == input_sticker.format
|
assert input_sticker_dict["format"] == input_sticker.format
|
||||||
|
|
||||||
def test_with_sticker_input_types(self, video_sticker_file): # noqa: F811
|
def test_with_sticker_input_types(self, video_sticker_file):
|
||||||
sticker = InputSticker(sticker=video_sticker_file, emoji_list=["👍"], format="video")
|
sticker = InputSticker(sticker=video_sticker_file, emoji_list=["👍"], format="video")
|
||||||
assert isinstance(sticker.sticker, InputFile)
|
assert isinstance(sticker.sticker, InputFile)
|
||||||
sticker = InputSticker(data_file("telegram_video_sticker.webm"), ["👍"], "video")
|
sticker = InputSticker(data_file("telegram_video_sticker.webm"), ["👍"], "video")
|
||||||
|
|
|
@ -34,37 +34,9 @@ from tests.auxil.bot_method_checks import (
|
||||||
)
|
)
|
||||||
from tests.auxil.build_messages import make_message
|
from tests.auxil.build_messages import make_message
|
||||||
from tests.auxil.files import data_file
|
from tests.auxil.files import data_file
|
||||||
from tests.auxil.networking import expect_bad_request
|
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
|
||||||
def photo_file():
|
|
||||||
with data_file("telegram.jpg").open("rb") as f:
|
|
||||||
yield f
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
|
||||||
async def photolist(bot, chat_id):
|
|
||||||
async def func():
|
|
||||||
with data_file("telegram.jpg").open("rb") as f:
|
|
||||||
return (await bot.send_photo(chat_id, photo=f, read_timeout=50)).photo
|
|
||||||
|
|
||||||
return await expect_bad_request(
|
|
||||||
func, "Type of file mismatch", "Telegram did not accept the file."
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
|
||||||
def thumb(photolist):
|
|
||||||
return photolist[0]
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
|
||||||
def photo(photolist):
|
|
||||||
return photolist[-1]
|
|
||||||
|
|
||||||
|
|
||||||
class TestPhotoBase:
|
class TestPhotoBase:
|
||||||
width = 800
|
width = 800
|
||||||
height = 800
|
height = 800
|
||||||
|
|
|
@ -77,12 +77,6 @@ async def animated_sticker(bot, chat_id):
|
||||||
return (await bot.send_sticker(chat_id, sticker=f, read_timeout=50)).sticker
|
return (await bot.send_sticker(chat_id, sticker=f, read_timeout=50)).sticker
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
|
||||||
def video_sticker_file():
|
|
||||||
with data_file("telegram_video_sticker.webm").open("rb") as f:
|
|
||||||
yield f
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
@pytest.fixture(scope="module")
|
||||||
def video_sticker(bot, chat_id):
|
def video_sticker(bot, chat_id):
|
||||||
with data_file("telegram_video_sticker.webm").open("rb") as f:
|
with data_file("telegram_video_sticker.webm").open("rb") as f:
|
||||||
|
|
|
@ -37,18 +37,6 @@ from tests.auxil.files import data_file
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
|
||||||
def video_file():
|
|
||||||
with data_file("telegram.mp4").open("rb") as f:
|
|
||||||
yield f
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
|
||||||
async def video(bot, chat_id):
|
|
||||||
with data_file("telegram.mp4").open("rb") as f:
|
|
||||||
return (await bot.send_video(chat_id, video=f, read_timeout=50)).video
|
|
||||||
|
|
||||||
|
|
||||||
class TestVideoBase:
|
class TestVideoBase:
|
||||||
width = 360
|
width = 360
|
||||||
height = 640
|
height = 640
|
||||||
|
|
|
@ -244,7 +244,7 @@ class TestVideoNoteWithRequest(TestVideoNoteBase):
|
||||||
assert message.video_note.thumbnail.height == self.thumb_height
|
assert message.video_note.thumbnail.height == self.thumb_height
|
||||||
assert message.has_protected_content
|
assert message.has_protected_content
|
||||||
|
|
||||||
async def test_get_and_download(self, bot, video_note, chat_id, tmp_file):
|
async def test_get_and_download(self, bot, video_note, tmp_file):
|
||||||
new_file = await bot.get_file(video_note.file_id)
|
new_file = await bot.get_file(video_note.file_id)
|
||||||
|
|
||||||
assert new_file.file_size == self.file_size
|
assert new_file.file_size == self.file_size
|
||||||
|
|
|
@ -20,3 +20,7 @@
|
||||||
# THIS KEY IS OBVIOUSLY COMPROMISED
|
# THIS KEY IS OBVIOUSLY COMPROMISED
|
||||||
# DO NOT USE IN PRODUCTION!
|
# DO NOT USE IN PRODUCTION!
|
||||||
PRIVATE_KEY = b"-----BEGIN RSA PRIVATE KEY-----\r\nMIIEowIBAAKCAQEA0AvEbNaOnfIL3GjB8VI4M5IaWe+GcK8eSPHkLkXREIsaddum\r\nwPBm/+w8lFYdnY+O06OEJrsaDtwGdU//8cbGJ/H/9cJH3dh0tNbfszP7nTrQD+88\r\nydlcYHzClaG8G+oTe9uEZSVdDXj5IUqR0y6rDXXb9tC9l+oSz+ShYg6+C4grAb3E\r\nSTv5khZ9Zsi/JEPWStqNdpoNuRh7qEYc3t4B/a5BH7bsQENyJSc8AWrfv+drPAEe\r\njQ8xm1ygzWvJp8yZPwOIYuL+obtANcoVT2G2150Wy6qLC0bD88Bm40GqLbSazueC\r\nRHZRug0B9rMUKvKc4FhG4AlNzBCaKgIcCWEqKwIDAQABAoIBACcIjin9d3Sa3S7V\r\nWM32JyVF3DvTfN3XfU8iUzV7U+ZOswA53eeFM04A/Ly4C4ZsUNfUbg72O8Vd8rg/\r\n8j1ilfsYpHVvphwxaHQlfIMa1bKCPlc/A6C7b2GLBtccKTbzjARJA2YWxIaqk9Nz\r\nMjj1IJK98i80qt29xRnMQ5sqOO3gn2SxTErvNchtBiwOH8NirqERXig8VCY6fr3n\r\nz7ZImPU3G/4qpD0+9ULrt9x/VkjqVvNdK1l7CyAuve3D7ha3jPMfVHFtVH5gqbyp\r\nKotyIHAyD+Ex3FQ1JV+H7DkP0cPctQiss7OiO9Zd9C1G2OrfQz9el7ewAPqOmZtC\r\nKjB3hUECgYEA/4MfKa1cvaCqzd3yUprp1JhvssVkhM1HyucIxB5xmBcVLX2/Kdhn\r\nhiDApZXARK0O9IRpFF6QVeMEX7TzFwB6dfkyIePsGxputA5SPbtBlHOvjZa8omMl\r\nEYfNa8x/mJkvSEpzvkWPascuHJWv1cEypqphu/70DxubWB5UKo/8o6cCgYEA0HFy\r\ncgwPMB//nltHGrmaQZPFT7/Qgl9ErZT3G9S8teWY4o4CXnkdU75tBoKAaJnpSfX3\r\nq8VuRerF45AFhqCKhlG4l51oW7TUH50qE3GM+4ivaH5YZB3biwQ9Wqw+QyNLAh/Q\r\nnS4/Wwb8qC9QuyEgcCju5lsCaPEXZiZqtPVxZd0CgYEAshBG31yZjO0zG1TZUwfy\r\nfN3euc8mRgZpSdXIHiS5NSyg7Zr8ZcUSID8jAkJiQ3n3OiAsuq1MGQ6kNa582kLT\r\nFPQdI9Ea8ahyDbkNR0gAY9xbM2kg/Gnro1PorH9PTKE0ekSodKk1UUyNrg4DBAwn\r\nqE6E3ebHXt/2WmqIbUD653ECgYBQCC8EAQNX3AFegPd1GGxU33Lz4tchJ4kMCNU0\r\nN2NZh9VCr3nTYjdTbxsXU8YP44CCKFG2/zAO4kymyiaFAWEOn5P7irGF/JExrjt4\r\nibGy5lFLEq/HiPtBjhgsl1O0nXlwUFzd7OLghXc+8CPUJaz5w42unqT3PBJa40c3\r\nQcIPdQKBgBnSb7BcDAAQ/Qx9juo/RKpvhyeqlnp0GzPSQjvtWi9dQRIu9Pe7luHc\r\nm1Img1EO1OyE3dis/rLaDsAa2AKu1Yx6h85EmNjavBqP9wqmFa0NIQQH8fvzKY3/\r\nP8IHY6009aoamLqYaexvrkHVq7fFKiI6k8myMJ6qblVNFv14+KXU\r\n-----END RSA PRIVATE KEY-----" # noqa: E501
|
PRIVATE_KEY = b"-----BEGIN RSA PRIVATE KEY-----\r\nMIIEowIBAAKCAQEA0AvEbNaOnfIL3GjB8VI4M5IaWe+GcK8eSPHkLkXREIsaddum\r\nwPBm/+w8lFYdnY+O06OEJrsaDtwGdU//8cbGJ/H/9cJH3dh0tNbfszP7nTrQD+88\r\nydlcYHzClaG8G+oTe9uEZSVdDXj5IUqR0y6rDXXb9tC9l+oSz+ShYg6+C4grAb3E\r\nSTv5khZ9Zsi/JEPWStqNdpoNuRh7qEYc3t4B/a5BH7bsQENyJSc8AWrfv+drPAEe\r\njQ8xm1ygzWvJp8yZPwOIYuL+obtANcoVT2G2150Wy6qLC0bD88Bm40GqLbSazueC\r\nRHZRug0B9rMUKvKc4FhG4AlNzBCaKgIcCWEqKwIDAQABAoIBACcIjin9d3Sa3S7V\r\nWM32JyVF3DvTfN3XfU8iUzV7U+ZOswA53eeFM04A/Ly4C4ZsUNfUbg72O8Vd8rg/\r\n8j1ilfsYpHVvphwxaHQlfIMa1bKCPlc/A6C7b2GLBtccKTbzjARJA2YWxIaqk9Nz\r\nMjj1IJK98i80qt29xRnMQ5sqOO3gn2SxTErvNchtBiwOH8NirqERXig8VCY6fr3n\r\nz7ZImPU3G/4qpD0+9ULrt9x/VkjqVvNdK1l7CyAuve3D7ha3jPMfVHFtVH5gqbyp\r\nKotyIHAyD+Ex3FQ1JV+H7DkP0cPctQiss7OiO9Zd9C1G2OrfQz9el7ewAPqOmZtC\r\nKjB3hUECgYEA/4MfKa1cvaCqzd3yUprp1JhvssVkhM1HyucIxB5xmBcVLX2/Kdhn\r\nhiDApZXARK0O9IRpFF6QVeMEX7TzFwB6dfkyIePsGxputA5SPbtBlHOvjZa8omMl\r\nEYfNa8x/mJkvSEpzvkWPascuHJWv1cEypqphu/70DxubWB5UKo/8o6cCgYEA0HFy\r\ncgwPMB//nltHGrmaQZPFT7/Qgl9ErZT3G9S8teWY4o4CXnkdU75tBoKAaJnpSfX3\r\nq8VuRerF45AFhqCKhlG4l51oW7TUH50qE3GM+4ivaH5YZB3biwQ9Wqw+QyNLAh/Q\r\nnS4/Wwb8qC9QuyEgcCju5lsCaPEXZiZqtPVxZd0CgYEAshBG31yZjO0zG1TZUwfy\r\nfN3euc8mRgZpSdXIHiS5NSyg7Zr8ZcUSID8jAkJiQ3n3OiAsuq1MGQ6kNa582kLT\r\nFPQdI9Ea8ahyDbkNR0gAY9xbM2kg/Gnro1PorH9PTKE0ekSodKk1UUyNrg4DBAwn\r\nqE6E3ebHXt/2WmqIbUD653ECgYBQCC8EAQNX3AFegPd1GGxU33Lz4tchJ4kMCNU0\r\nN2NZh9VCr3nTYjdTbxsXU8YP44CCKFG2/zAO4kymyiaFAWEOn5P7irGF/JExrjt4\r\nibGy5lFLEq/HiPtBjhgsl1O0nXlwUFzd7OLghXc+8CPUJaz5w42unqT3PBJa40c3\r\nQcIPdQKBgBnSb7BcDAAQ/Qx9juo/RKpvhyeqlnp0GzPSQjvtWi9dQRIu9Pe7luHc\r\nm1Img1EO1OyE3dis/rLaDsAa2AKu1Yx6h85EmNjavBqP9wqmFa0NIQQH8fvzKY3/\r\nP8IHY6009aoamLqYaexvrkHVq7fFKiI6k8myMJ6qblVNFv14+KXU\r\n-----END RSA PRIVATE KEY-----" # noqa: E501
|
||||||
|
|
||||||
|
TEST_MSG_TEXT = "Topics are forever"
|
||||||
|
TEST_TOPIC_ICON_COLOR = 0x6FB9F0
|
||||||
|
TEST_TOPIC_NAME = "Sad bot true: real stories"
|
||||||
|
|
|
@ -40,7 +40,7 @@ from telegram.ext import ApplicationBuilder, Defaults, Updater
|
||||||
from telegram.ext.filters import MessageFilter, UpdateFilter
|
from telegram.ext.filters import MessageFilter, UpdateFilter
|
||||||
from tests.auxil.build_messages import DATE
|
from tests.auxil.build_messages import DATE
|
||||||
from tests.auxil.ci_bots import BOT_INFO_PROVIDER
|
from tests.auxil.ci_bots import BOT_INFO_PROVIDER
|
||||||
from tests.auxil.constants import PRIVATE_KEY
|
from tests.auxil.constants import PRIVATE_KEY, TEST_TOPIC_ICON_COLOR, TEST_TOPIC_NAME
|
||||||
from tests.auxil.envvars import RUN_TEST_OFFICIAL, TEST_WITH_OPT_DEPS
|
from tests.auxil.envvars import RUN_TEST_OFFICIAL, TEST_WITH_OPT_DEPS
|
||||||
from tests.auxil.files import data_file
|
from tests.auxil.files import data_file
|
||||||
from tests.auxil.networking import NonchalantHttpxRequest
|
from tests.auxil.networking import NonchalantHttpxRequest
|
||||||
|
@ -239,6 +239,30 @@ def class_thumb_file():
|
||||||
yield f
|
yield f
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
async def emoji_id(bot):
|
||||||
|
emoji_sticker_list = await bot.get_forum_topic_icon_stickers()
|
||||||
|
first_sticker = emoji_sticker_list[0]
|
||||||
|
return first_sticker.custom_emoji_id
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
async def real_topic(bot, emoji_id, forum_group_id):
|
||||||
|
result = await bot.create_forum_topic(
|
||||||
|
chat_id=forum_group_id,
|
||||||
|
name=TEST_TOPIC_NAME,
|
||||||
|
icon_color=TEST_TOPIC_ICON_COLOR,
|
||||||
|
icon_custom_emoji_id=emoji_id,
|
||||||
|
)
|
||||||
|
|
||||||
|
yield result
|
||||||
|
|
||||||
|
result = await bot.delete_forum_topic(
|
||||||
|
chat_id=forum_group_id, message_thread_id=result.message_thread_id
|
||||||
|
)
|
||||||
|
assert result is True, "Topic was not deleted"
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(
|
@pytest.fixture(
|
||||||
scope="class",
|
scope="class",
|
||||||
params=[{"class": MessageFilter}, {"class": UpdateFilter}],
|
params=[{"class": MessageFilter}, {"class": UpdateFilter}],
|
||||||
|
|
|
@ -99,11 +99,10 @@ from tests.auxil.networking import expect_bad_request
|
||||||
from tests.auxil.pytest_classes import PytestBot, PytestExtBot, make_bot
|
from tests.auxil.pytest_classes import PytestBot, PytestExtBot, make_bot
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
from ._files.test_photo import photo_file
|
|
||||||
from .auxil.build_messages import make_message
|
from .auxil.build_messages import make_message
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
@pytest.fixture(scope="module")
|
||||||
async def message(bot, chat_id): # mostly used in tests for edit_message
|
async def message(bot, chat_id): # mostly used in tests for edit_message
|
||||||
out = await bot.send_message(
|
out = await bot.send_message(
|
||||||
chat_id, "Text", disable_web_page_preview=True, disable_notification=True
|
chat_id, "Text", disable_web_page_preview=True, disable_notification=True
|
||||||
|
@ -1090,7 +1089,7 @@ class TestBotWithoutRequest:
|
||||||
)
|
)
|
||||||
|
|
||||||
# Test with send media group
|
# Test with send media group
|
||||||
media = InputMediaPhoto(photo_file)
|
media = InputMediaPhoto("")
|
||||||
with pytest.raises(ValueError, match="`reply_to_message_id` and"):
|
with pytest.raises(ValueError, match="`reply_to_message_id` and"):
|
||||||
await bot.send_media_group(
|
await bot.send_media_group(
|
||||||
chat_id, media, reply_to_message_id=1, reply_parameters=True
|
chat_id, media, reply_to_message_id=1, reply_parameters=True
|
||||||
|
|
|
@ -32,19 +32,9 @@ from telegram import (
|
||||||
Sticker,
|
Sticker,
|
||||||
)
|
)
|
||||||
from telegram.error import BadRequest
|
from telegram.error import BadRequest
|
||||||
|
from tests.auxil.constants import TEST_MSG_TEXT, TEST_TOPIC_ICON_COLOR, TEST_TOPIC_NAME
|
||||||
from tests.auxil.slots import mro_slots
|
from tests.auxil.slots import mro_slots
|
||||||
|
|
||||||
TEST_MSG_TEXT = "Topics are forever"
|
|
||||||
TEST_TOPIC_ICON_COLOR = 0x6FB9F0
|
|
||||||
TEST_TOPIC_NAME = "Sad bot true: real stories"
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
|
||||||
async def emoji_id(bot):
|
|
||||||
emoji_sticker_list = await bot.get_forum_topic_icon_stickers()
|
|
||||||
first_sticker = emoji_sticker_list[0]
|
|
||||||
return first_sticker.custom_emoji_id
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="module")
|
@pytest.fixture(scope="module")
|
||||||
async def forum_topic_object(forum_group_id, emoji_id):
|
async def forum_topic_object(forum_group_id, emoji_id):
|
||||||
|
@ -56,23 +46,6 @@ async def forum_topic_object(forum_group_id, emoji_id):
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
|
||||||
async def real_topic(bot, emoji_id, forum_group_id):
|
|
||||||
result = await bot.create_forum_topic(
|
|
||||||
chat_id=forum_group_id,
|
|
||||||
name=TEST_TOPIC_NAME,
|
|
||||||
icon_color=TEST_TOPIC_ICON_COLOR,
|
|
||||||
icon_custom_emoji_id=emoji_id,
|
|
||||||
)
|
|
||||||
|
|
||||||
yield result
|
|
||||||
|
|
||||||
result = await bot.delete_forum_topic(
|
|
||||||
chat_id=forum_group_id, message_thread_id=result.message_thread_id
|
|
||||||
)
|
|
||||||
assert result is True, "Topic was not deleted"
|
|
||||||
|
|
||||||
|
|
||||||
class TestForumTopicWithoutRequest:
|
class TestForumTopicWithoutRequest:
|
||||||
def test_slot_behaviour(self, forum_topic_object):
|
def test_slot_behaviour(self, forum_topic_object):
|
||||||
inst = forum_topic_object
|
inst = forum_topic_object
|
||||||
|
|
Loading…
Add table
Reference in a new issue