From 4d4d1060de0f58f8e8229ee483e3f376f9f761de Mon Sep 17 00:00:00 2001 From: suyiiyii Date: Wed, 3 Jul 2024 10:26:58 +0800 Subject: [PATCH] =?UTF-8?q?:bug:=20=E6=9F=A5=E8=AF=A2=E8=AE=A2=E9=98=85?= =?UTF-8?q?=E6=97=B6=E6=8F=90=E7=A4=BA=E4=B8=8D=E5=AD=98=E5=9C=A8=E7=9A=84?= =?UTF-8?q?=E5=B9=B3=E5=8F=B0=20(#584)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * :bug: 查询订阅时提示不存在的平台 fix #515 * :lipstick: auto fix by pre-commit hooks * :bug: 删除订阅时,获取详细信息跳过不存在的platform * :white_check_mark: 添加对于不存在的平台的单元测试 * :bug: 删除订阅时跳过不存在的platform * :lipstick: 规范化订阅列表的输出 * :lipstick: 规范化订阅列表的输出 * :lipstick: 规范化订阅列表的输出 * :lipstick: 规范化订阅列表的输出 --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> --- nonebot_bison/scheduler/manager.py | 2 + nonebot_bison/sub_manager/del_sub.py | 15 +++-- nonebot_bison/sub_manager/query_sub.py | 17 +++-- tests/sub_manager/test_query_del.py | 91 +++++++++++++++++++++++++- 4 files changed, 111 insertions(+), 14 deletions(-) diff --git a/nonebot_bison/scheduler/manager.py b/nonebot_bison/scheduler/manager.py index 750c0da..badb91a 100644 --- a/nonebot_bison/scheduler/manager.py +++ b/nonebot_bison/scheduler/manager.py @@ -52,6 +52,8 @@ async def handle_insert_new_target(platform_name: str, target: T_Target): async def handle_delete_target(platform_name: str, target: T_Target): + if platform_name not in platform_manager: + return platform = platform_manager[platform_name] scheduler_obj = scheduler_dict[platform.site] scheduler_obj.delete_schedulable(platform_name, target) diff --git a/nonebot_bison/sub_manager/del_sub.py b/nonebot_bison/sub_manager/del_sub.py index c1003c2..b70d923 100644 --- a/nonebot_bison/sub_manager/del_sub.py +++ b/nonebot_bison/sub_manager/del_sub.py @@ -28,12 +28,15 @@ def do_del_sub(del_sub: type[Matcher]): "target": sub.target.target, } res += f"{index} {sub.target.platform_name} {sub.target.target_name} {sub.target.target}\n" - platform = platform_manager[sub.target.platform_name] - if platform.categories: - res += " [{}]".format(", ".join(platform.categories[Category(x)] for x in sub.categories)) - if platform.enable_tag: - res += " {}".format(", ".join(sub.tags)) - res += "\n" + if platform := platform_manager.get(sub.target.platform_name): + if platform.categories: + res += " [{}]".format(", ".join(platform.categories[Category(x)] for x in sub.categories)) + if platform.enable_tag: + res += " {}".format(", ".join(sub.tags)) + else: + res += f" (平台 {sub.target.platform_name} 已失效,请删除此订阅)" + if res[-1] != "\n": + res += "\n" res += "请输入要删除的订阅的序号\n输入'取消'中止" await MessageFactory(await parse_text(res)).send() diff --git a/nonebot_bison/sub_manager/query_sub.py b/nonebot_bison/sub_manager/query_sub.py index 5bce812..8f4d7ba 100644 --- a/nonebot_bison/sub_manager/query_sub.py +++ b/nonebot_bison/sub_manager/query_sub.py @@ -17,12 +17,15 @@ def do_query_sub(query_sub: type[Matcher]): sub_list = await config.list_subscribe(user_info) res = "订阅的帐号为:\n" for sub in sub_list: - res += f"{sub.target.platform_name} {sub.target.target_name} {sub.target.target}" - platform = platform_manager[sub.target.platform_name] - if platform.categories: - res += " [{}]".format(", ".join(platform.categories[Category(x)] for x in sub.categories)) - if platform.enable_tag: - res += " {}".format(", ".join(sub.tags)) - res += "\n" + res += f"{sub.target.platform_name} {sub.target.target_name} {sub.target.target}\n" + if platform := platform_manager.get(sub.target.platform_name): + if platform.categories: + res += " [{}]".format(", ".join(platform.categories[Category(x)] for x in sub.categories)) + if platform.enable_tag: + res += " {}".format(", ".join(sub.tags)) + else: + res += f" (平台 {sub.target.platform_name} 已失效,请删除此订阅)" + if res[-1] != "\n": + res += "\n" await MessageFactory(await parse_text(res)).send() await query_sub.finish() diff --git a/tests/sub_manager/test_query_del.py b/tests/sub_manager/test_query_del.py index d5c0141..f92a119 100644 --- a/tests/sub_manager/test_query_del.py +++ b/tests/sub_manager/test_query_del.py @@ -32,7 +32,45 @@ async def test_query_sub(app: App, init_scheduler): ctx.should_pass_permission() should_send_saa( ctx, - MessageFactory("订阅的帐号为:\nweibo 明日方舟Arknights 6279793937 [图文] 明日方舟\n"), + MessageFactory("订阅的帐号为:\nweibo 明日方舟Arknights 6279793937\n [图文] 明日方舟\n"), + bot, + event=event, + ) + + +@pytest.mark.asyncio +async def test_query_no_exsits_sub(app: App, init_scheduler): + from nonebot.adapters.onebot.v11 import Bot, Message + from nonebot_plugin_saa import TargetQQGroup, MessageFactory + + from nonebot_bison.types import Target + from nonebot_bison.config import config + from nonebot_bison.platform import platform_manager + from nonebot_bison.sub_manager import query_sub_matcher + + platform_manager["no_exsits_platform"] = platform_manager["weibo"] + await config.add_subscribe( + TargetQQGroup(group_id=10000), + Target("6279793937"), + "明日方舟Arknights", + "no_exsits_platform", + [platform_manager["weibo"].reverse_category["图文"]], + ["明日方舟"], + ) + del platform_manager["no_exsits_platform"] + async with app.test_matcher(query_sub_matcher) as ctx: + bot = ctx.create_bot(base=Bot) + + event = fake_group_message_event(message=Message("查询订阅"), to_me=True) + ctx.receive_event(bot, event) + ctx.should_pass_rule() + ctx.should_pass_permission() + should_send_saa( + ctx, + MessageFactory( + "订阅的帐号为:\nno_exsits_platform 明日方舟Arknights 6279793937\n" + + " (平台 no_exsits_platform 已失效,请删除此订阅)\n" + ), bot, event=event, ) @@ -87,6 +125,57 @@ async def test_del_sub(app: App, init_scheduler): assert len(subs) == 0 +@pytest.mark.asyncio +async def test_del_no_exsits_sub(app: App, init_scheduler): + from nonebot.adapters.onebot.v11.bot import Bot + from nonebot.adapters.onebot.v11.message import Message + from nonebot_plugin_saa import TargetQQGroup, MessageFactory + + from nonebot_bison.types import Target + from nonebot_bison.config import config + from nonebot_bison.platform import platform_manager + from nonebot_bison.sub_manager import del_sub_matcher + + platform_manager["no_exsits_platform"] = platform_manager["weibo"] + await config.add_subscribe( + TargetQQGroup(group_id=10000), + Target("6279793937"), + "明日方舟Arknights", + "no_exsits_platform", + [platform_manager["weibo"].reverse_category["图文"]], + ["明日方舟"], + ) + del platform_manager["no_exsits_platform"] + async with app.test_matcher(del_sub_matcher) as ctx: + bot = ctx.create_bot(base=Bot) + assert isinstance(bot, Bot) + event = fake_group_message_event(message=Message("删除订阅"), to_me=True, sender=fake_admin_user) + ctx.receive_event(bot, event) + ctx.should_pass_rule() + ctx.should_pass_permission() + should_send_saa( + ctx, + MessageFactory( + "订阅的帐号为:\n" + + "1 no_exsits_platform 明日方舟Arknights 6279793937\n" + + " (平台 no_exsits_platform 已失效,请删除此订阅)\n" + + "请输入要删除的订阅的序号\n输入'取消'中止", + ), + bot, + event=event, + ) + event_1_err = fake_group_message_event(message=Message("2"), sender=fake_admin_user) + ctx.receive_event(bot, event_1_err) + ctx.should_call_send(event_1_err, "删除错误", True) + ctx.should_rejected() + event_1_ok = fake_group_message_event(message=Message("1"), sender=fake_admin_user) + ctx.receive_event(bot, event_1_ok) + ctx.should_call_send(event_1_ok, "删除成功", True) + ctx.should_finished() + subs = await config.list_subscribe(TargetQQGroup(group_id=10000)) + assert len(subs) == 0 + + @pytest.mark.asyncio async def test_del_empty_sub(app: App, init_scheduler): from nonebot.adapters.onebot.v11.bot import Bot