2021-09-22 16:49:10 +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
|
2021-09-22 16:49:10 +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/].
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
from telegram import User
|
2021-10-10 15:10:21 +02:00
|
|
|
from telegram._utils.defaultvalue import DefaultValue
|
2023-02-22 20:19:46 +01:00
|
|
|
from tests.auxil.slots import mro_slots
|
2021-09-22 16:49:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
class TestDefaultValue:
|
2023-02-22 20:19:46 +01:00
|
|
|
def test_slot_behaviour(self):
|
2021-09-22 16:49:10 +02:00
|
|
|
inst = DefaultValue(1)
|
|
|
|
for attr in inst.__slots__:
|
2022-05-05 17:40:22 +02:00
|
|
|
assert getattr(inst, attr, "err") != "err", f"got extra slot '{attr}'"
|
2021-09-22 16:49:10 +02:00
|
|
|
assert len(mro_slots(inst)) == len(set(mro_slots(inst))), "duplicate slot"
|
|
|
|
|
|
|
|
def test_identity(self):
|
|
|
|
df_1 = DefaultValue(1)
|
|
|
|
df_2 = DefaultValue(2)
|
|
|
|
assert df_1 is not df_2
|
|
|
|
assert df_1 != df_2
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
2023-03-25 19:18:04 +01:00
|
|
|
("value", "expected"),
|
2021-09-22 16:49:10 +02:00
|
|
|
[
|
|
|
|
({}, False),
|
|
|
|
({1: 2}, True),
|
|
|
|
(None, False),
|
|
|
|
(True, True),
|
|
|
|
(1, True),
|
|
|
|
(0, False),
|
|
|
|
(False, False),
|
|
|
|
([], False),
|
|
|
|
([1], True),
|
|
|
|
],
|
|
|
|
)
|
|
|
|
def test_truthiness(self, value, expected):
|
|
|
|
assert bool(DefaultValue(value)) == expected
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
2022-05-05 17:40:22 +02:00
|
|
|
"value", ["string", 1, True, [1, 2, 3], {1: 3}, DefaultValue(1), User(1, "first", False)]
|
2021-09-22 16:49:10 +02:00
|
|
|
)
|
|
|
|
def test_string_representations(self, value):
|
|
|
|
df = DefaultValue(value)
|
2022-05-05 17:40:22 +02:00
|
|
|
assert str(df) == f"DefaultValue({value})"
|
2021-09-22 16:49:10 +02:00
|
|
|
assert repr(df) == repr(value)
|
|
|
|
|
|
|
|
def test_as_function_argument(self):
|
|
|
|
default_one = DefaultValue(1)
|
|
|
|
|
|
|
|
def foo(arg=default_one):
|
|
|
|
if arg is default_one:
|
|
|
|
return 1
|
2023-03-25 19:18:04 +01:00
|
|
|
return 2
|
2021-09-22 16:49:10 +02:00
|
|
|
|
|
|
|
assert foo() == 1
|
|
|
|
assert foo(None) == 2
|
|
|
|
assert foo(1) == 2
|