2017-05-20 17:30:50 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#
|
|
|
|
# A library that provides a Python interface to the Telegram Bot API
|
2023-01-01 21:31:29 +01:00
|
|
|
# Copyright (C) 2015-2023
|
2017-05-20 17:30:50 +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
|
2017-05-20 17:30:50 +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.
|
2017-05-20 17:30:50 +02:00
|
|
|
#
|
2017-08-11 23:58:41 +02:00
|
|
|
# You should have received a copy of the GNU Lesser Public License
|
2017-05-20 17:30:50 +02:00
|
|
|
# along with this program. If not, see [http://www.gnu.org/licenses/].
|
2017-08-11 23:58:41 +02:00
|
|
|
import pytest
|
2017-05-20 18:51:31 +02:00
|
|
|
|
2022-05-05 12:57:54 +05:30
|
|
|
from telegram import Invoice, LabeledPrice
|
2020-11-29 16:20:46 +01:00
|
|
|
from telegram.error import BadRequest
|
2022-04-24 12:38:09 +02:00
|
|
|
from telegram.request import RequestData
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
|
2022-05-05 17:40:22 +02:00
|
|
|
@pytest.fixture(scope="class")
|
2017-08-11 23:58:41 +02:00
|
|
|
def invoice():
|
2020-10-09 17:22:07 +02:00
|
|
|
return Invoice(
|
|
|
|
TestInvoice.title,
|
|
|
|
TestInvoice.description,
|
|
|
|
TestInvoice.start_parameter,
|
|
|
|
TestInvoice.currency,
|
|
|
|
TestInvoice.total_amount,
|
|
|
|
)
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
|
2020-06-15 18:20:51 +02:00
|
|
|
class TestInvoice:
|
2022-05-05 17:40:22 +02:00
|
|
|
payload = "payload"
|
|
|
|
prices = [LabeledPrice("Fish", 100), LabeledPrice("Fish Tax", 1000)]
|
2017-12-08 22:38:59 +01:00
|
|
|
provider_data = """{"test":"test"}"""
|
2022-05-05 17:40:22 +02:00
|
|
|
title = "title"
|
|
|
|
description = "description"
|
|
|
|
start_parameter = "start_parameter"
|
|
|
|
currency = "EUR"
|
2021-06-06 11:48:48 +02:00
|
|
|
total_amount = sum(p.amount for p in prices)
|
2021-04-30 10:09:21 +02:00
|
|
|
max_tip_amount = 42
|
|
|
|
suggested_tip_amounts = [13, 42]
|
2017-08-11 23:58:41 +02:00
|
|
|
|
2021-08-20 01:31:10 +05:30
|
|
|
def test_slot_behaviour(self, invoice, mro_slots):
|
2021-05-29 19:48:16 +05:30
|
|
|
for attr in invoice.__slots__:
|
2022-05-05 17:40:22 +02:00
|
|
|
assert getattr(invoice, attr, "err") != "err", f"got extra slot '{attr}'"
|
2021-05-29 19:48:16 +05:30
|
|
|
assert len(mro_slots(invoice)) == len(set(mro_slots(invoice))), "duplicate slot"
|
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
def test_de_json(self, bot):
|
2020-10-09 17:22:07 +02:00
|
|
|
invoice_json = Invoice.de_json(
|
|
|
|
{
|
2022-05-05 17:40:22 +02:00
|
|
|
"title": TestInvoice.title,
|
|
|
|
"description": TestInvoice.description,
|
|
|
|
"start_parameter": TestInvoice.start_parameter,
|
|
|
|
"currency": TestInvoice.currency,
|
|
|
|
"total_amount": TestInvoice.total_amount,
|
2020-10-09 17:22:07 +02:00
|
|
|
},
|
|
|
|
bot,
|
|
|
|
)
|
2022-10-07 11:51:53 +02:00
|
|
|
assert invoice_json.api_kwargs == {}
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
assert invoice_json.title == self.title
|
|
|
|
assert invoice_json.description == self.description
|
|
|
|
assert invoice_json.start_parameter == self.start_parameter
|
|
|
|
assert invoice_json.currency == self.currency
|
|
|
|
assert invoice_json.total_amount == self.total_amount
|
|
|
|
|
|
|
|
def test_to_dict(self, invoice):
|
|
|
|
invoice_dict = invoice.to_dict()
|
|
|
|
|
|
|
|
assert isinstance(invoice_dict, dict)
|
2022-05-05 17:40:22 +02:00
|
|
|
assert invoice_dict["title"] == invoice.title
|
|
|
|
assert invoice_dict["description"] == invoice.description
|
|
|
|
assert invoice_dict["start_parameter"] == invoice.start_parameter
|
|
|
|
assert invoice_dict["currency"] == invoice.currency
|
|
|
|
assert invoice_dict["total_amount"] == invoice.total_amount
|
2017-05-20 17:30:50 +02:00
|
|
|
|
2022-11-10 01:13:27 +05:30
|
|
|
@pytest.mark.flaky(3, 1)
|
2022-04-24 12:38:09 +02:00
|
|
|
async def test_send_required_args_only(self, bot, chat_id, provider_token):
|
|
|
|
message = await bot.send_invoice(
|
2021-04-30 10:09:21 +02:00
|
|
|
chat_id=chat_id,
|
|
|
|
title=self.title,
|
|
|
|
description=self.description,
|
|
|
|
payload=self.payload,
|
|
|
|
provider_token=provider_token,
|
|
|
|
currency=self.currency,
|
|
|
|
prices=self.prices,
|
2020-10-09 17:22:07 +02:00
|
|
|
)
|
2017-08-11 23:58:41 +02:00
|
|
|
|
|
|
|
assert message.invoice.currency == self.currency
|
2022-05-05 17:40:22 +02:00
|
|
|
assert message.invoice.start_parameter == ""
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.invoice.description == self.description
|
|
|
|
assert message.invoice.title == self.title
|
|
|
|
assert message.invoice.total_amount == self.total_amount
|
2017-05-20 18:51:31 +02:00
|
|
|
|
2022-06-27 18:54:11 +02:00
|
|
|
link = await bot.create_invoice_link(
|
|
|
|
title=self.title,
|
|
|
|
description=self.description,
|
|
|
|
payload=self.payload,
|
|
|
|
provider_token=provider_token,
|
|
|
|
currency=self.currency,
|
|
|
|
prices=self.prices,
|
|
|
|
)
|
|
|
|
assert isinstance(link, str)
|
|
|
|
assert link != ""
|
|
|
|
|
|
|
|
async def test_send_all_args_send_invoice(self, bot, chat_id, provider_token, monkeypatch):
|
2022-04-24 12:38:09 +02:00
|
|
|
message = await bot.send_invoice(
|
2017-08-11 23:58:41 +02:00
|
|
|
chat_id,
|
2017-05-20 18:51:31 +02:00
|
|
|
self.title,
|
|
|
|
self.description,
|
|
|
|
self.payload,
|
2017-08-11 23:58:41 +02:00
|
|
|
provider_token,
|
2017-05-20 18:51:31 +02:00
|
|
|
self.currency,
|
|
|
|
self.prices,
|
2021-04-30 10:09:21 +02:00
|
|
|
max_tip_amount=self.max_tip_amount,
|
|
|
|
suggested_tip_amounts=self.suggested_tip_amounts,
|
|
|
|
start_parameter=self.start_parameter,
|
2017-12-08 22:38:59 +01:00
|
|
|
provider_data=self.provider_data,
|
2022-05-05 17:40:22 +02:00
|
|
|
photo_url="https://raw.githubusercontent.com/"
|
|
|
|
"python-telegram-bot/logos/master/"
|
|
|
|
"logo/png/ptb-logo_240.png",
|
2017-05-20 18:51:31 +02:00
|
|
|
photo_size=240,
|
|
|
|
photo_width=240,
|
|
|
|
photo_height=240,
|
|
|
|
need_name=True,
|
|
|
|
need_phone_number=True,
|
2017-08-11 23:58:41 +02:00
|
|
|
need_email=True,
|
2017-05-20 18:51:31 +02:00
|
|
|
need_shipping_address=True,
|
2018-02-10 16:54:09 +01:00
|
|
|
send_phone_number_to_provider=True,
|
|
|
|
send_email_to_provider=True,
|
2020-10-09 17:22:07 +02:00
|
|
|
is_flexible=True,
|
2022-01-03 11:13:33 +04:00
|
|
|
disable_notification=True,
|
|
|
|
protect_content=True,
|
2020-10-09 17:22:07 +02:00
|
|
|
)
|
2017-05-20 17:30:50 +02:00
|
|
|
|
2017-08-11 23:58:41 +02:00
|
|
|
assert message.invoice.currency == self.currency
|
|
|
|
assert message.invoice.start_parameter == self.start_parameter
|
|
|
|
assert message.invoice.description == self.description
|
|
|
|
assert message.invoice.title == self.title
|
|
|
|
assert message.invoice.total_amount == self.total_amount
|
2022-01-03 11:13:33 +04:00
|
|
|
assert message.has_protected_content
|
2017-12-08 22:38:59 +01:00
|
|
|
|
2021-05-16 21:56:28 +03:00
|
|
|
# We do this next one as safety guard to make sure that we pass all of the optional
|
|
|
|
# parameters correctly because #2526 went unnoticed for 3 years …
|
2022-04-24 12:38:09 +02:00
|
|
|
async def make_assertion(*args, **_):
|
2021-05-16 21:56:28 +03:00
|
|
|
kwargs = args[1]
|
|
|
|
return (
|
2022-05-05 17:40:22 +02:00
|
|
|
kwargs["chat_id"] == "chat_id"
|
|
|
|
and kwargs["title"] == "title"
|
|
|
|
and kwargs["description"] == "description"
|
|
|
|
and kwargs["payload"] == "payload"
|
|
|
|
and kwargs["provider_token"] == "provider_token"
|
|
|
|
and kwargs["currency"] == "currency"
|
|
|
|
and kwargs["prices"] == self.prices
|
|
|
|
and kwargs["max_tip_amount"] == "max_tip_amount"
|
|
|
|
and kwargs["suggested_tip_amounts"] == "suggested_tip_amounts"
|
|
|
|
and kwargs["start_parameter"] == "start_parameter"
|
|
|
|
and kwargs["provider_data"] == "provider_data"
|
|
|
|
and kwargs["photo_url"] == "photo_url"
|
|
|
|
and kwargs["photo_size"] == "photo_size"
|
|
|
|
and kwargs["photo_width"] == "photo_width"
|
|
|
|
and kwargs["photo_height"] == "photo_height"
|
|
|
|
and kwargs["need_name"] == "need_name"
|
|
|
|
and kwargs["need_phone_number"] == "need_phone_number"
|
|
|
|
and kwargs["need_email"] == "need_email"
|
|
|
|
and kwargs["need_shipping_address"] == "need_shipping_address"
|
|
|
|
and kwargs["send_phone_number_to_provider"] == "send_phone_number_to_provider"
|
|
|
|
and kwargs["send_email_to_provider"] == "send_email_to_provider"
|
|
|
|
and kwargs["is_flexible"] == "is_flexible"
|
2021-05-16 21:56:28 +03:00
|
|
|
)
|
|
|
|
|
2022-05-05 17:40:22 +02:00
|
|
|
monkeypatch.setattr(bot, "_send_message", make_assertion)
|
2022-04-24 12:38:09 +02:00
|
|
|
assert await bot.send_invoice(
|
2022-05-05 17:40:22 +02:00
|
|
|
chat_id="chat_id",
|
|
|
|
title="title",
|
|
|
|
description="description",
|
|
|
|
payload="payload",
|
|
|
|
provider_token="provider_token",
|
|
|
|
currency="currency",
|
2021-05-16 21:56:28 +03:00
|
|
|
prices=self.prices,
|
2022-05-05 17:40:22 +02:00
|
|
|
max_tip_amount="max_tip_amount",
|
|
|
|
suggested_tip_amounts="suggested_tip_amounts",
|
|
|
|
start_parameter="start_parameter",
|
|
|
|
provider_data="provider_data",
|
|
|
|
photo_url="photo_url",
|
|
|
|
photo_size="photo_size",
|
|
|
|
photo_width="photo_width",
|
|
|
|
photo_height="photo_height",
|
|
|
|
need_name="need_name",
|
|
|
|
need_phone_number="need_phone_number",
|
|
|
|
need_email="need_email",
|
|
|
|
need_shipping_address="need_shipping_address",
|
|
|
|
send_phone_number_to_provider="send_phone_number_to_provider",
|
|
|
|
send_email_to_provider="send_email_to_provider",
|
|
|
|
is_flexible="is_flexible",
|
2022-01-03 11:13:33 +04:00
|
|
|
disable_notification=True,
|
|
|
|
protect_content=True,
|
2021-05-16 21:56:28 +03:00
|
|
|
)
|
|
|
|
|
2022-06-27 18:54:11 +02:00
|
|
|
async def test_send_all_args_create_invoice_link(
|
|
|
|
self, bot, chat_id, provider_token, monkeypatch
|
|
|
|
):
|
|
|
|
async def make_assertion(*args, **_):
|
|
|
|
kwargs = args[1]
|
|
|
|
return (
|
|
|
|
kwargs["title"] == "title"
|
|
|
|
and kwargs["description"] == "description"
|
|
|
|
and kwargs["payload"] == "payload"
|
|
|
|
and kwargs["provider_token"] == "provider_token"
|
|
|
|
and kwargs["currency"] == "currency"
|
|
|
|
and kwargs["prices"] == self.prices
|
|
|
|
and kwargs["max_tip_amount"] == "max_tip_amount"
|
|
|
|
and kwargs["suggested_tip_amounts"] == "suggested_tip_amounts"
|
|
|
|
and kwargs["provider_data"] == "provider_data"
|
|
|
|
and kwargs["photo_url"] == "photo_url"
|
|
|
|
and kwargs["photo_size"] == "photo_size"
|
|
|
|
and kwargs["photo_width"] == "photo_width"
|
|
|
|
and kwargs["photo_height"] == "photo_height"
|
|
|
|
and kwargs["need_name"] == "need_name"
|
|
|
|
and kwargs["need_phone_number"] == "need_phone_number"
|
|
|
|
and kwargs["need_email"] == "need_email"
|
|
|
|
and kwargs["need_shipping_address"] == "need_shipping_address"
|
|
|
|
and kwargs["send_phone_number_to_provider"] == "send_phone_number_to_provider"
|
|
|
|
and kwargs["send_email_to_provider"] == "send_email_to_provider"
|
|
|
|
and kwargs["is_flexible"] == "is_flexible"
|
|
|
|
)
|
|
|
|
|
|
|
|
monkeypatch.setattr(bot, "_post", make_assertion)
|
|
|
|
assert await bot.create_invoice_link(
|
|
|
|
title="title",
|
|
|
|
description="description",
|
|
|
|
payload="payload",
|
|
|
|
provider_token="provider_token",
|
|
|
|
currency="currency",
|
|
|
|
prices=self.prices,
|
|
|
|
max_tip_amount="max_tip_amount",
|
|
|
|
suggested_tip_amounts="suggested_tip_amounts",
|
|
|
|
provider_data="provider_data",
|
|
|
|
photo_url="photo_url",
|
|
|
|
photo_size="photo_size",
|
|
|
|
photo_width="photo_width",
|
|
|
|
photo_height="photo_height",
|
|
|
|
need_name="need_name",
|
|
|
|
need_phone_number="need_phone_number",
|
|
|
|
need_email="need_email",
|
|
|
|
need_shipping_address="need_shipping_address",
|
|
|
|
send_phone_number_to_provider="send_phone_number_to_provider",
|
|
|
|
send_email_to_provider="send_email_to_provider",
|
|
|
|
is_flexible="is_flexible",
|
|
|
|
)
|
|
|
|
|
2022-04-24 12:38:09 +02:00
|
|
|
async def test_send_object_as_provider_data(self, monkeypatch, bot, chat_id, provider_token):
|
|
|
|
async def make_assertion(url, request_data: RequestData, *args, **kwargs):
|
2022-05-19 12:47:53 +02:00
|
|
|
return request_data.json_parameters["provider_data"] == '{"test_data": 123456789}'
|
2017-12-08 22:38:59 +01:00
|
|
|
|
2022-05-05 17:40:22 +02:00
|
|
|
monkeypatch.setattr(bot.request, "post", make_assertion)
|
2017-12-08 22:38:59 +01:00
|
|
|
|
2022-04-24 12:38:09 +02:00
|
|
|
assert await bot.send_invoice(
|
2020-10-09 17:22:07 +02:00
|
|
|
chat_id,
|
|
|
|
self.title,
|
|
|
|
self.description,
|
|
|
|
self.payload,
|
|
|
|
provider_token,
|
|
|
|
self.currency,
|
|
|
|
self.prices,
|
2022-05-05 17:40:22 +02:00
|
|
|
provider_data={"test_data": 123456789},
|
2021-04-30 10:09:21 +02:00
|
|
|
start_parameter=self.start_parameter,
|
2020-10-09 17:22:07 +02:00
|
|
|
)
|
2020-07-14 21:33:56 +02:00
|
|
|
|
2022-11-10 01:13:27 +05:30
|
|
|
@pytest.mark.flaky(3, 1)
|
2020-11-29 16:20:46 +01:00
|
|
|
@pytest.mark.parametrize(
|
2022-05-05 17:40:22 +02:00
|
|
|
"default_bot,custom",
|
2020-11-29 16:20:46 +01:00
|
|
|
[
|
2022-05-05 17:40:22 +02:00
|
|
|
({"allow_sending_without_reply": True}, None),
|
|
|
|
({"allow_sending_without_reply": False}, None),
|
|
|
|
({"allow_sending_without_reply": False}, True),
|
2020-11-29 16:20:46 +01:00
|
|
|
],
|
2022-05-05 17:40:22 +02:00
|
|
|
indirect=["default_bot"],
|
2020-11-29 16:20:46 +01:00
|
|
|
)
|
2022-04-24 12:38:09 +02:00
|
|
|
async def test_send_invoice_default_allow_sending_without_reply(
|
2020-11-29 16:20:46 +01:00
|
|
|
self, default_bot, chat_id, custom, provider_token
|
|
|
|
):
|
2022-05-05 17:40:22 +02:00
|
|
|
reply_to_message = await default_bot.send_message(chat_id, "test")
|
2022-04-24 12:38:09 +02:00
|
|
|
await reply_to_message.delete()
|
2020-11-29 16:20:46 +01:00
|
|
|
if custom is not None:
|
2022-04-24 12:38:09 +02:00
|
|
|
message = await default_bot.send_invoice(
|
2020-11-29 16:20:46 +01:00
|
|
|
chat_id,
|
|
|
|
self.title,
|
|
|
|
self.description,
|
|
|
|
self.payload,
|
|
|
|
provider_token,
|
|
|
|
self.currency,
|
|
|
|
self.prices,
|
|
|
|
allow_sending_without_reply=custom,
|
|
|
|
reply_to_message_id=reply_to_message.message_id,
|
|
|
|
)
|
|
|
|
assert message.reply_to_message is None
|
|
|
|
elif default_bot.defaults.allow_sending_without_reply:
|
2022-04-24 12:38:09 +02:00
|
|
|
message = await default_bot.send_invoice(
|
2020-11-29 16:20:46 +01:00
|
|
|
chat_id,
|
|
|
|
self.title,
|
|
|
|
self.description,
|
|
|
|
self.payload,
|
|
|
|
provider_token,
|
|
|
|
self.currency,
|
|
|
|
self.prices,
|
|
|
|
reply_to_message_id=reply_to_message.message_id,
|
|
|
|
)
|
|
|
|
assert message.reply_to_message is None
|
|
|
|
else:
|
2022-05-05 17:40:22 +02:00
|
|
|
with pytest.raises(BadRequest, match="message not found"):
|
2022-04-24 12:38:09 +02:00
|
|
|
await default_bot.send_invoice(
|
2020-11-29 16:20:46 +01:00
|
|
|
chat_id,
|
|
|
|
self.title,
|
|
|
|
self.description,
|
|
|
|
self.payload,
|
|
|
|
provider_token,
|
|
|
|
self.currency,
|
|
|
|
self.prices,
|
|
|
|
reply_to_message_id=reply_to_message.message_id,
|
|
|
|
)
|
|
|
|
|
2022-11-10 01:13:27 +05:30
|
|
|
@pytest.mark.flaky(3, 1)
|
2022-05-05 17:40:22 +02:00
|
|
|
@pytest.mark.parametrize("default_bot", [{"protect_content": True}], indirect=True)
|
2022-04-24 12:38:09 +02:00
|
|
|
async def test_send_invoice_default_protect_content(
|
|
|
|
self, chat_id, default_bot, provider_token
|
|
|
|
):
|
|
|
|
protected = await default_bot.send_invoice(
|
2022-01-07 20:02:23 +04:00
|
|
|
chat_id,
|
|
|
|
self.title,
|
|
|
|
self.description,
|
|
|
|
self.payload,
|
|
|
|
provider_token,
|
|
|
|
self.currency,
|
|
|
|
self.prices,
|
|
|
|
)
|
|
|
|
assert protected.has_protected_content
|
2022-04-24 12:38:09 +02:00
|
|
|
unprotected = await default_bot.send_invoice(
|
2022-01-07 20:02:23 +04:00
|
|
|
chat_id,
|
|
|
|
self.title,
|
|
|
|
self.description,
|
|
|
|
self.payload,
|
|
|
|
provider_token,
|
|
|
|
self.currency,
|
|
|
|
self.prices,
|
|
|
|
protect_content=False,
|
|
|
|
)
|
|
|
|
assert not unprotected.has_protected_content
|
|
|
|
|
2020-07-14 21:33:56 +02:00
|
|
|
def test_equality(self):
|
2022-05-05 17:40:22 +02:00
|
|
|
a = Invoice("invoice", "desc", "start", "EUR", 7)
|
|
|
|
b = Invoice("invoice", "desc", "start", "EUR", 7)
|
|
|
|
c = Invoice("invoices", "description", "stop", "USD", 8)
|
|
|
|
d = LabeledPrice("label", 5)
|
2020-07-14 21:33:56 +02:00
|
|
|
|
|
|
|
assert a == b
|
|
|
|
assert hash(a) == hash(b)
|
|
|
|
|
|
|
|
assert a != c
|
|
|
|
assert hash(a) != hash(c)
|
|
|
|
|
|
|
|
assert a != d
|
|
|
|
assert hash(a) != hash(d)
|