2016-05-15 02:39:11 +02:00
|
|
|
#!/usr/bin/env python
|
2015-09-07 19:10:57 +02:00
|
|
|
#
|
|
|
|
# A library that provides a Python interface to the Telegram Bot API
|
2020-02-02 22:08:54 +01:00
|
|
|
# Copyright (C) 2015-2020
|
2016-01-05 14:12:03 +01:00
|
|
|
# Leandro Toledo de Souza <devs@python-telegram-bot.org>
|
2015-09-07 19:10:57 +02:00
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
2017-08-11 23:58:41 +02:00
|
|
|
# it under the terms of the GNU Lesser Public License as published by
|
2015-09-07 19:10:57 +02:00
|
|
|
# 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
|
2017-08-11 23:58:41 +02:00
|
|
|
# GNU Lesser Public License for more details.
|
2015-09-07 19:10:57 +02:00
|
|
|
#
|
2017-08-11 23:58:41 +02:00
|
|
|
# You should have received a copy of the GNU Lesser Public License
|
2015-09-07 19:10:57 +02:00
|
|
|
# along with this program. If not, see [http://www.gnu.org/licenses/].
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
import pytest
|
2016-09-20 06:36:55 +02:00
|
|
|
|
2019-09-06 21:41:43 +02:00
|
|
|
from telegram import Chat, ChatAction, ChatPermissions
|
2020-02-06 11:22:56 +01:00
|
|
|
from telegram import User, Message
|
2016-09-20 06:36:55 +02:00
|
|
|
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
@pytest.fixture(scope='class')
|
|
|
|
def chat(bot):
|
2020-02-23 22:03:58 +01:00
|
|
|
return Chat(TestChat.id_, TestChat.title, TestChat.type_, username=TestChat.username,
|
2017-08-11 23:58:41 +02:00
|
|
|
all_members_are_administrators=TestChat.all_members_are_administrators,
|
2017-10-14 20:03:02 +02:00
|
|
|
bot=bot, sticker_set_name=TestChat.sticker_set_name,
|
2019-09-06 21:41:43 +02:00
|
|
|
can_set_sticker_set=TestChat.can_set_sticker_set,
|
2020-03-28 16:37:26 +01:00
|
|
|
permissions=TestChat.permissions,
|
|
|
|
slow_mode_delay=TestChat.slow_mode_delay)
|
2015-09-07 19:10:57 +02:00
|
|
|
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
class TestChat(object):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = -28767330
|
2017-08-11 23:58:41 +02:00
|
|
|
title = 'ToledosPalaceBot - Group'
|
2020-02-23 22:03:58 +01:00
|
|
|
type_ = 'group'
|
2018-05-09 11:42:12 +02:00
|
|
|
username = 'username'
|
2017-08-11 23:58:41 +02:00
|
|
|
all_members_are_administrators = False
|
2017-10-14 20:03:02 +02:00
|
|
|
sticker_set_name = 'stickers'
|
|
|
|
can_set_sticker_set = False
|
2019-09-06 21:41:43 +02:00
|
|
|
permissions = ChatPermissions(
|
|
|
|
can_send_messages=True,
|
|
|
|
can_change_info=False,
|
|
|
|
can_invite_users=True,
|
|
|
|
)
|
2020-03-28 16:37:26 +01:00
|
|
|
slow_mode_delay = 30
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_de_json(self, bot):
|
|
|
|
json_dict = {
|
2020-02-23 22:03:58 +01:00
|
|
|
'id': self.id_,
|
2017-10-14 20:03:02 +02:00
|
|
|
'title': self.title,
|
2020-02-23 22:03:58 +01:00
|
|
|
'type': self.type_,
|
2018-05-09 11:42:12 +02:00
|
|
|
'username': self.username,
|
2017-10-14 20:03:02 +02:00
|
|
|
'all_members_are_administrators': self.all_members_are_administrators,
|
|
|
|
'sticker_set_name': self.sticker_set_name,
|
2019-09-06 21:41:43 +02:00
|
|
|
'can_set_sticker_set': self.can_set_sticker_set,
|
2020-03-28 16:37:26 +01:00
|
|
|
'permissions': self.permissions.to_dict(),
|
|
|
|
'slow_mode_delay': self.slow_mode_delay
|
2016-10-12 22:56:57 +02:00
|
|
|
}
|
2017-08-11 23:58:41 +02:00
|
|
|
chat = Chat.de_json(json_dict, bot)
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2020-02-23 22:03:58 +01:00
|
|
|
assert chat.id == self.id_
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.title == self.title
|
2020-02-23 22:03:58 +01:00
|
|
|
assert chat.type == self.type_
|
2018-05-09 11:42:12 +02:00
|
|
|
assert chat.username == self.username
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.all_members_are_administrators == self.all_members_are_administrators
|
2017-10-14 20:03:02 +02:00
|
|
|
assert chat.sticker_set_name == self.sticker_set_name
|
|
|
|
assert chat.can_set_sticker_set == self.can_set_sticker_set
|
2019-09-06 21:41:43 +02:00
|
|
|
assert chat.permissions == self.permissions
|
2020-03-28 16:37:26 +01:00
|
|
|
assert chat.slow_mode_delay == self.slow_mode_delay
|
2015-09-08 01:11:02 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
def test_de_json_default_quote(self, bot):
|
|
|
|
json_dict = {
|
2020-02-23 22:03:58 +01:00
|
|
|
'id': self.id_,
|
|
|
|
'type': self.type_,
|
2020-02-06 11:22:56 +01:00
|
|
|
'pinned_message': Message(
|
|
|
|
message_id=123,
|
|
|
|
from_user=None,
|
|
|
|
date=None,
|
|
|
|
chat=None
|
|
|
|
).to_dict(),
|
|
|
|
'default_quote': True
|
|
|
|
}
|
|
|
|
chat = Chat.de_json(json_dict, bot)
|
|
|
|
|
|
|
|
assert chat.pinned_message.default_quote is True
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_to_dict(self, chat):
|
|
|
|
chat_dict = chat.to_dict()
|
2015-09-08 01:11:02 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert isinstance(chat_dict, dict)
|
|
|
|
assert chat_dict['id'] == chat.id
|
|
|
|
assert chat_dict['title'] == chat.title
|
|
|
|
assert chat_dict['type'] == chat.type
|
2018-05-09 11:42:12 +02:00
|
|
|
assert chat_dict['username'] == chat.username
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat_dict['all_members_are_administrators'] == chat.all_members_are_administrators
|
2019-09-06 21:41:43 +02:00
|
|
|
assert chat_dict['permissions'] == chat.permissions.to_dict()
|
2020-03-28 16:37:26 +01:00
|
|
|
assert chat_dict['slow_mode_delay'] == chat.slow_mode_delay
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2018-05-09 11:42:12 +02:00
|
|
|
def test_link(self, chat):
|
|
|
|
assert chat.link == 'https://t.me/{}'.format(chat.username)
|
|
|
|
chat.username = None
|
|
|
|
assert chat.link is None
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_send_action(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == chat.id
|
2017-08-11 23:58:41 +02:00
|
|
|
action = kwargs['action'] == ChatAction.TYPING
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and action
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_chat_action', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.send_action(action=ChatAction.TYPING)
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_leave(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'leave_chat', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.leave()
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_get_administrators(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id
|
2015-09-07 19:10:57 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'get_chat_administrators', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.get_administrators()
|
2016-09-20 06:36:55 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_get_members_count(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id
|
2016-09-20 06:36:55 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'get_chat_members_count', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.get_members_count()
|
2016-09-20 06:36:55 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_get_member(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
chat_id = args[0] == chat.id
|
|
|
|
user_id = args[1] == 42
|
2017-08-11 23:58:41 +02:00
|
|
|
return chat_id and user_id
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'get_chat_member', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.get_member(42)
|
|
|
|
|
|
|
|
def test_kick_member(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
chat_id = args[0] == chat.id
|
|
|
|
user_id = args[1] == 42
|
2017-08-11 23:58:41 +02:00
|
|
|
until = kwargs['until_date'] == 43
|
|
|
|
return chat_id and user_id and until
|
2017-05-14 23:29:31 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'kick_chat_member', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.kick_member(42, until_date=43)
|
2017-05-14 23:29:31 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_unban_member(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
chat_id = args[0] == chat.id
|
|
|
|
user_id = args[1] == 42
|
2017-08-11 23:58:41 +02:00
|
|
|
return chat_id and user_id
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'unban_chat_member', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert chat.unban_member(42)
|
|
|
|
|
2019-09-06 21:41:43 +02:00
|
|
|
def test_set_permissions(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
chat_id = args[0] == chat.id
|
|
|
|
permissions = args[1] == self.permissions
|
2019-09-06 21:41:43 +02:00
|
|
|
return chat_id and permissions
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'set_chat_permissions', test)
|
2019-09-06 21:41:43 +02:00
|
|
|
assert chat.set_permissions(self.permissions)
|
|
|
|
|
2020-03-28 16:37:26 +01:00
|
|
|
def test_set_administrator_custom_title(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = args[1] == chat.id
|
|
|
|
user_id = args[2] == 42
|
|
|
|
custom_title = args[3] == 'custom_title'
|
|
|
|
return chat_id and user_id and custom_title
|
|
|
|
|
|
|
|
monkeypatch.setattr('telegram.Bot.set_chat_administrator_custom_title', test)
|
|
|
|
assert chat.set_administrator_custom_title(42, 'custom_title')
|
|
|
|
|
2018-02-18 16:49:52 +01:00
|
|
|
def test_instance_method_send_message(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test'
|
2018-02-18 16:49:52 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_message', test)
|
2018-02-18 16:49:52 +01:00
|
|
|
assert chat.send_message('test')
|
|
|
|
|
2018-03-17 00:10:11 +01:00
|
|
|
def test_instance_method_send_photo(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_photo'
|
2018-03-17 00:10:11 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_photo', test)
|
2018-03-17 00:10:11 +01:00
|
|
|
assert chat.send_photo('test_photo')
|
|
|
|
|
2018-02-18 16:49:52 +01:00
|
|
|
def test_instance_method_send_audio(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_audio'
|
2018-02-18 16:49:52 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_audio', test)
|
2018-03-17 00:10:11 +01:00
|
|
|
assert chat.send_audio('test_audio')
|
2018-02-18 16:49:52 +01:00
|
|
|
|
|
|
|
def test_instance_method_send_document(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_document'
|
2018-02-18 16:49:52 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_document', test)
|
2018-03-17 00:10:11 +01:00
|
|
|
assert chat.send_document('test_document')
|
2018-02-18 16:49:52 +01:00
|
|
|
|
|
|
|
def test_instance_method_send_sticker(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_sticker'
|
2018-02-18 16:49:52 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_sticker', test)
|
2018-03-17 00:10:11 +01:00
|
|
|
assert chat.send_sticker('test_sticker')
|
2018-02-18 16:49:52 +01:00
|
|
|
|
|
|
|
def test_instance_method_send_video(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_video'
|
2018-02-18 16:49:52 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_video', test)
|
2018-03-17 00:10:11 +01:00
|
|
|
assert chat.send_video('test_video')
|
2018-02-18 16:49:52 +01:00
|
|
|
|
|
|
|
def test_instance_method_send_video_note(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_video_note'
|
2018-02-18 16:49:52 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_video_note', test)
|
2018-03-17 00:10:11 +01:00
|
|
|
assert chat.send_video_note('test_video_note')
|
2018-02-18 16:49:52 +01:00
|
|
|
|
|
|
|
def test_instance_method_send_voice(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_voice'
|
2018-02-18 16:49:52 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_voice', test)
|
2018-03-17 00:10:11 +01:00
|
|
|
assert chat.send_voice('test_voice')
|
2018-02-18 16:49:52 +01:00
|
|
|
|
Bot API 4.0 (#1168)
Telegram Passport (#1174):
- Add full support for telegram passport.
- New types: PassportData, PassportFile, EncryptedPassportElement, EncryptedCredentials, PassportElementError, PassportElementErrorDataField, PassportElementErrorFrontSide, PassportElementErrorReverseSide, PassportElementErrorSelfie, PassportElementErrorFile and PassportElementErrorFiles.
- New bot method: set_passport_data_errors
- New filter: Filters.passport_data
- Field passport_data field on Message
- PassportData is automagically decrypted when you specify your private key when creating Updater or Bot.
- PassportFiles is also automagically decrypted as you download/retrieve them.
- See new passportbot.py example for details on how to use, or go to our telegram passport wiki page for more info
- NOTE: Passport decryption requires new dependency `cryptography`.
Inputfile rework (#1184):
- Change how Inputfile is handled internally
- This allows support for specifying the thumbnails of photos and videos using the thumb= argument in the different send_ methods.
- Also allows Bot.send_media_group to actually finally send more than one media.
- Add thumb to Audio, Video and Videonote
- Add Bot.edit_message_media together with InputMediaAnimation, InputMediaAudio, and inputMediaDocument.
Other Bot API 4.0 changes:
- Add forusquare_type to Venue, InlineQueryResultVenue, InputVenueMessageContent, and Bot.send_venue. (#1170)
- Add vCard support by adding vcard field to Contact, InlineQueryResultContact, InputContactMessageContent, and Bot.send_contact. (#1166)
- Support new message entities: CASHTAG and PHONE_NUMBER. (#1179)
- Cashtag seems to be things like $USD and $GBP, but it seems telegram doesn't currently send them to bots.
- Phone number also seems to have limited support for now
- Add Bot.send_animation, add width, height, and duration to Animation, and add Filters.animation. (#1172)
Co-authored-by: Jasmin Bom <jsmnbom@gmail.com>
Co-authored-by: code1mountain <32801117+code1mountain@users.noreply.github.com>
Co-authored-by: Eldinnie <pieter.schutz+github@gmail.com>
Co-authored-by: mathefreak1 <mathefreak@hi2.in>
2018-08-29 14:18:58 +02:00
|
|
|
def test_instance_method_send_animation(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_animation'
|
Bot API 4.0 (#1168)
Telegram Passport (#1174):
- Add full support for telegram passport.
- New types: PassportData, PassportFile, EncryptedPassportElement, EncryptedCredentials, PassportElementError, PassportElementErrorDataField, PassportElementErrorFrontSide, PassportElementErrorReverseSide, PassportElementErrorSelfie, PassportElementErrorFile and PassportElementErrorFiles.
- New bot method: set_passport_data_errors
- New filter: Filters.passport_data
- Field passport_data field on Message
- PassportData is automagically decrypted when you specify your private key when creating Updater or Bot.
- PassportFiles is also automagically decrypted as you download/retrieve them.
- See new passportbot.py example for details on how to use, or go to our telegram passport wiki page for more info
- NOTE: Passport decryption requires new dependency `cryptography`.
Inputfile rework (#1184):
- Change how Inputfile is handled internally
- This allows support for specifying the thumbnails of photos and videos using the thumb= argument in the different send_ methods.
- Also allows Bot.send_media_group to actually finally send more than one media.
- Add thumb to Audio, Video and Videonote
- Add Bot.edit_message_media together with InputMediaAnimation, InputMediaAudio, and inputMediaDocument.
Other Bot API 4.0 changes:
- Add forusquare_type to Venue, InlineQueryResultVenue, InputVenueMessageContent, and Bot.send_venue. (#1170)
- Add vCard support by adding vcard field to Contact, InlineQueryResultContact, InputContactMessageContent, and Bot.send_contact. (#1166)
- Support new message entities: CASHTAG and PHONE_NUMBER. (#1179)
- Cashtag seems to be things like $USD and $GBP, but it seems telegram doesn't currently send them to bots.
- Phone number also seems to have limited support for now
- Add Bot.send_animation, add width, height, and duration to Animation, and add Filters.animation. (#1172)
Co-authored-by: Jasmin Bom <jsmnbom@gmail.com>
Co-authored-by: code1mountain <32801117+code1mountain@users.noreply.github.com>
Co-authored-by: Eldinnie <pieter.schutz+github@gmail.com>
Co-authored-by: mathefreak1 <mathefreak@hi2.in>
2018-08-29 14:18:58 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_animation', test)
|
Bot API 4.0 (#1168)
Telegram Passport (#1174):
- Add full support for telegram passport.
- New types: PassportData, PassportFile, EncryptedPassportElement, EncryptedCredentials, PassportElementError, PassportElementErrorDataField, PassportElementErrorFrontSide, PassportElementErrorReverseSide, PassportElementErrorSelfie, PassportElementErrorFile and PassportElementErrorFiles.
- New bot method: set_passport_data_errors
- New filter: Filters.passport_data
- Field passport_data field on Message
- PassportData is automagically decrypted when you specify your private key when creating Updater or Bot.
- PassportFiles is also automagically decrypted as you download/retrieve them.
- See new passportbot.py example for details on how to use, or go to our telegram passport wiki page for more info
- NOTE: Passport decryption requires new dependency `cryptography`.
Inputfile rework (#1184):
- Change how Inputfile is handled internally
- This allows support for specifying the thumbnails of photos and videos using the thumb= argument in the different send_ methods.
- Also allows Bot.send_media_group to actually finally send more than one media.
- Add thumb to Audio, Video and Videonote
- Add Bot.edit_message_media together with InputMediaAnimation, InputMediaAudio, and inputMediaDocument.
Other Bot API 4.0 changes:
- Add forusquare_type to Venue, InlineQueryResultVenue, InputVenueMessageContent, and Bot.send_venue. (#1170)
- Add vCard support by adding vcard field to Contact, InlineQueryResultContact, InputContactMessageContent, and Bot.send_contact. (#1166)
- Support new message entities: CASHTAG and PHONE_NUMBER. (#1179)
- Cashtag seems to be things like $USD and $GBP, but it seems telegram doesn't currently send them to bots.
- Phone number also seems to have limited support for now
- Add Bot.send_animation, add width, height, and duration to Animation, and add Filters.animation. (#1172)
Co-authored-by: Jasmin Bom <jsmnbom@gmail.com>
Co-authored-by: code1mountain <32801117+code1mountain@users.noreply.github.com>
Co-authored-by: Eldinnie <pieter.schutz+github@gmail.com>
Co-authored-by: mathefreak1 <mathefreak@hi2.in>
2018-08-29 14:18:58 +02:00
|
|
|
assert chat.send_animation('test_animation')
|
|
|
|
|
2019-08-23 21:20:41 +02:00
|
|
|
def test_instance_method_send_poll(self, monkeypatch, chat):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
return args[0] == chat.id and args[1] == 'test_poll'
|
2019-08-23 21:20:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(chat.bot, 'send_poll', test)
|
2019-08-23 21:20:41 +02:00
|
|
|
assert chat.send_poll('test_poll')
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_equality(self):
|
2020-02-23 22:03:58 +01:00
|
|
|
a = Chat(self.id_, self.title, self.type_)
|
|
|
|
b = Chat(self.id_, self.title, self.type_)
|
|
|
|
c = Chat(self.id_, '', '')
|
|
|
|
d = Chat(0, self.title, self.type_)
|
|
|
|
e = User(self.id_, '', False)
|
2017-05-14 23:29:31 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert a == b
|
|
|
|
assert hash(a) == hash(b)
|
|
|
|
assert a is not b
|
2017-05-14 23:29:31 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert a == c
|
|
|
|
assert hash(a) == hash(c)
|
2017-05-14 23:29:31 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert a != d
|
|
|
|
assert hash(a) != hash(d)
|
2016-05-15 02:39:11 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert a != e
|
|
|
|
assert hash(a) != hash(e)
|