2016-09-07 08:49:09 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#
|
|
|
|
# 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-09-07 08:49:09 +02:00
|
|
|
# Leandro Toledo de Souza <devs@python-telegram-bot.org>
|
|
|
|
#
|
|
|
|
# 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
|
2016-09-07 08:49:09 +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.
|
2016-09-07 08:49:09 +02:00
|
|
|
#
|
2017-08-11 23:58:41 +02:00
|
|
|
# You should have received a copy of the GNU Lesser Public License
|
2016-09-07 08:49:09 +02:00
|
|
|
# along with this program. If not, see [http://www.gnu.org/licenses/].
|
2017-08-11 23:58:41 +02:00
|
|
|
from datetime import datetime
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
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
|
|
|
from telegram import (Update, Message, User, MessageEntity, Chat, Audio, Document, Animation,
|
2017-08-11 23:58:41 +02:00
|
|
|
Game, PhotoSize, Sticker, Video, Voice, VideoNote, Contact, Location, Venue,
|
2020-04-10 19:22:45 +02:00
|
|
|
Invoice, SuccessfulPayment, PassportData, ParseMode, Poll, PollOption, Dice)
|
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
|
|
|
from tests.test_passport import RAW_PASSPORT_DATA
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='class')
|
|
|
|
def message(bot):
|
2020-02-23 22:03:58 +01:00
|
|
|
return Message(TestMessage.id_, TestMessage.from_user, TestMessage.date, TestMessage.chat,
|
2017-08-11 23:58:41 +02:00
|
|
|
bot=bot)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='function',
|
|
|
|
params=[
|
2017-09-01 08:40:05 +02:00
|
|
|
{'forward_from': User(99, 'forward_user', False),
|
2019-11-15 21:51:22 +01:00
|
|
|
'forward_date': datetime.utcnow()},
|
2017-08-11 23:58:41 +02:00
|
|
|
{'forward_from_chat': Chat(-23, 'channel'),
|
|
|
|
'forward_from_message_id': 101,
|
2019-11-15 21:51:22 +01:00
|
|
|
'forward_date': datetime.utcnow()},
|
2017-08-11 23:58:41 +02:00
|
|
|
{'reply_to_message': Message(50, None, None, None)},
|
2019-11-15 21:51:22 +01:00
|
|
|
{'edit_date': datetime.utcnow()},
|
2017-10-14 20:03:02 +02:00
|
|
|
{'text': 'a text message',
|
2017-08-11 23:58:41 +02:00
|
|
|
'enitites': [MessageEntity('bold', 10, 4),
|
|
|
|
MessageEntity('italic', 16, 7)]},
|
2017-10-14 20:03:02 +02:00
|
|
|
{'caption': 'A message caption',
|
|
|
|
'caption_entities': [MessageEntity('bold', 1, 1),
|
|
|
|
MessageEntity('text_link', 4, 3)]},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'audio': Audio('audio_id', 'unique_id', 12),
|
2017-08-11 23:58:41 +02:00
|
|
|
'caption': 'audio_file'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'document': Document('document_id', 'unique_id'),
|
2017-08-11 23:58:41 +02:00
|
|
|
'caption': 'document_file'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'animation': Animation('animation_id', 'unique_id', 30, 30, 1),
|
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
|
|
|
'caption': 'animation_file'},
|
2017-08-11 23:58:41 +02:00
|
|
|
{'game': Game('my_game', 'just my game',
|
2020-03-28 16:37:26 +01:00
|
|
|
[PhotoSize('game_photo_id', 'unique_id', 30, 30), ])},
|
|
|
|
{'photo': [PhotoSize('photo_id', 'unique_id', 50, 50)],
|
2017-08-11 23:58:41 +02:00
|
|
|
'caption': 'photo_file'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'sticker': Sticker('sticker_id', 'unique_id', 50, 50, True)},
|
|
|
|
{'video': Video('video_id', 'unique_id', 12, 12, 12),
|
2017-08-11 23:58:41 +02:00
|
|
|
'caption': 'video_file'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'voice': Voice('voice_id', 'unique_id', 5)},
|
|
|
|
{'video_note': VideoNote('video_note_id', 'unique_id', 20, 12)},
|
2017-09-01 08:40:05 +02:00
|
|
|
{'new_chat_members': [User(55, 'new_user', False)]},
|
2017-08-11 23:58:41 +02:00
|
|
|
{'contact': Contact('phone_numner', 'contact_name')},
|
|
|
|
{'location': Location(-23.691288, 46.788279)},
|
|
|
|
{'venue': Venue(Location(-23.691288, 46.788279),
|
|
|
|
'some place', 'right here')},
|
2017-09-01 08:40:05 +02:00
|
|
|
{'left_chat_member': User(33, 'kicked', False)},
|
2017-08-11 23:58:41 +02:00
|
|
|
{'new_chat_title': 'new title'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'new_chat_photo': [PhotoSize('photo_id', 'unique_id', 50, 50)]},
|
2017-08-11 23:58:41 +02:00
|
|
|
{'delete_chat_photo': True},
|
|
|
|
{'group_chat_created': True},
|
|
|
|
{'supergroup_chat_created': True},
|
|
|
|
{'channel_chat_created': True},
|
|
|
|
{'migrate_to_chat_id': -12345},
|
|
|
|
{'migrate_from_chat_id': -54321},
|
|
|
|
{'pinned_message': Message(7, None, None, None)},
|
|
|
|
{'invoice': Invoice('my invoice', 'invoice', 'start', 'EUR', 243)},
|
|
|
|
{'successful_payment': SuccessfulPayment('EUR', 243, 'payload',
|
|
|
|
'charge_id', 'provider_id',
|
2017-09-01 08:40:05 +02:00
|
|
|
order_info={})},
|
2018-02-18 16:11:04 +01:00
|
|
|
{'connected_website': 'http://example.com/'},
|
2017-09-01 08:40:05 +02:00
|
|
|
{'forward_signature': 'some_forward_sign'},
|
2017-12-08 22:38:59 +01:00
|
|
|
{'author_signature': 'some_author_sign'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'photo': [PhotoSize('photo_id', 'unique_id', 50, 50)],
|
2017-12-08 22:38:59 +01:00
|
|
|
'caption': 'photo_file',
|
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
|
|
|
'media_group_id': 1234443322222},
|
2019-08-23 21:20:41 +02:00
|
|
|
{'passport_data': PassportData.de_json(RAW_PASSPORT_DATA, None)},
|
|
|
|
{'poll': Poll(id='abc', question='What is this?',
|
|
|
|
options=[PollOption(text='a', voter_count=1),
|
2020-03-29 09:52:30 +02:00
|
|
|
PollOption(text='b', voter_count=2)], is_closed=False,
|
|
|
|
total_voter_count=0, is_anonymous=False, type=Poll.REGULAR,
|
2020-05-02 11:56:52 +02:00
|
|
|
allows_multiple_answers=True, explanation_entities=[])},
|
2019-08-23 21:20:41 +02:00
|
|
|
{'text': 'a text message', 'reply_markup': {'inline_keyboard': [[{
|
|
|
|
'text': 'start', 'url': 'http://google.com'}, {
|
|
|
|
'text': 'next', 'callback_data': 'abcd'}],
|
2020-02-06 11:22:56 +01:00
|
|
|
[{'text': 'Cancel', 'callback_data': 'Cancel'}]]}},
|
2020-04-10 19:22:45 +02:00
|
|
|
{'quote': True},
|
2020-06-22 20:09:52 +02:00
|
|
|
{'dice': Dice(4, '🎲')},
|
|
|
|
{'via_bot': User(9, 'A_Bot', True)}
|
2017-08-11 23:58:41 +02:00
|
|
|
],
|
2017-10-14 20:03:02 +02:00
|
|
|
ids=['forwarded_user', 'forwarded_channel', 'reply', 'edited', 'text',
|
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
|
|
|
'caption_entities', 'audio', 'document', 'animation', 'game', 'photo',
|
|
|
|
'sticker', 'video', 'voice', 'video_note', 'new_members', 'contact',
|
|
|
|
'location', 'venue', 'left_member', 'new_title', 'new_photo', 'delete_photo',
|
|
|
|
'group_created', 'supergroup_created', 'channel_created', 'migrated_to',
|
|
|
|
'migrated_from', 'pinned', 'invoice', 'successful_payment',
|
|
|
|
'connected_website', 'forward_signature', 'author_signature',
|
2020-02-06 11:22:56 +01:00
|
|
|
'photo_from_media_group', 'passport_data', 'poll', 'reply_markup',
|
2020-06-22 20:09:52 +02:00
|
|
|
'default_quote', 'dice', 'via_bot'])
|
2017-08-11 23:58:41 +02:00
|
|
|
def message_params(bot, request):
|
2020-02-23 22:03:58 +01:00
|
|
|
return Message(message_id=TestMessage.id_,
|
2017-08-11 23:58:41 +02:00
|
|
|
from_user=TestMessage.from_user,
|
|
|
|
date=TestMessage.date,
|
|
|
|
chat=TestMessage.chat, bot=bot, **request.param)
|
|
|
|
|
|
|
|
|
2020-06-15 18:20:51 +02:00
|
|
|
class TestMessage:
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = 1
|
2017-09-01 08:40:05 +02:00
|
|
|
from_user = User(2, 'testuser', False)
|
2019-11-15 21:51:22 +01:00
|
|
|
date = datetime.utcnow()
|
2017-08-11 23:58:41 +02:00
|
|
|
chat = Chat(3, 'private')
|
|
|
|
test_entities = [{'length': 4, 'offset': 10, 'type': 'bold'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'length': 3, 'offset': 16, 'type': 'italic'},
|
|
|
|
{'length': 3, 'offset': 20, 'type': 'italic'},
|
2017-08-11 23:58:41 +02:00
|
|
|
{'length': 4, 'offset': 25, 'type': 'code'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'length': 5, 'offset': 31, 'type': 'text_link',
|
|
|
|
'url': 'http://github.com/ab_'},
|
2018-09-25 20:07:55 +02:00
|
|
|
{'length': 12, 'offset': 38, 'type': 'text_mention',
|
2018-11-01 10:18:07 +01:00
|
|
|
'user': User(123456789, 'mentioned user', False)},
|
2020-03-29 09:52:30 +02:00
|
|
|
{'length': 3, 'offset': 55, 'type': 'pre', 'language': 'python'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'length': 21, 'offset': 60, 'type': 'url'}]
|
|
|
|
test_text = 'Test for <bold, ita_lic, code, links, text-mention and pre. http://google.com/ab_'
|
|
|
|
test_entities_v2 = [{'length': 4, 'offset': 0, 'type': 'underline'},
|
|
|
|
{'length': 4, 'offset': 10, 'type': 'bold'},
|
|
|
|
{'length': 7, 'offset': 16, 'type': 'italic'},
|
|
|
|
{'length': 6, 'offset': 25, 'type': 'code'},
|
|
|
|
{'length': 5, 'offset': 33, 'type': 'text_link',
|
2020-06-15 18:20:51 +02:00
|
|
|
'url': r'http://github.com/abc\)def'},
|
2020-03-28 16:37:26 +01:00
|
|
|
{'length': 12, 'offset': 40, 'type': 'text_mention',
|
|
|
|
'user': User(123456789, 'mentioned user', False)},
|
|
|
|
{'length': 5, 'offset': 57, 'type': 'pre'},
|
|
|
|
{'length': 17, 'offset': 64, 'type': 'url'},
|
|
|
|
{'length': 36, 'offset': 86, 'type': 'italic'},
|
|
|
|
{'length': 24, 'offset': 91, 'type': 'bold'},
|
2020-03-29 09:52:30 +02:00
|
|
|
{'length': 4, 'offset': 101, 'type': 'strikethrough'},
|
|
|
|
{'length': 10, 'offset': 124, 'type': 'pre', 'language': 'python'}]
|
2020-06-15 18:20:51 +02:00
|
|
|
test_text_v2 = (r'Test for <bold, ita_lic, \`code, links, text-mention and `\pre. '
|
2020-03-29 09:52:30 +02:00
|
|
|
'http://google.com and bold nested in strk nested in italic. Python pre.')
|
2017-08-11 23:58:41 +02:00
|
|
|
test_message = Message(message_id=1,
|
|
|
|
from_user=None,
|
|
|
|
date=None,
|
|
|
|
chat=None,
|
|
|
|
text=test_text,
|
2018-02-22 16:38:54 +01:00
|
|
|
entities=[MessageEntity(**e) for e in test_entities],
|
|
|
|
caption=test_text,
|
|
|
|
caption_entities=[MessageEntity(**e) for e in test_entities])
|
2020-03-28 16:37:26 +01:00
|
|
|
test_message_v2 = Message(message_id=1,
|
|
|
|
from_user=None,
|
|
|
|
date=None,
|
|
|
|
chat=None,
|
|
|
|
text=test_text_v2,
|
|
|
|
entities=[MessageEntity(**e) for e in test_entities_v2],
|
|
|
|
caption=test_text_v2,
|
|
|
|
caption_entities=[
|
|
|
|
MessageEntity(**e) for e in test_entities_v2
|
|
|
|
])
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
def test_all_posibilities_de_json_and_to_dict(self, bot, message_params):
|
|
|
|
new = Message.de_json(message_params.to_dict(), bot)
|
|
|
|
|
|
|
|
assert new.to_dict() == message_params.to_dict()
|
|
|
|
|
|
|
|
def test_dict_approach(self, message):
|
|
|
|
assert message['date'] == message.date
|
|
|
|
assert message['chat_id'] == message.chat_id
|
|
|
|
assert message['no_key'] is None
|
2017-01-20 20:13:58 +01:00
|
|
|
|
2016-09-07 08:49:09 +02:00
|
|
|
def test_parse_entity(self):
|
|
|
|
text = (b'\\U0001f469\\u200d\\U0001f469\\u200d\\U0001f467'
|
|
|
|
b'\\u200d\\U0001f467\\U0001f431http://google.com').decode('unicode-escape')
|
2017-08-11 23:58:41 +02:00
|
|
|
entity = MessageEntity(type=MessageEntity.URL, offset=13, length=17)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat, text=text, entities=[entity])
|
|
|
|
assert message.parse_entity(entity) == 'http://google.com'
|
2016-09-07 08:49:09 +02:00
|
|
|
|
2017-10-14 20:03:02 +02:00
|
|
|
def test_parse_caption_entity(self):
|
|
|
|
caption = (b'\\U0001f469\\u200d\\U0001f469\\u200d\\U0001f467'
|
|
|
|
b'\\u200d\\U0001f467\\U0001f431http://google.com').decode('unicode-escape')
|
|
|
|
entity = MessageEntity(type=MessageEntity.URL, offset=13, length=17)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat, caption=caption,
|
|
|
|
caption_entities=[entity])
|
|
|
|
assert message.parse_caption_entity(entity) == 'http://google.com'
|
|
|
|
|
2016-09-07 08:49:09 +02:00
|
|
|
def test_parse_entities(self):
|
|
|
|
text = (b'\\U0001f469\\u200d\\U0001f469\\u200d\\U0001f467'
|
|
|
|
b'\\u200d\\U0001f467\\U0001f431http://google.com').decode('unicode-escape')
|
2017-08-11 23:58:41 +02:00
|
|
|
entity = MessageEntity(type=MessageEntity.URL, offset=13, length=17)
|
|
|
|
entity_2 = MessageEntity(type=MessageEntity.BOLD, offset=13, length=1)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat,
|
|
|
|
text=text, entities=[entity_2, entity])
|
|
|
|
assert message.parse_entities(MessageEntity.URL) == {entity: 'http://google.com'}
|
|
|
|
assert message.parse_entities() == {entity: 'http://google.com', entity_2: 'h'}
|
2016-09-07 08:49:09 +02:00
|
|
|
|
2017-10-14 20:03:02 +02:00
|
|
|
def test_parse_caption_entities(self):
|
|
|
|
text = (b'\\U0001f469\\u200d\\U0001f469\\u200d\\U0001f467'
|
|
|
|
b'\\u200d\\U0001f467\\U0001f431http://google.com').decode('unicode-escape')
|
|
|
|
entity = MessageEntity(type=MessageEntity.URL, offset=13, length=17)
|
|
|
|
entity_2 = MessageEntity(type=MessageEntity.BOLD, offset=13, length=1)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat,
|
|
|
|
caption=text, caption_entities=[entity_2, entity])
|
|
|
|
assert message.parse_caption_entities(MessageEntity.URL) == {entity: 'http://google.com'}
|
|
|
|
assert message.parse_caption_entities() == {entity: 'http://google.com', entity_2: 'h'}
|
|
|
|
|
2017-05-21 14:00:07 +02:00
|
|
|
def test_text_html_simple(self):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_html_string = ('<u>Test</u> for <<b>bold</b>, <i>ita_lic</i>, '
|
|
|
|
r'<code>\`code</code>, '
|
|
|
|
r'<a href="http://github.com/abc\)def">links</a>, '
|
2018-09-25 20:07:55 +02:00
|
|
|
'<a href="tg://user?id=123456789">text-mention</a> and '
|
2020-06-15 18:20:51 +02:00
|
|
|
r'<pre>`\pre</pre>. http://google.com '
|
2020-03-29 09:52:30 +02:00
|
|
|
'and <i>bold <b>nested in <s>strk</s> nested in</b> italic</i>. '
|
|
|
|
'<pre><code class="python">Python pre</code></pre>.')
|
2020-03-28 16:37:26 +01:00
|
|
|
text_html = self.test_message_v2.text_html
|
2017-08-11 23:58:41 +02:00
|
|
|
assert text_html == test_html_string
|
|
|
|
|
2018-03-16 21:42:39 +01:00
|
|
|
def test_text_html_empty(self, message):
|
|
|
|
message.text = None
|
|
|
|
message.caption = "test"
|
|
|
|
assert message.text_html is None
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_text_html_urled(self):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_html_string = ('<u>Test</u> for <<b>bold</b>, <i>ita_lic</i>, '
|
|
|
|
r'<code>\`code</code>, '
|
|
|
|
r'<a href="http://github.com/abc\)def">links</a>, '
|
2018-09-25 20:07:55 +02:00
|
|
|
'<a href="tg://user?id=123456789">text-mention</a> and '
|
2020-06-15 18:20:51 +02:00
|
|
|
r'<pre>`\pre</pre>. <a href="http://google.com">http://google.com</a> '
|
2020-03-29 09:52:30 +02:00
|
|
|
'and <i>bold <b>nested in <s>strk</s> nested in</b> italic</i>. '
|
|
|
|
'<pre><code class="python">Python pre</code></pre>.')
|
2020-03-28 16:37:26 +01:00
|
|
|
text_html = self.test_message_v2.text_html_urled
|
2017-08-11 23:58:41 +02:00
|
|
|
assert text_html == test_html_string
|
2017-01-20 20:13:58 +01:00
|
|
|
|
2017-05-21 14:00:07 +02:00
|
|
|
def test_text_markdown_simple(self):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_md_string = (r'Test for <*bold*, _ita_\__lic_, `code`, '
|
|
|
|
'[links](http://github.com/ab_), '
|
|
|
|
'[text-mention](tg://user?id=123456789) and ```python\npre```. '
|
|
|
|
r'http://google.com/ab\_')
|
2017-01-20 20:13:58 +01:00
|
|
|
text_markdown = self.test_message.text_markdown
|
2017-08-11 23:58:41 +02:00
|
|
|
assert text_markdown == test_md_string
|
|
|
|
|
2020-03-28 16:37:26 +01:00
|
|
|
def test_text_markdown_v2_simple(self):
|
|
|
|
test_md_string = (r'__Test__ for <*bold*, _ita\_lic_, `\\\`code`, '
|
2020-06-15 18:20:51 +02:00
|
|
|
'[links](http://github.com/abc\\\\\\)def), '
|
|
|
|
'[text\\-mention](tg://user?id=123456789) and ```\\`\\\\pre```\\. '
|
|
|
|
r'http://google\.com and _bold *nested in ~strk~ nested in* italic_\. '
|
|
|
|
'```python\nPython pre```\\.')
|
2020-03-28 16:37:26 +01:00
|
|
|
text_markdown = self.test_message_v2.text_markdown_v2
|
|
|
|
assert text_markdown == test_md_string
|
|
|
|
|
|
|
|
def test_text_markdown_new_in_v2(self, message):
|
|
|
|
message.text = 'test'
|
|
|
|
message.entities = [MessageEntity(MessageEntity.BOLD, offset=0, length=4),
|
|
|
|
MessageEntity(MessageEntity.ITALIC, offset=0, length=4)]
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
assert message.text_markdown
|
|
|
|
|
|
|
|
message.entities = [MessageEntity(MessageEntity.UNDERLINE, offset=0, length=4)]
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
message.text_markdown
|
|
|
|
|
|
|
|
message.entities = [MessageEntity(MessageEntity.STRIKETHROUGH, offset=0, length=4)]
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
message.text_markdown
|
|
|
|
|
|
|
|
message.entities = []
|
|
|
|
|
2018-03-16 21:42:39 +01:00
|
|
|
def test_text_markdown_empty(self, message):
|
|
|
|
message.text = None
|
|
|
|
message.caption = "test"
|
|
|
|
assert message.text_markdown is None
|
2020-03-28 16:37:26 +01:00
|
|
|
assert message.text_markdown_v2 is None
|
2018-03-16 21:42:39 +01:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_text_markdown_urled(self):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_md_string = (r'Test for <*bold*, _ita_\__lic_, `code`, '
|
|
|
|
'[links](http://github.com/ab_), '
|
|
|
|
'[text-mention](tg://user?id=123456789) and ```python\npre```. '
|
2020-03-28 16:37:26 +01:00
|
|
|
'[http://google.com/ab_](http://google.com/ab_)')
|
2017-08-11 23:58:41 +02:00
|
|
|
text_markdown = self.test_message.text_markdown_urled
|
|
|
|
assert text_markdown == test_md_string
|
2017-01-20 20:13:58 +01:00
|
|
|
|
2020-03-28 16:37:26 +01:00
|
|
|
def test_text_markdown_v2_urled(self):
|
|
|
|
test_md_string = (r'__Test__ for <*bold*, _ita\_lic_, `\\\`code`, '
|
2020-06-15 18:20:51 +02:00
|
|
|
'[links](http://github.com/abc\\\\\\)def), '
|
|
|
|
'[text\\-mention](tg://user?id=123456789) and ```\\`\\\\pre```\\. '
|
|
|
|
r'[http://google\.com](http://google.com) and _bold *nested in ~strk~ '
|
|
|
|
'nested in* italic_\\. ```python\nPython pre```\\.')
|
2020-03-28 16:37:26 +01:00
|
|
|
text_markdown = self.test_message_v2.text_markdown_v2_urled
|
|
|
|
assert text_markdown == test_md_string
|
|
|
|
|
2017-05-21 14:00:07 +02:00
|
|
|
def test_text_html_emoji(self):
|
2017-08-11 23:58:41 +02:00
|
|
|
text = b'\\U0001f469\\u200d\\U0001f469\\u200d ABC'.decode('unicode-escape')
|
|
|
|
expected = b'\\U0001f469\\u200d\\U0001f469\\u200d <b>ABC</b>'.decode('unicode-escape')
|
|
|
|
bold_entity = MessageEntity(type=MessageEntity.BOLD, offset=7, length=3)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat,
|
|
|
|
text=text, entities=[bold_entity])
|
|
|
|
assert expected == message.text_html
|
2017-05-21 14:00:07 +02:00
|
|
|
|
|
|
|
def test_text_markdown_emoji(self):
|
2017-08-11 23:58:41 +02:00
|
|
|
text = b'\\U0001f469\\u200d\\U0001f469\\u200d ABC'.decode('unicode-escape')
|
|
|
|
expected = b'\\U0001f469\\u200d\\U0001f469\\u200d *ABC*'.decode('unicode-escape')
|
|
|
|
bold_entity = MessageEntity(type=MessageEntity.BOLD, offset=7, length=3)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat,
|
|
|
|
text=text, entities=[bold_entity])
|
|
|
|
assert expected == message.text_markdown
|
2017-05-21 14:00:07 +02:00
|
|
|
|
2018-02-22 16:38:54 +01:00
|
|
|
def test_caption_html_simple(self):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_html_string = ('<u>Test</u> for <<b>bold</b>, <i>ita_lic</i>, '
|
|
|
|
r'<code>\`code</code>, '
|
|
|
|
r'<a href="http://github.com/abc\)def">links</a>, '
|
2018-09-25 20:07:55 +02:00
|
|
|
'<a href="tg://user?id=123456789">text-mention</a> and '
|
2020-06-15 18:20:51 +02:00
|
|
|
r'<pre>`\pre</pre>. http://google.com '
|
2020-03-29 09:52:30 +02:00
|
|
|
'and <i>bold <b>nested in <s>strk</s> nested in</b> italic</i>. '
|
|
|
|
'<pre><code class="python">Python pre</code></pre>.')
|
2020-03-28 16:37:26 +01:00
|
|
|
caption_html = self.test_message_v2.caption_html
|
2018-02-22 16:38:54 +01:00
|
|
|
assert caption_html == test_html_string
|
|
|
|
|
2018-03-16 21:42:39 +01:00
|
|
|
def test_caption_html_empty(self, message):
|
|
|
|
message.text = "test"
|
|
|
|
message.caption = None
|
|
|
|
assert message.caption_html is None
|
|
|
|
|
2018-02-22 16:38:54 +01:00
|
|
|
def test_caption_html_urled(self):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_html_string = ('<u>Test</u> for <<b>bold</b>, <i>ita_lic</i>, '
|
|
|
|
r'<code>\`code</code>, '
|
|
|
|
r'<a href="http://github.com/abc\)def">links</a>, '
|
2018-09-25 20:07:55 +02:00
|
|
|
'<a href="tg://user?id=123456789">text-mention</a> and '
|
2020-06-15 18:20:51 +02:00
|
|
|
r'<pre>`\pre</pre>. <a href="http://google.com">http://google.com</a> '
|
2020-03-29 09:52:30 +02:00
|
|
|
'and <i>bold <b>nested in <s>strk</s> nested in</b> italic</i>. '
|
|
|
|
'<pre><code class="python">Python pre</code></pre>.')
|
2020-03-28 16:37:26 +01:00
|
|
|
caption_html = self.test_message_v2.caption_html_urled
|
2018-02-22 16:38:54 +01:00
|
|
|
assert caption_html == test_html_string
|
|
|
|
|
|
|
|
def test_caption_markdown_simple(self):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_md_string = (r'Test for <*bold*, _ita_\__lic_, `code`, '
|
|
|
|
'[links](http://github.com/ab_), '
|
|
|
|
'[text-mention](tg://user?id=123456789) and ```python\npre```. '
|
|
|
|
r'http://google.com/ab\_')
|
2018-02-22 16:38:54 +01:00
|
|
|
caption_markdown = self.test_message.caption_markdown
|
|
|
|
assert caption_markdown == test_md_string
|
|
|
|
|
2020-03-28 16:37:26 +01:00
|
|
|
def test_caption_markdown_v2_simple(self):
|
|
|
|
test_md_string = (r'__Test__ for <*bold*, _ita\_lic_, `\\\`code`, '
|
|
|
|
'[links](http://github.com/abc\\\\\\)def), '
|
2020-06-15 18:20:51 +02:00
|
|
|
'[text\\-mention](tg://user?id=123456789) and ```\\`\\\\pre```\\. '
|
|
|
|
r'http://google\.com and _bold *nested in ~strk~ nested in* italic_\. '
|
|
|
|
'```python\nPython pre```\\.')
|
2020-03-28 16:37:26 +01:00
|
|
|
caption_markdown = self.test_message_v2.caption_markdown_v2
|
|
|
|
assert caption_markdown == test_md_string
|
|
|
|
|
2018-03-16 21:42:39 +01:00
|
|
|
def test_caption_markdown_empty(self, message):
|
|
|
|
message.text = "test"
|
|
|
|
message.caption = None
|
|
|
|
assert message.caption_markdown is None
|
2020-03-28 16:37:26 +01:00
|
|
|
assert message.caption_markdown_v2 is None
|
2018-03-16 21:42:39 +01:00
|
|
|
|
2018-02-22 16:38:54 +01:00
|
|
|
def test_caption_markdown_urled(self):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_md_string = (r'Test for <*bold*, _ita_\__lic_, `code`, '
|
|
|
|
'[links](http://github.com/ab_), '
|
|
|
|
'[text-mention](tg://user?id=123456789) and ```python\npre```. '
|
2020-03-28 16:37:26 +01:00
|
|
|
'[http://google.com/ab_](http://google.com/ab_)')
|
2018-02-22 16:38:54 +01:00
|
|
|
caption_markdown = self.test_message.caption_markdown_urled
|
|
|
|
assert caption_markdown == test_md_string
|
|
|
|
|
2020-03-28 16:37:26 +01:00
|
|
|
def test_caption_markdown_v2_urled(self):
|
|
|
|
test_md_string = (r'__Test__ for <*bold*, _ita\_lic_, `\\\`code`, '
|
|
|
|
'[links](http://github.com/abc\\\\\\)def), '
|
2020-06-15 18:20:51 +02:00
|
|
|
'[text\\-mention](tg://user?id=123456789) and ```\\`\\\\pre```\\. '
|
|
|
|
r'[http://google\.com](http://google.com) and _bold *nested in ~strk~ '
|
|
|
|
'nested in* italic_\\. ```python\nPython pre```\\.')
|
2020-03-28 16:37:26 +01:00
|
|
|
caption_markdown = self.test_message_v2.caption_markdown_v2_urled
|
|
|
|
assert caption_markdown == test_md_string
|
|
|
|
|
2018-02-22 16:38:54 +01:00
|
|
|
def test_caption_html_emoji(self):
|
|
|
|
caption = b'\\U0001f469\\u200d\\U0001f469\\u200d ABC'.decode('unicode-escape')
|
|
|
|
expected = b'\\U0001f469\\u200d\\U0001f469\\u200d <b>ABC</b>'.decode('unicode-escape')
|
|
|
|
bold_entity = MessageEntity(type=MessageEntity.BOLD, offset=7, length=3)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat,
|
|
|
|
caption=caption, caption_entities=[bold_entity])
|
|
|
|
assert expected == message.caption_html
|
|
|
|
|
|
|
|
def test_caption_markdown_emoji(self):
|
|
|
|
caption = b'\\U0001f469\\u200d\\U0001f469\\u200d ABC'.decode('unicode-escape')
|
|
|
|
expected = b'\\U0001f469\\u200d\\U0001f469\\u200d *ABC*'.decode('unicode-escape')
|
|
|
|
bold_entity = MessageEntity(type=MessageEntity.BOLD, offset=7, length=3)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat,
|
|
|
|
caption=caption, caption_entities=[bold_entity])
|
|
|
|
assert expected == message.caption_markdown
|
|
|
|
|
2017-05-21 14:00:07 +02:00
|
|
|
def test_parse_entities_url_emoji(self):
|
|
|
|
url = b'http://github.com/?unicode=\\u2713\\U0001f469'.decode('unicode-escape')
|
|
|
|
text = 'some url'
|
2017-08-11 23:58:41 +02:00
|
|
|
link_entity = MessageEntity(type=MessageEntity.URL, offset=0, length=8, url=url)
|
|
|
|
message = Message(1, self.from_user, self.date, self.chat,
|
|
|
|
text=text, entities=[link_entity])
|
|
|
|
assert message.parse_entities() == {link_entity: text}
|
|
|
|
assert next(iter(message.parse_entities())).url == url
|
2017-05-14 23:29:31 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_chat_id(self, message):
|
|
|
|
assert message.chat_id == message.chat.id
|
2017-05-14 23:29:31 +02:00
|
|
|
|
2019-11-29 13:50:44 +01:00
|
|
|
@pytest.mark.parametrize('type', argvalues=[Chat.SUPERGROUP, Chat.CHANNEL])
|
|
|
|
def test_link_with_username(self, message, type):
|
2018-05-09 11:42:12 +02:00
|
|
|
message.chat.username = 'username'
|
2019-11-29 13:50:44 +01:00
|
|
|
message.chat.type = type
|
2018-05-09 11:42:12 +02:00
|
|
|
assert message.link == 'https://t.me/{}/{}'.format(message.chat.username,
|
|
|
|
message.message_id)
|
2019-11-29 13:50:44 +01:00
|
|
|
|
|
|
|
@pytest.mark.parametrize('type, id', argvalues=[
|
2020-02-02 20:27:53 +01:00
|
|
|
(Chat.CHANNEL, -1003), (Chat.SUPERGROUP, -1003)])
|
2019-11-29 13:50:44 +01:00
|
|
|
def test_link_with_id(self, message, type, id):
|
|
|
|
message.chat.username = None
|
|
|
|
message.chat.id = id
|
|
|
|
message.chat.type = type
|
|
|
|
# The leading - for group ids/ -100 for supergroup ids isn't supposed to be in the link
|
|
|
|
assert message.link == 'https://t.me/c/{}/{}'.format(3, message.message_id)
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('id, username', argvalues=[
|
|
|
|
(None, 'username'), (-3, None)
|
|
|
|
])
|
|
|
|
def test_link_private_chats(self, message, id, username):
|
|
|
|
message.chat.type = Chat.PRIVATE
|
|
|
|
message.chat.id = id
|
|
|
|
message.chat.username = username
|
2018-05-09 11:42:12 +02:00
|
|
|
assert message.link is None
|
2020-02-02 20:27:53 +01:00
|
|
|
message.chat.type = Chat.GROUP
|
|
|
|
assert message.link is None
|
2018-05-09 11:42:12 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_effective_attachment(self, message_params):
|
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
|
|
|
for i in ('audio', 'game', 'document', 'animation', 'photo', 'sticker', 'video', 'voice',
|
|
|
|
'video_note', 'contact', 'location', 'venue', 'invoice', 'invoice',
|
|
|
|
'successful_payment'):
|
2017-08-11 23:58:41 +02:00
|
|
|
item = getattr(message_params, i, None)
|
|
|
|
if item:
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
item = None
|
|
|
|
assert message_params.effective_attachment == item
|
|
|
|
|
|
|
|
def test_reply_text(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2020-02-06 11:22:56 +01:00
|
|
|
text = args[1] == 'test'
|
2017-08-11 23:58:41 +02:00
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and text and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_message', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_text('test')
|
|
|
|
assert message.reply_text('test', quote=True)
|
|
|
|
assert message.reply_text('test', reply_to_message_id=message.message_id, quote=True)
|
|
|
|
|
2018-02-12 14:39:46 +01:00
|
|
|
def test_reply_markdown(self, monkeypatch, message):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_md_string = (r'Test for <*bold*, _ita_\__lic_, `code`, '
|
|
|
|
'[links](http://github.com/ab_), '
|
|
|
|
'[text-mention](tg://user?id=123456789) and ```python\npre```. '
|
|
|
|
r'http://google.com/ab\_')
|
2018-02-12 14:39:46 +01:00
|
|
|
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
cid = args[0] == message.chat_id
|
|
|
|
markdown_text = args[1] == test_md_string
|
2018-02-12 14:39:46 +01:00
|
|
|
markdown_enabled = kwargs['parse_mode'] == ParseMode.MARKDOWN
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
|
|
|
return all([cid, markdown_text, reply, markdown_enabled])
|
|
|
|
|
|
|
|
text_markdown = self.test_message.text_markdown
|
|
|
|
assert text_markdown == test_md_string
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_message', test)
|
2018-02-12 14:39:46 +01:00
|
|
|
assert message.reply_markdown(self.test_message.text_markdown)
|
|
|
|
assert message.reply_markdown(self.test_message.text_markdown, quote=True)
|
|
|
|
assert message.reply_markdown(self.test_message.text_markdown,
|
|
|
|
reply_to_message_id=message.message_id,
|
|
|
|
quote=True)
|
|
|
|
|
2020-03-28 16:37:26 +01:00
|
|
|
def test_reply_markdown_v2(self, monkeypatch, message):
|
|
|
|
test_md_string = (r'__Test__ for <*bold*, _ita\_lic_, `\\\`code`, '
|
2020-06-15 18:20:51 +02:00
|
|
|
'[links](http://github.com/abc\\\\\\)def), '
|
|
|
|
'[text\\-mention](tg://user?id=123456789) and ```\\`\\\\pre```\\. '
|
|
|
|
r'http://google\.com and _bold *nested in ~strk~ nested in* italic_\. '
|
|
|
|
'```python\nPython pre```\\.')
|
2020-03-28 16:37:26 +01:00
|
|
|
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
cid = args[0] == message.chat_id
|
|
|
|
markdown_text = args[1] == test_md_string
|
|
|
|
markdown_enabled = kwargs['parse_mode'] == ParseMode.MARKDOWN_V2
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
|
|
|
return all([cid, markdown_text, reply, markdown_enabled])
|
|
|
|
|
|
|
|
text_markdown = self.test_message_v2.text_markdown_v2
|
|
|
|
assert text_markdown == test_md_string
|
|
|
|
|
|
|
|
monkeypatch.setattr(message.bot, 'send_message', test)
|
|
|
|
assert message.reply_markdown_v2(self.test_message_v2.text_markdown_v2)
|
|
|
|
assert message.reply_markdown_v2(self.test_message_v2.text_markdown_v2, quote=True)
|
|
|
|
assert message.reply_markdown_v2(self.test_message_v2.text_markdown_v2,
|
|
|
|
reply_to_message_id=message.message_id,
|
|
|
|
quote=True)
|
|
|
|
|
2018-02-12 14:39:46 +01:00
|
|
|
def test_reply_html(self, monkeypatch, message):
|
2020-06-15 18:20:51 +02:00
|
|
|
test_html_string = ('<u>Test</u> for <<b>bold</b>, <i>ita_lic</i>, '
|
|
|
|
r'<code>\`code</code>, '
|
|
|
|
r'<a href="http://github.com/abc\)def">links</a>, '
|
2018-09-25 20:07:55 +02:00
|
|
|
'<a href="tg://user?id=123456789">text-mention</a> and '
|
2020-06-15 18:20:51 +02:00
|
|
|
r'<pre>`\pre</pre>. http://google.com '
|
2020-03-29 09:52:30 +02:00
|
|
|
'and <i>bold <b>nested in <s>strk</s> nested in</b> italic</i>. '
|
|
|
|
'<pre><code class="python">Python pre</code></pre>.')
|
2018-02-12 14:39:46 +01:00
|
|
|
|
|
|
|
def test(*args, **kwargs):
|
2020-02-06 11:22:56 +01:00
|
|
|
cid = args[0] == message.chat_id
|
|
|
|
html_text = args[1] == test_html_string
|
2018-02-12 14:39:46 +01:00
|
|
|
html_enabled = kwargs['parse_mode'] == ParseMode.HTML
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
|
|
|
return all([cid, html_text, reply, html_enabled])
|
|
|
|
|
2020-03-28 16:37:26 +01:00
|
|
|
text_html = self.test_message_v2.text_html
|
2018-02-12 14:39:46 +01:00
|
|
|
assert text_html == test_html_string
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_message', test)
|
2020-03-28 16:37:26 +01:00
|
|
|
assert message.reply_html(self.test_message_v2.text_html)
|
|
|
|
assert message.reply_html(self.test_message_v2.text_html, quote=True)
|
|
|
|
assert message.reply_html(self.test_message_v2.text_html,
|
2018-02-12 14:39:46 +01:00
|
|
|
reply_to_message_id=message.message_id,
|
|
|
|
quote=True)
|
|
|
|
|
2018-02-12 14:51:18 +01:00
|
|
|
def test_reply_media_group(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2018-02-12 14:51:18 +01:00
|
|
|
media = kwargs['media'] == 'reply_media_group'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and media and reply
|
2018-02-12 14:51:18 +01:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_media_group', test)
|
2018-02-12 14:51:18 +01:00
|
|
|
assert message.reply_media_group(media='reply_media_group')
|
|
|
|
assert message.reply_media_group(media='reply_media_group', quote=True)
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_reply_photo(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
photo = kwargs['photo'] == 'test_photo'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and photo and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_photo', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_photo(photo='test_photo')
|
|
|
|
assert message.reply_photo(photo='test_photo', quote=True)
|
|
|
|
|
|
|
|
def test_reply_audio(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
audio = kwargs['audio'] == 'test_audio'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and audio and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_audio', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_audio(audio='test_audio')
|
|
|
|
assert message.reply_audio(audio='test_audio', quote=True)
|
|
|
|
|
|
|
|
def test_reply_document(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
document = kwargs['document'] == 'test_document'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and document and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_document', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_document(document='test_document')
|
|
|
|
assert message.reply_document(document='test_document', quote=True)
|
|
|
|
|
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_reply_animation(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
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
|
|
|
animation = kwargs['animation'] == 'test_animation'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and animation and reply
|
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(message.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 message.reply_animation(animation='test_animation')
|
|
|
|
assert message.reply_animation(animation='test_animation', quote=True)
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_reply_sticker(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
sticker = kwargs['sticker'] == 'test_sticker'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and sticker and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_sticker', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_sticker(sticker='test_sticker')
|
|
|
|
assert message.reply_sticker(sticker='test_sticker', quote=True)
|
|
|
|
|
|
|
|
def test_reply_video(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
video = kwargs['video'] == 'test_video'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and video and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_video', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_video(video='test_video')
|
|
|
|
assert message.reply_video(video='test_video', quote=True)
|
|
|
|
|
|
|
|
def test_reply_video_note(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
video_note = kwargs['video_note'] == 'test_video_note'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and video_note and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_video_note', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_video_note(video_note='test_video_note')
|
|
|
|
assert message.reply_video_note(video_note='test_video_note', quote=True)
|
|
|
|
|
|
|
|
def test_reply_voice(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
voice = kwargs['voice'] == 'test_voice'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and voice and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_voice', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_voice(voice='test_voice')
|
|
|
|
assert message.reply_voice(voice='test_voice', quote=True)
|
|
|
|
|
|
|
|
def test_reply_location(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
location = kwargs['location'] == 'test_location'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and location and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_location', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_location(location='test_location')
|
|
|
|
assert message.reply_location(location='test_location', quote=True)
|
|
|
|
|
|
|
|
def test_reply_venue(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
venue = kwargs['venue'] == 'test_venue'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and venue and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_venue', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_venue(venue='test_venue')
|
|
|
|
assert message.reply_venue(venue='test_venue', quote=True)
|
|
|
|
|
|
|
|
def test_reply_contact(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2017-08-11 23:58:41 +02:00
|
|
|
contact = kwargs['contact'] == 'test_contact'
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and contact and reply
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_contact', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.reply_contact(contact='test_contact')
|
|
|
|
assert message.reply_contact(contact='test_contact', quote=True)
|
|
|
|
|
2019-08-23 21:20:41 +02:00
|
|
|
def test_reply_poll(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = args[0] == message.chat_id
|
2020-04-10 19:22:45 +02:00
|
|
|
contact = kwargs['question'] == 'test_poll'
|
2019-08-23 21:20:41 +02:00
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
2020-02-23 22:03:58 +01:00
|
|
|
return id_ and contact and reply
|
2019-08-23 21:20:41 +02:00
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'send_poll', test)
|
2020-04-10 19:22:45 +02:00
|
|
|
assert message.reply_poll(question='test_poll')
|
|
|
|
assert message.reply_poll(question='test_poll', quote=True)
|
|
|
|
|
|
|
|
def test_reply_dice(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
id_ = args[0] == message.chat_id
|
|
|
|
contact = kwargs['disable_notification'] is True
|
|
|
|
if kwargs.get('reply_to_message_id'):
|
|
|
|
reply = kwargs['reply_to_message_id'] == message.message_id
|
|
|
|
else:
|
|
|
|
reply = True
|
|
|
|
return id_ and contact and reply
|
|
|
|
|
|
|
|
monkeypatch.setattr(message.bot, 'send_dice', test)
|
|
|
|
assert message.reply_dice(disable_notification=True)
|
|
|
|
assert message.reply_dice(disable_notification=True, quote=True)
|
2019-08-23 21:20:41 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_forward(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == 123456
|
|
|
|
from_chat = kwargs['from_chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
if kwargs.get('disable_notification'):
|
|
|
|
notification = kwargs['disable_notification'] is True
|
|
|
|
else:
|
|
|
|
notification = True
|
|
|
|
return chat_id and from_chat and message_id and notification
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'forward_message', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.forward(123456)
|
|
|
|
assert message.forward(123456, disable_notification=True)
|
|
|
|
assert not message.forward(635241)
|
|
|
|
|
|
|
|
def test_edit_text(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
text = kwargs['text'] == 'test'
|
|
|
|
return chat_id and message_id and text
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'edit_message_text', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.edit_text(text='test')
|
|
|
|
|
|
|
|
def test_edit_caption(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
caption = kwargs['caption'] == 'new caption'
|
|
|
|
return chat_id and message_id and caption
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'edit_message_caption', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.edit_caption(caption='new caption')
|
|
|
|
|
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_edit_media(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
media = kwargs['media'] == 'my_media'
|
|
|
|
return chat_id and message_id and media
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'edit_message_media', 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 message.edit_media('my_media')
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_edit_reply_markup(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
reply_markup = kwargs['reply_markup'] == [['1', '2']]
|
|
|
|
return chat_id and message_id and reply_markup
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'edit_message_reply_markup', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.edit_reply_markup(reply_markup=[['1', '2']])
|
|
|
|
|
2020-08-13 13:39:43 +02:00
|
|
|
def test_edit_live_location(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
latitude = kwargs['latitude'] == 1
|
|
|
|
longitude = kwargs['longitude'] == 2
|
|
|
|
return chat_id and message_id and longitude and latitude
|
|
|
|
|
|
|
|
monkeypatch.setattr(message.bot, 'edit_message_live_location', test)
|
|
|
|
assert message.edit_live_location(latitude=1, longitude=2)
|
|
|
|
|
|
|
|
def test_stop_live_location(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
return chat_id and message_id
|
|
|
|
|
|
|
|
monkeypatch.setattr(message.bot, 'stop_message_live_location', test)
|
|
|
|
assert message.stop_live_location()
|
|
|
|
|
|
|
|
def test_set_game_score(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
user_id = kwargs['user_id'] == 1
|
|
|
|
score = kwargs['score'] == 2
|
|
|
|
return chat_id and message_id and user_id and score
|
|
|
|
|
|
|
|
monkeypatch.setattr(message.bot, 'set_game_score', test)
|
|
|
|
assert message.set_game_score(user_id=1, score=2)
|
|
|
|
|
|
|
|
def test_get_game_high_scores(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
user_id = kwargs['user_id'] == 1
|
|
|
|
return chat_id and message_id and user_id
|
|
|
|
|
|
|
|
monkeypatch.setattr(message.bot, 'get_game_high_scores', test)
|
|
|
|
assert message.get_game_high_scores(user_id=1, score=2)
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_delete(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
return chat_id and message_id
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
monkeypatch.setattr(message.bot, 'delete_message', test)
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.delete()
|
|
|
|
|
2020-08-13 13:39:43 +02:00
|
|
|
def test_stop_poll(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
return chat_id and message_id
|
|
|
|
|
|
|
|
monkeypatch.setattr(message.bot, 'stop_poll', test)
|
|
|
|
assert message.stop_poll()
|
|
|
|
|
|
|
|
def test_pin(self, monkeypatch, message):
|
|
|
|
def test(*args, **kwargs):
|
|
|
|
chat_id = kwargs['chat_id'] == message.chat_id
|
|
|
|
message_id = kwargs['message_id'] == message.message_id
|
|
|
|
return chat_id and message_id
|
|
|
|
|
|
|
|
monkeypatch.setattr(message.bot, 'pin_chat_message', test)
|
|
|
|
assert message.pin()
|
|
|
|
|
2020-02-06 11:22:56 +01:00
|
|
|
def test_default_quote(self, message):
|
|
|
|
kwargs = {}
|
|
|
|
|
|
|
|
message.default_quote = False
|
|
|
|
message._quote(kwargs)
|
|
|
|
assert 'reply_to_message_id' not in kwargs
|
|
|
|
|
|
|
|
message.default_quote = True
|
|
|
|
message._quote(kwargs)
|
|
|
|
assert 'reply_to_message_id' in kwargs
|
|
|
|
|
|
|
|
kwargs = {}
|
|
|
|
message.default_quote = None
|
|
|
|
message.chat.type = Chat.PRIVATE
|
|
|
|
message._quote(kwargs)
|
|
|
|
assert 'reply_to_message_id' not in kwargs
|
|
|
|
|
|
|
|
message.chat.type = Chat.GROUP
|
|
|
|
message._quote(kwargs)
|
|
|
|
assert 'reply_to_message_id' in kwargs
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_equality(self):
|
2020-02-23 22:03:58 +01:00
|
|
|
id_ = 1
|
|
|
|
a = Message(id_, self.from_user, self.date, self.chat)
|
|
|
|
b = Message(id_, self.from_user, self.date, self.chat)
|
|
|
|
c = Message(id_, User(0, '', False), self.date, self.chat)
|
2017-08-11 23:58:41 +02:00
|
|
|
d = Message(0, self.from_user, self.date, self.chat)
|
2020-02-23 22:03:58 +01:00
|
|
|
e = Update(id_)
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
assert a == b
|
|
|
|
assert hash(a) == hash(b)
|
|
|
|
assert a is not b
|
2017-08-07 23:25:19 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert a == c
|
|
|
|
assert hash(a) == hash(c)
|
2017-08-07 23:25:19 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert a != d
|
|
|
|
assert hash(a) != hash(d)
|
2016-09-07 08:49:09 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert a != e
|
|
|
|
assert hash(a) != hash(e)
|