python-telegram-bot/tests/test_inlinequery.py

105 lines
3.6 KiB
Python
Raw Normal View History

2016-02-07 23:34:15 +01:00
#!/usr/bin/env python
#
# A library that provides a Python interface to the Telegram Bot API
2020-02-02 23:08:54 +02:00
# Copyright (C) 2015-2020
2016-02-07 23:34:15 +01: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
2016-02-07 23:34:15 +01: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
# GNU Lesser Public License for more details.
2016-02-07 23:34:15 +01:00
#
# You should have received a copy of the GNU Lesser Public License
2016-02-07 23:34:15 +01:00
# along with this program. If not, see [http://www.gnu.org/licenses/].
import pytest
from telegram import User, Location, InlineQuery, Update
2016-02-07 23:34:15 +01:00
@pytest.fixture(scope='class')
def inline_query(bot):
return InlineQuery(
TestInlineQuery.id_,
TestInlineQuery.from_user,
TestInlineQuery.query,
TestInlineQuery.offset,
location=TestInlineQuery.location,
bot=bot,
)
2016-02-07 23:34:15 +01:00
class TestInlineQuery:
id_ = 1234
from_user = User(1, 'First name', False)
query = 'query text'
offset = 'offset'
location = Location(8.8, 53.1)
2016-02-07 23:34:15 +01:00
def test_de_json(self, bot):
json_dict = {
'id': self.id_,
2016-02-07 23:34:15 +01:00
'from': self.from_user.to_dict(),
'query': self.query,
2016-05-01 20:08:34 +02:00
'offset': self.offset,
'location': self.location.to_dict(),
2016-02-07 23:34:15 +01:00
}
inline_query_json = InlineQuery.de_json(json_dict, bot)
2016-02-07 23:34:15 +01:00
assert inline_query_json.id == self.id_
assert inline_query_json.from_user == self.from_user
assert inline_query_json.location == self.location
assert inline_query_json.query == self.query
assert inline_query_json.offset == self.offset
2016-02-07 23:34:15 +01:00
def test_to_dict(self, inline_query):
inline_query_dict = inline_query.to_dict()
2016-02-07 23:34:15 +01:00
assert isinstance(inline_query_dict, dict)
assert inline_query_dict['id'] == inline_query.id
assert inline_query_dict['from'] == inline_query.from_user.to_dict()
assert inline_query_dict['location'] == inline_query.location.to_dict()
assert inline_query_dict['query'] == inline_query.query
assert inline_query_dict['offset'] == inline_query.offset
2016-02-07 23:34:15 +01:00
def test_answer(self, monkeypatch, inline_query):
def test(*args, **kwargs):
return args[0] == inline_query.id
2016-02-07 23:34:15 +01:00
monkeypatch.setattr(inline_query.bot, 'answer_inline_query', test)
assert inline_query.answer()
2016-02-07 23:34:15 +01:00
def test_answer_auto_pagination(self, monkeypatch, inline_query):
def make_assertion(*args, **kwargs):
inline_query_id_matches = args[0] == inline_query.id
offset_matches = kwargs.get('current_offset') == inline_query.offset
return offset_matches and inline_query_id_matches
monkeypatch.setattr(inline_query.bot, 'answer_inline_query', make_assertion)
assert inline_query.answer(auto_pagination=True)
def test_equality(self):
a = InlineQuery(self.id_, User(1, '', False), '', '')
b = InlineQuery(self.id_, User(1, '', False), '', '')
c = InlineQuery(self.id_, User(0, '', False), '', '')
d = InlineQuery(0, User(1, '', False), '', '')
e = Update(self.id_)
assert a == b
assert hash(a) == hash(b)
assert a is not b
assert a == c
assert hash(a) == hash(c)
assert a != d
assert hash(a) != hash(d)
2016-02-07 23:34:15 +01:00
assert a != e
assert hash(a) != hash(e)