2017-08-11 23:58:41 +02:00
|
|
|
#!/usr/bin/env python
|
2018-09-21 08:57:43 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
2017-08-11 23:58:41 +02:00
|
|
|
#
|
|
|
|
# A library that provides a Python interface to the Telegram Bot API
|
2018-01-04 16:16:06 +01:00
|
|
|
# Copyright (C) 2015-2018
|
2017-08-11 23:58:41 +02:00
|
|
|
# Leandro Toledo de Souza <devs@python-telegram-bot.org>
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU Lesser Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU Lesser Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU Lesser Public License
|
|
|
|
# along with this program. If not, see [http://www.gnu.org/licenses/].
|
2019-02-13 12:07:25 +01:00
|
|
|
import re
|
2018-09-21 08:57:01 +02:00
|
|
|
from queue import Queue
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
import pytest
|
2019-02-13 12:07:25 +01:00
|
|
|
from telegram.utils.deprecate import TelegramDeprecationWarning
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
from telegram import (Message, Update, Chat, Bot, User, CallbackQuery, InlineQuery,
|
2018-09-21 08:57:43 +02:00
|
|
|
ChosenInlineResult, ShippingQuery, PreCheckoutQuery, MessageEntity)
|
|
|
|
from telegram.ext import CommandHandler, Filters, BaseFilter, CallbackContext, JobQueue, \
|
|
|
|
PrefixHandler
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2017-09-01 08:40:05 +02:00
|
|
|
message = Message(1, User(1, '', False), None, Chat(1, ''), text='test')
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
params = [
|
2017-09-01 08:40:05 +02:00
|
|
|
{'callback_query': CallbackQuery(1, User(1, '', False), 'chat', message=message)},
|
2017-08-11 23:58:41 +02:00
|
|
|
{'channel_post': message},
|
|
|
|
{'edited_channel_post': message},
|
2017-09-01 08:40:05 +02:00
|
|
|
{'inline_query': InlineQuery(1, User(1, '', False), '', '')},
|
|
|
|
{'chosen_inline_result': ChosenInlineResult('id', User(1, '', False), '')},
|
|
|
|
{'shipping_query': ShippingQuery('id', User(1, '', False), '', None)},
|
|
|
|
{'pre_checkout_query': PreCheckoutQuery('id', User(1, '', False), '', 0, '')},
|
|
|
|
{'callback_query': CallbackQuery(1, User(1, '', False), 'chat')}
|
2017-08-11 23:58:41 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
ids = ('callback_query', 'channel_post', 'edited_channel_post', 'inline_query',
|
|
|
|
'chosen_inline_result', 'shipping_query', 'pre_checkout_query',
|
|
|
|
'callback_query_without_message',)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='class', params=params, ids=ids)
|
|
|
|
def false_update(request):
|
|
|
|
return Update(update_id=1, **request.param)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='function')
|
|
|
|
def message(bot):
|
2018-09-21 08:57:43 +02:00
|
|
|
return Message(message_id=1,
|
|
|
|
from_user=User(id=1, first_name='', is_bot=False),
|
|
|
|
date=None,
|
|
|
|
chat=Chat(id=1, type=''),
|
|
|
|
message='/test',
|
|
|
|
bot=bot,
|
|
|
|
entities=[MessageEntity(type=MessageEntity.BOT_COMMAND,
|
|
|
|
offset=0,
|
|
|
|
length=len('/test'))])
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
class TestCommandHandler(object):
|
|
|
|
test_flag = False
|
2019-02-13 12:07:25 +01:00
|
|
|
SRE_TYPE = type(re.match("", ""))
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def reset(self):
|
|
|
|
self.test_flag = False
|
|
|
|
|
|
|
|
def callback_basic(self, bot, update):
|
|
|
|
test_bot = isinstance(bot, Bot)
|
|
|
|
test_update = isinstance(update, Update)
|
|
|
|
self.test_flag = test_bot and test_update
|
|
|
|
|
|
|
|
def callback_data_1(self, bot, update, user_data=None, chat_data=None):
|
|
|
|
self.test_flag = (user_data is not None) or (chat_data is not None)
|
|
|
|
|
|
|
|
def callback_data_2(self, bot, update, user_data=None, chat_data=None):
|
|
|
|
self.test_flag = (user_data is not None) and (chat_data is not None)
|
|
|
|
|
|
|
|
def callback_queue_1(self, bot, update, job_queue=None, update_queue=None):
|
|
|
|
self.test_flag = (job_queue is not None) or (update_queue is not None)
|
|
|
|
|
|
|
|
def callback_queue_2(self, bot, update, job_queue=None, update_queue=None):
|
|
|
|
self.test_flag = (job_queue is not None) and (update_queue is not None)
|
|
|
|
|
|
|
|
def ch_callback_args(self, bot, update, args):
|
|
|
|
if update.message.text == '/test':
|
|
|
|
self.test_flag = len(args) == 0
|
|
|
|
elif update.message.text == '/test@{}'.format(bot.username):
|
|
|
|
self.test_flag = len(args) == 0
|
|
|
|
else:
|
|
|
|
self.test_flag = args == ['one', 'two']
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def callback_context(self, update, context):
|
2019-02-08 20:55:40 +01:00
|
|
|
self.test_flag = (isinstance(context, CallbackContext)
|
|
|
|
and isinstance(context.bot, Bot)
|
|
|
|
and isinstance(update, Update)
|
|
|
|
and isinstance(context.update_queue, Queue)
|
|
|
|
and isinstance(context.job_queue, JobQueue)
|
|
|
|
and isinstance(context.user_data, dict)
|
|
|
|
and isinstance(context.chat_data, dict)
|
|
|
|
and isinstance(update.message, Message))
|
2018-09-21 08:57:01 +02:00
|
|
|
|
|
|
|
def callback_context_args(self, update, context):
|
|
|
|
self.test_flag = context.args == ['one', 'two']
|
|
|
|
|
2019-02-13 12:07:25 +01:00
|
|
|
def callback_context_regex1(self, update, context):
|
|
|
|
if context.matches:
|
|
|
|
types = all([type(res) == self.SRE_TYPE for res in context.matches])
|
|
|
|
num = len(context.matches) == 1
|
|
|
|
self.test_flag = types and num
|
|
|
|
|
|
|
|
def callback_context_regex2(self, update, context):
|
|
|
|
if context.matches:
|
|
|
|
types = all([type(res) == self.SRE_TYPE for res in context.matches])
|
|
|
|
num = len(context.matches) == 2
|
|
|
|
self.test_flag = types and num
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_basic(self, dp, message):
|
|
|
|
handler = CommandHandler('test', self.callback_basic)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test'
|
|
|
|
dp.process_update(Update(0, message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
message.text = '/nottest'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is None or check is False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
message.text = 'test'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is None or check is False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
message.text = 'not /test at start'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is None or check is False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2018-09-21 08:57:43 +02:00
|
|
|
message.entities = []
|
|
|
|
message.text = '/test'
|
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('command',
|
|
|
|
['way_too_longcommand1234567yes_way_toooooooLong', 'ïñválídletters',
|
|
|
|
'invalid #&* chars'],
|
|
|
|
ids=['too long', 'invalid letter', 'invalid characters'])
|
|
|
|
def test_invalid_commands(self, command):
|
|
|
|
with pytest.raises(ValueError, match='not a valid bot command'):
|
|
|
|
CommandHandler(command, self.callback_basic)
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_command_list(self, message):
|
2018-09-21 08:57:43 +02:00
|
|
|
handler = CommandHandler(['test', 'star'], self.callback_basic)
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
message.text = '/test'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2018-09-21 08:57:43 +02:00
|
|
|
message.text = '/star'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
message.text = '/stop'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is None or check is False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2019-02-13 12:07:25 +01:00
|
|
|
def test_deprecation_warning(self):
|
|
|
|
with pytest.warns(TelegramDeprecationWarning, match='See https://git.io/fxJuV'):
|
|
|
|
CommandHandler('test', self.callback_basic, allow_edited=True)
|
|
|
|
|
|
|
|
def test_no_edited(self, message):
|
|
|
|
handler = CommandHandler('test', self.callback_basic)
|
|
|
|
message.text = '/test'
|
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is not None and check is not False
|
|
|
|
|
|
|
|
check = handler.check_update(Update(0, edited_message=message))
|
|
|
|
assert check is not None and check is not False
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
handler = CommandHandler('test', self.callback_basic,
|
2019-02-13 12:07:25 +01:00
|
|
|
filters=~Filters.update.edited_message)
|
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is not None and check is not False
|
|
|
|
|
|
|
|
check = handler.check_update(Update(0, edited_message=message))
|
|
|
|
assert check is None or check is False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2019-02-13 12:07:25 +01:00
|
|
|
def test_edited_deprecated(self, message):
|
|
|
|
handler = CommandHandler('test', self.callback_basic,
|
|
|
|
allow_edited=False)
|
2017-08-11 23:58:41 +02:00
|
|
|
message.text = '/test'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is not None and check is not False
|
2018-09-21 08:57:43 +02:00
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, edited_message=message))
|
|
|
|
assert check is None or check is False
|
2018-09-21 08:57:43 +02:00
|
|
|
|
2019-02-13 12:07:25 +01:00
|
|
|
handler = CommandHandler('test', self.callback_basic,
|
|
|
|
allow_edited=True)
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is not None and check is not False
|
2018-09-21 08:57:43 +02:00
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, edited_message=message))
|
|
|
|
assert check is not None and check is not False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
def test_directed_commands(self, message):
|
|
|
|
handler = CommandHandler('test', self.callback_basic)
|
|
|
|
|
|
|
|
message.text = '/test@{}'.format(message.bot.username)
|
2018-09-21 08:57:43 +02:00
|
|
|
message.entities[0].length = len(message.text)
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is not None and check is not False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
message.text = '/test@otherbot'
|
2018-09-21 08:57:43 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is None or check is False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
def test_with_filter(self, message):
|
|
|
|
handler = CommandHandler('test', self.callback_basic, Filters.group)
|
|
|
|
|
|
|
|
message.chat = Chat(-23, 'group')
|
|
|
|
message.text = '/test'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is not None and check is not False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
message.chat = Chat(23, 'private')
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is None or check is False
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
def test_pass_args(self, dp, message):
|
|
|
|
handler = CommandHandler('test', self.ch_callback_args, pass_args=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test'
|
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
self.test_flag = False
|
|
|
|
message.text = '/test@{}'.format(message.bot.username)
|
2018-09-21 08:57:43 +02:00
|
|
|
message.entities[0].length = len(message.text)
|
2017-08-11 23:58:41 +02:00
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
self.test_flag = False
|
2018-09-21 08:57:43 +02:00
|
|
|
message.text = '/test@{} one two'.format(message.bot.username)
|
2017-08-11 23:58:41 +02:00
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
self.test_flag = False
|
2018-09-21 08:57:43 +02:00
|
|
|
message.text = '/test one two'
|
|
|
|
message.entities[0].length = len('/test')
|
2017-08-11 23:58:41 +02:00
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
2017-10-14 20:04:02 +02:00
|
|
|
def test_newline(self, dp, message):
|
|
|
|
handler = CommandHandler('test', self.callback_basic)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test\nfoobar'
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is not None and check is not False
|
2018-09-21 08:57:43 +02:00
|
|
|
|
2017-10-14 20:04:02 +02:00
|
|
|
dp.process_update(Update(0, message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_pass_user_or_chat_data(self, dp, message):
|
2018-09-21 08:57:01 +02:00
|
|
|
handler = CommandHandler('test', self.callback_data_1,
|
|
|
|
pass_user_data=True)
|
2017-08-11 23:58:41 +02:00
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test'
|
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
dp.remove_handler(handler)
|
2018-09-21 08:57:01 +02:00
|
|
|
handler = CommandHandler('test', self.callback_data_1,
|
|
|
|
pass_chat_data=True)
|
2017-08-11 23:58:41 +02:00
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
self.test_flag = False
|
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
dp.remove_handler(handler)
|
2018-09-21 08:57:01 +02:00
|
|
|
handler = CommandHandler('test', self.callback_data_2,
|
|
|
|
pass_chat_data=True,
|
2017-08-11 23:58:41 +02:00
|
|
|
pass_user_data=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
self.test_flag = False
|
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_pass_job_or_update_queue(self, dp, message):
|
2018-09-21 08:57:01 +02:00
|
|
|
handler = CommandHandler('test', self.callback_queue_1,
|
|
|
|
pass_job_queue=True)
|
2017-08-11 23:58:41 +02:00
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test'
|
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
dp.remove_handler(handler)
|
2018-09-21 08:57:01 +02:00
|
|
|
handler = CommandHandler('test', self.callback_queue_1,
|
|
|
|
pass_update_queue=True)
|
2017-08-11 23:58:41 +02:00
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
self.test_flag = False
|
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
dp.remove_handler(handler)
|
2018-09-21 08:57:01 +02:00
|
|
|
handler = CommandHandler('test', self.callback_queue_2,
|
|
|
|
pass_job_queue=True,
|
2017-08-11 23:58:41 +02:00
|
|
|
pass_update_queue=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
self.test_flag = False
|
|
|
|
dp.process_update(Update(0, message=message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_other_update_types(self, false_update):
|
|
|
|
handler = CommandHandler('test', self.callback_basic)
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(false_update)
|
|
|
|
assert check is None or check is False
|
2018-04-17 06:37:29 +02:00
|
|
|
|
|
|
|
def test_filters_for_wrong_command(self, message):
|
|
|
|
"""Filters should not be executed if the command does not match the handler"""
|
|
|
|
|
|
|
|
class TestFilter(BaseFilter):
|
|
|
|
def __init__(self):
|
|
|
|
self.tested = False
|
|
|
|
|
|
|
|
def filter(self, message):
|
|
|
|
self.tested = True
|
|
|
|
|
|
|
|
test_filter = TestFilter()
|
|
|
|
|
2018-09-21 08:57:43 +02:00
|
|
|
handler = CommandHandler('test', self.callback_basic,
|
2018-09-21 08:57:01 +02:00
|
|
|
filters=test_filter)
|
2018-09-21 08:57:43 +02:00
|
|
|
message.text = '/star'
|
2018-04-17 06:37:29 +02:00
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
check = handler.check_update(Update(0, message=message))
|
|
|
|
assert check is None or check is False
|
2018-04-17 06:37:29 +02:00
|
|
|
|
|
|
|
assert not test_filter.tested
|
2018-09-21 08:57:01 +02:00
|
|
|
|
|
|
|
def test_context(self, cdp, message):
|
|
|
|
handler = CommandHandler('test', self.callback_context)
|
|
|
|
cdp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test'
|
|
|
|
cdp.process_update(Update(0, message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_context_args(self, cdp, message):
|
|
|
|
handler = CommandHandler('test', self.callback_context_args)
|
|
|
|
cdp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test'
|
|
|
|
cdp.process_update(Update(0, message))
|
|
|
|
assert not self.test_flag
|
|
|
|
|
|
|
|
message.text = '/test one two'
|
|
|
|
cdp.process_update(Update(0, message))
|
|
|
|
assert self.test_flag
|
2018-09-21 08:57:43 +02:00
|
|
|
|
2019-02-13 12:07:25 +01:00
|
|
|
def test_context_regex(self, cdp, message):
|
|
|
|
handler = CommandHandler('test', self.callback_context_regex1, Filters.regex('one two'))
|
|
|
|
cdp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test'
|
|
|
|
cdp.process_update(Update(0, message))
|
|
|
|
assert not self.test_flag
|
|
|
|
|
|
|
|
message.text += ' one two'
|
|
|
|
cdp.process_update(Update(0, message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_context_multiple_regex(self, cdp, message):
|
|
|
|
handler = CommandHandler('test', self.callback_context_regex2,
|
|
|
|
Filters.regex('one') & Filters.regex('two'))
|
|
|
|
cdp.add_handler(handler)
|
|
|
|
|
|
|
|
message.text = '/test'
|
|
|
|
cdp.process_update(Update(0, message))
|
|
|
|
assert not self.test_flag
|
|
|
|
|
|
|
|
message.text += ' one two'
|
|
|
|
cdp.process_update(Update(0, message))
|
|
|
|
assert self.test_flag
|
|
|
|
|
2018-09-21 08:57:43 +02:00
|
|
|
|
|
|
|
par = ['!help', '!test', '#help', '#test', 'mytrig-help', 'mytrig-test']
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='function', params=par)
|
|
|
|
def prefixmessage(bot, request):
|
|
|
|
return Message(message_id=1,
|
|
|
|
from_user=User(id=1, first_name='', is_bot=False),
|
|
|
|
date=None,
|
|
|
|
chat=Chat(id=1, type=''),
|
|
|
|
text=request.param,
|
|
|
|
bot=bot)
|
|
|
|
|
|
|
|
|
|
|
|
class TestPrefixHandler(object):
|
|
|
|
test_flag = False
|
2019-02-13 12:07:25 +01:00
|
|
|
SRE_TYPE = type(re.match("", ""))
|
2018-09-21 08:57:43 +02:00
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def reset(self):
|
|
|
|
self.test_flag = False
|
|
|
|
|
|
|
|
def callback_basic(self, bot, update):
|
|
|
|
test_bot = isinstance(bot, Bot)
|
|
|
|
test_update = isinstance(update, Update)
|
|
|
|
self.test_flag = test_bot and test_update
|
|
|
|
|
|
|
|
def callback_data_1(self, bot, update, user_data=None, chat_data=None):
|
|
|
|
self.test_flag = (user_data is not None) or (chat_data is not None)
|
|
|
|
|
|
|
|
def callback_data_2(self, bot, update, user_data=None, chat_data=None):
|
|
|
|
self.test_flag = (user_data is not None) and (chat_data is not None)
|
|
|
|
|
|
|
|
def callback_queue_1(self, bot, update, job_queue=None, update_queue=None):
|
|
|
|
self.test_flag = (job_queue is not None) or (update_queue is not None)
|
|
|
|
|
|
|
|
def callback_queue_2(self, bot, update, job_queue=None, update_queue=None):
|
|
|
|
self.test_flag = (job_queue is not None) and (update_queue is not None)
|
|
|
|
|
|
|
|
def ch_callback_args(self, bot, update, args):
|
|
|
|
if update.message.text in par:
|
|
|
|
self.test_flag = len(args) == 0
|
|
|
|
else:
|
|
|
|
self.test_flag = args == ['one', 'two']
|
|
|
|
|
|
|
|
def callback_context(self, update, context):
|
2019-02-08 20:55:40 +01:00
|
|
|
self.test_flag = (isinstance(context, CallbackContext)
|
|
|
|
and isinstance(context.bot, Bot)
|
|
|
|
and isinstance(update, Update)
|
|
|
|
and isinstance(context.update_queue, Queue)
|
|
|
|
and isinstance(context.job_queue, JobQueue)
|
|
|
|
and isinstance(context.user_data, dict)
|
|
|
|
and isinstance(context.chat_data, dict)
|
|
|
|
and isinstance(update.message, Message))
|
2018-09-21 08:57:43 +02:00
|
|
|
|
|
|
|
def callback_context_args(self, update, context):
|
|
|
|
self.test_flag = context.args == ['one', 'two']
|
|
|
|
|
2019-02-13 12:07:25 +01:00
|
|
|
def callback_context_regex1(self, update, context):
|
|
|
|
if context.matches:
|
|
|
|
types = all([type(res) == self.SRE_TYPE for res in context.matches])
|
|
|
|
num = len(context.matches) == 1
|
|
|
|
self.test_flag = types and num
|
|
|
|
|
|
|
|
def callback_context_regex2(self, update, context):
|
|
|
|
if context.matches:
|
|
|
|
types = all([type(res) == self.SRE_TYPE for res in context.matches])
|
|
|
|
num = len(context.matches) == 2
|
|
|
|
self.test_flag = types and num
|
|
|
|
|
2018-09-21 08:57:43 +02:00
|
|
|
def test_basic(self, dp, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_basic)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
dp.process_update(Update(0, prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
prefixmessage.text = 'test'
|
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
prefixmessage.text = '#nocom'
|
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
message.text = 'not !test at start'
|
|
|
|
check = handler.check_update(Update(0, message))
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
def test_single_prefix_single_command(self, prefixmessage):
|
|
|
|
handler = PrefixHandler('!', 'test', self.callback_basic)
|
|
|
|
|
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
if prefixmessage.text in ['!test']:
|
|
|
|
assert check is not None and check is not False
|
|
|
|
else:
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
def test_single_prefix_multi_command(self, prefixmessage):
|
|
|
|
handler = PrefixHandler('!', ['test', 'help'], self.callback_basic)
|
|
|
|
|
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
if prefixmessage.text in ['!test', '!help']:
|
|
|
|
assert check is not None and check is not False
|
|
|
|
else:
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
def test_multi_prefix_single_command(self, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#'], 'test', self.callback_basic)
|
|
|
|
|
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
if prefixmessage.text in ['!test', '#test']:
|
|
|
|
assert check is not None and check is not False
|
|
|
|
else:
|
|
|
|
assert check is None or check is False
|
|
|
|
|
2019-02-13 12:07:25 +01:00
|
|
|
def test_no_edited(self, prefixmessage):
|
2018-09-21 08:57:43 +02:00
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_basic)
|
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
assert check is not None and check is not False
|
|
|
|
|
|
|
|
check = handler.check_update(Update(0, edited_message=prefixmessage))
|
2019-02-13 12:07:25 +01:00
|
|
|
assert check is not None and check is not False
|
2018-09-21 08:57:43 +02:00
|
|
|
|
2019-02-13 12:07:25 +01:00
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_basic,
|
|
|
|
filters=~Filters.update.edited_message)
|
2018-09-21 08:57:43 +02:00
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
assert check is not None and check is not False
|
|
|
|
|
|
|
|
check = handler.check_update(Update(0, edited_message=prefixmessage))
|
2019-02-13 12:07:25 +01:00
|
|
|
assert check is None or check is False
|
2018-09-21 08:57:43 +02:00
|
|
|
|
|
|
|
def test_with_filter(self, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_basic,
|
|
|
|
filters=Filters.group)
|
|
|
|
|
|
|
|
prefixmessage.chat = Chat(-23, 'group')
|
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
assert check is not None and check is not False
|
|
|
|
|
|
|
|
prefixmessage.chat = Chat(23, 'private')
|
|
|
|
check = handler.check_update(Update(0, prefixmessage))
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
def test_pass_args(self, dp, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.ch_callback_args,
|
|
|
|
pass_args=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
dp.process_update(Update(0, message=prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
self.test_flag = False
|
|
|
|
prefixmessage.text += ' one two'
|
|
|
|
dp.process_update(Update(0, message=prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_pass_user_or_chat_data(self, dp, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_data_1,
|
|
|
|
pass_user_data=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
dp.process_update(Update(0, message=prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
dp.remove_handler(handler)
|
|
|
|
self.test_flag = False
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_data_1,
|
|
|
|
pass_chat_data=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
dp.process_update(Update(0, message=prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
dp.remove_handler(handler)
|
|
|
|
self.test_flag = False
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_data_2,
|
|
|
|
pass_chat_data=True, pass_user_data=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
dp.process_update(Update(0, message=prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_pass_job_or_update_queue(self, dp, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_queue_1,
|
|
|
|
pass_job_queue=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
|
|
|
|
dp.process_update(Update(0, message=prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
dp.remove_handler(handler)
|
|
|
|
self.test_flag = False
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_queue_1,
|
|
|
|
pass_update_queue=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
dp.process_update(Update(0, message=prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
dp.remove_handler(handler)
|
|
|
|
self.test_flag = False
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_queue_2,
|
|
|
|
pass_job_queue=True, pass_update_queue=True)
|
|
|
|
dp.add_handler(handler)
|
|
|
|
dp.process_update(Update(0, message=prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_other_update_types(self, false_update):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_basic)
|
|
|
|
check = handler.check_update(false_update)
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
def test_filters_for_wrong_command(self, prefixmessage):
|
|
|
|
"""Filters should not be executed if the command does not match the handler"""
|
|
|
|
|
|
|
|
class TestFilter(BaseFilter):
|
|
|
|
def __init__(self):
|
|
|
|
self.tested = False
|
|
|
|
|
|
|
|
def filter(self, message):
|
|
|
|
self.tested = True
|
|
|
|
|
|
|
|
test_filter = TestFilter()
|
|
|
|
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_basic,
|
|
|
|
filters=test_filter)
|
|
|
|
|
|
|
|
prefixmessage.text = '/star'
|
|
|
|
|
|
|
|
check = handler.check_update(Update(0, message=prefixmessage))
|
|
|
|
assert check is None or check is False
|
|
|
|
|
|
|
|
assert not test_filter.tested
|
|
|
|
|
|
|
|
def test_context(self, cdp, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'], self.callback_context)
|
|
|
|
cdp.add_handler(handler)
|
|
|
|
|
|
|
|
cdp.process_update(Update(0, prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_context_args(self, cdp, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'],
|
|
|
|
self.callback_context_args)
|
|
|
|
cdp.add_handler(handler)
|
|
|
|
|
|
|
|
cdp.process_update(Update(0, prefixmessage))
|
|
|
|
assert not self.test_flag
|
|
|
|
|
|
|
|
prefixmessage.text += ' one two'
|
|
|
|
cdp.process_update(Update(0, prefixmessage))
|
|
|
|
assert self.test_flag
|
2019-02-13 12:07:25 +01:00
|
|
|
|
|
|
|
def test_context_regex(self, cdp, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'],
|
|
|
|
self.callback_context_regex1, Filters.regex('one two'))
|
|
|
|
cdp.add_handler(handler)
|
|
|
|
|
|
|
|
cdp.process_update(Update(0, prefixmessage))
|
|
|
|
assert not self.test_flag
|
|
|
|
|
|
|
|
prefixmessage.text += ' one two'
|
|
|
|
cdp.process_update(Update(0, prefixmessage))
|
|
|
|
assert self.test_flag
|
|
|
|
|
|
|
|
def test_context_multiple_regex(self, cdp, prefixmessage):
|
|
|
|
handler = PrefixHandler(['!', '#', 'mytrig-'], ['help', 'test'],
|
|
|
|
self.callback_context_regex2,
|
|
|
|
Filters.regex('one') & Filters.regex('two'))
|
|
|
|
cdp.add_handler(handler)
|
|
|
|
|
|
|
|
cdp.process_update(Update(0, prefixmessage))
|
|
|
|
assert not self.test_flag
|
|
|
|
|
|
|
|
prefixmessage.text += ' one two'
|
|
|
|
cdp.process_update(Update(0, prefixmessage))
|
|
|
|
assert self.test_flag
|