mirror of
https://github.com/aiogram/aiogram.git
synced 2026-04-08 16:37:47 +00:00
Merge branch 'dev-3.x' into scenes
# Conflicts: # aiogram/__init__.py
This commit is contained in:
commit
09d0244a79
3 changed files with 55 additions and 2 deletions
|
|
@ -1,7 +1,8 @@
|
|||
import sys
|
||||
from decimal import Decimal
|
||||
from enum import Enum, auto
|
||||
from fractions import Fraction
|
||||
from typing import Optional
|
||||
from typing import Optional, Union
|
||||
from uuid import UUID
|
||||
|
||||
import pytest
|
||||
|
|
@ -147,6 +148,32 @@ class TestCallbackData:
|
|||
assert MyCallback3.unpack("test3:experiment:42") == MyCallback3(bar=42)
|
||||
assert MyCallback3.unpack("test3:spam:42") == MyCallback3(foo="spam", bar=42)
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"hint",
|
||||
[
|
||||
Union[int, None],
|
||||
Optional[int],
|
||||
],
|
||||
)
|
||||
def test_unpack_optional_wo_default(self, hint):
|
||||
"""Test CallbackData without default optional."""
|
||||
|
||||
class TgData(CallbackData, prefix="tg"):
|
||||
chat_id: int
|
||||
thread_id: hint
|
||||
|
||||
assert TgData.unpack("tg:123:") == TgData(chat_id=123, thread_id=None)
|
||||
|
||||
@pytest.mark.skipif(sys.version_info < (3, 10), reason="UnionType is added in Python 3.10")
|
||||
def test_unpack_optional_wo_default_union_type(self):
|
||||
"""Test CallbackData without default optional."""
|
||||
|
||||
class TgData(CallbackData, prefix="tg"):
|
||||
chat_id: int
|
||||
thread_id: int | None
|
||||
|
||||
assert TgData.unpack("tg:123:") == TgData(chat_id=123, thread_id=None)
|
||||
|
||||
def test_build_filter(self):
|
||||
filter_object = MyCallback.filter(F.foo == "test")
|
||||
assert isinstance(filter_object.rule, MagicFilter)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue