From 5abf55d0956f26c650ee9d7c8447154820138133 Mon Sep 17 00:00:00 2001 From: yanyongyu <42488585+yanyongyu@users.noreply.github.com> Date: Sat, 29 Jan 2022 23:39:13 +0800 Subject: [PATCH] :white_check_mark: add message tests --- tests/test_adapters/test_message.py | 48 +++++++++++++++++++++------- tests/test_adapters/test_template.py | 17 ++++++++++ 2 files changed, 54 insertions(+), 11 deletions(-) create mode 100644 tests/test_adapters/test_template.py diff --git a/tests/test_adapters/test_message.py b/tests/test_adapters/test_message.py index 88d9e563..56fbab7c 100644 --- a/tests/test_adapters/test_message.py +++ b/tests/test_adapters/test_message.py @@ -1,23 +1,49 @@ from utils import make_fake_message -def test_message_template(): - from nonebot.adapters import MessageTemplate - +def test_segment_add(): Message = make_fake_message() + MessageSegment = Message.get_segment_class() - template = MessageTemplate("{a:custom}{b:text}{c:image}", Message) + assert MessageSegment.text("text") + MessageSegment.text("text") == Message( + [MessageSegment.text("text"), MessageSegment.text("text")] + ) - @template.add_format_spec - def custom(input: str) -> str: - return input + "-custom!" + assert MessageSegment.text("text") + "text" == Message( + [MessageSegment.text("text"), MessageSegment.text("text")] + ) - formatted = template.format(a="test", b="test", c="https://example.com/test") - assert formatted.extract_plain_text() == "test-custom!test" - assert str(formatted) == "test-custom!test[fake:image]" + assert MessageSegment.text("text") + Message( + [MessageSegment.text("text")] + ) == Message([MessageSegment.text("text"), MessageSegment.text("text")]) + + assert "text" + MessageSegment.text("text") == Message( + [MessageSegment.text("text"), MessageSegment.text("text")] + ) -def test_message_slice(): +def test_message_add(): + Message = make_fake_message() + MessageSegment = Message.get_segment_class() + + assert Message([MessageSegment.text("text")]) + MessageSegment.text( + "text" + ) == Message([MessageSegment.text("text"), MessageSegment.text("text")]) + + assert Message([MessageSegment.text("text")]) + "text" == Message( + [MessageSegment.text("text"), MessageSegment.text("text")] + ) + + assert Message([MessageSegment.text("text")]) + Message( + [MessageSegment.text("text")] + ) == Message([MessageSegment.text("text"), MessageSegment.text("text")]) + + msg = Message([MessageSegment.text("text")]) + msg += MessageSegment.text("text") + assert msg == Message([MessageSegment.text("text"), MessageSegment.text("text")]) + + +def test_message_getitem(): Message = make_fake_message() MessageSegment = Message.get_segment_class() diff --git a/tests/test_adapters/test_template.py b/tests/test_adapters/test_template.py new file mode 100644 index 00000000..3dbef541 --- /dev/null +++ b/tests/test_adapters/test_template.py @@ -0,0 +1,17 @@ +from utils import make_fake_message + + +def test_message_template(): + from nonebot.adapters import MessageTemplate + + Message = make_fake_message() + + template = MessageTemplate("{a:custom}{b:text}{c:image}", Message) + + @template.add_format_spec + def custom(input: str) -> str: + return input + "-custom!" + + formatted = template.format(a="test", b="test", c="https://example.com/test") + assert formatted.extract_plain_text() == "test-custom!test" + assert str(formatted) == "test-custom!test[fake:image]"