mirror of
https://github.com/suyiiyii/nonebot-bison.git
synced 2025-06-07 20:33:01 +08:00
Merge pull request #52 from AzideCupric/abortbug
修复issue#51存在的问题并修改相应的单元测试
This commit is contained in:
commit
1ef7d68d25
@ -244,38 +244,46 @@ def do_del_sub(del_sub: Type[Matcher]):
|
|||||||
config: Config = Config()
|
config: Config = Config()
|
||||||
user_info = state["target_user_info"]
|
user_info = state["target_user_info"]
|
||||||
assert isinstance(user_info, User)
|
assert isinstance(user_info, User)
|
||||||
sub_list = config.list_subscribe(
|
try:
|
||||||
# state.get("_user_id") or event.group_id, "group"
|
sub_list = config.list_subscribe(
|
||||||
user_info.user,
|
# state.get("_user_id") or event.group_id, "group"
|
||||||
user_info.user_type,
|
user_info.user,
|
||||||
)
|
user_info.user_type,
|
||||||
res = "订阅的帐号为:\n"
|
|
||||||
state["sub_table"] = {}
|
|
||||||
for index, sub in enumerate(sub_list, 1):
|
|
||||||
state["sub_table"][index] = {
|
|
||||||
"target_type": sub["target_type"],
|
|
||||||
"target": sub["target"],
|
|
||||||
}
|
|
||||||
res += "{} {} {} {}\n".format(
|
|
||||||
index, sub["target_type"], sub["target_name"], sub["target"]
|
|
||||||
)
|
)
|
||||||
platform = platform_manager[sub["target_type"]]
|
assert sub_list
|
||||||
if platform.categories:
|
except AssertionError:
|
||||||
res += " [{}]".format(
|
await del_sub.finish("暂无已订阅账号\n请使用“添加订阅”命令添加订阅")
|
||||||
", ".join(
|
else:
|
||||||
map(lambda x: platform.categories[Category(x)], sub["cats"])
|
res = "订阅的帐号为:\n"
|
||||||
)
|
state["sub_table"] = {}
|
||||||
|
for index, sub in enumerate(sub_list, 1):
|
||||||
|
state["sub_table"][index] = {
|
||||||
|
"target_type": sub["target_type"],
|
||||||
|
"target": sub["target"],
|
||||||
|
}
|
||||||
|
res += "{} {} {} {}\n".format(
|
||||||
|
index, sub["target_type"], sub["target_name"], sub["target"]
|
||||||
)
|
)
|
||||||
if platform.enable_tag:
|
platform = platform_manager[sub["target_type"]]
|
||||||
res += " {}".format(", ".join(sub["tags"]))
|
if platform.categories:
|
||||||
res += "\n"
|
res += " [{}]".format(
|
||||||
res += "请输入要删除的订阅的序号"
|
", ".join(
|
||||||
await bot.send(event=event, message=Message(await parse_text(res)))
|
map(lambda x: platform.categories[Category(x)], sub["cats"])
|
||||||
|
)
|
||||||
|
)
|
||||||
|
if platform.enable_tag:
|
||||||
|
res += " {}".format(", ".join(sub["tags"]))
|
||||||
|
res += "\n"
|
||||||
|
res += "请输入要删除的订阅的序号\n输入'取消'中止"
|
||||||
|
await bot.send(event=event, message=Message(await parse_text(res)))
|
||||||
|
|
||||||
@del_sub.receive()
|
@del_sub.receive()
|
||||||
async def do_del(event: Event, state: T_State):
|
async def do_del(event: Event, state: T_State):
|
||||||
|
user_msg = str(event.get_message()).strip()
|
||||||
|
if user_msg == "取消":
|
||||||
|
await del_sub.finish("删除中止")
|
||||||
try:
|
try:
|
||||||
index = int(str(event.get_message()).strip())
|
index = int(user_msg)
|
||||||
config = Config()
|
config = Config()
|
||||||
user_info = state["target_user_info"]
|
user_info = state["target_user_info"]
|
||||||
assert isinstance(user_info, User)
|
assert isinstance(user_info, User)
|
||||||
|
@ -281,3 +281,49 @@ async def test_abort_add_on_tag(app: App):
|
|||||||
True,
|
True,
|
||||||
)
|
)
|
||||||
ctx.should_finished()
|
ctx.should_finished()
|
||||||
|
|
||||||
|
|
||||||
|
# 删除订阅阶段中止
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_abort_del_sub(app: App):
|
||||||
|
from nonebot.adapters.onebot.v11.bot import Bot
|
||||||
|
from nonebot.adapters.onebot.v11.message import Message
|
||||||
|
from nonebot_bison.config import Config
|
||||||
|
from nonebot_bison.config_manager import del_sub_matcher
|
||||||
|
from nonebot_bison.platform import platform_manager
|
||||||
|
|
||||||
|
config = Config()
|
||||||
|
config.user_target.truncate()
|
||||||
|
config.add_subscribe(
|
||||||
|
10000,
|
||||||
|
"group",
|
||||||
|
"6279793937",
|
||||||
|
"明日方舟Arknights",
|
||||||
|
"weibo",
|
||||||
|
[platform_manager["weibo"].reverse_category["图文"]],
|
||||||
|
["明日方舟"],
|
||||||
|
)
|
||||||
|
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()
|
||||||
|
ctx.should_call_send(
|
||||||
|
event,
|
||||||
|
Message(
|
||||||
|
"订阅的帐号为:\n1 weibo 明日方舟Arknights 6279793937\n [图文] 明日方舟\n请输入要删除的订阅的序号\n输入'取消'中止"
|
||||||
|
),
|
||||||
|
True,
|
||||||
|
)
|
||||||
|
event_abort = fake_group_message_event(
|
||||||
|
message=Message("取消"), sender=fake_admin_user
|
||||||
|
)
|
||||||
|
ctx.receive_event(bot, event_abort)
|
||||||
|
ctx.should_call_send(event_abort, "删除中止", True)
|
||||||
|
ctx.should_finished()
|
||||||
|
subs = config.list_subscribe(10000, "group")
|
||||||
|
assert subs
|
||||||
|
@ -387,8 +387,8 @@ async def test_add_with_get_id(app: App):
|
|||||||
True,
|
True,
|
||||||
)
|
)
|
||||||
"""
|
"""
|
||||||
line 362:
|
关于Message([MessageSegment(*BotReply.add_reply_on_id_input_search())]):
|
||||||
鬼知道为什么要在这里这样写,
|
异客知道为什么要在这里这样写,
|
||||||
没有[]的话assert不了(should_call_send使用[MessageSegment(...)]的格式进行比较)
|
没有[]的话assert不了(should_call_send使用[MessageSegment(...)]的格式进行比较)
|
||||||
不在这里MessageSegment()的话也assert不了(指不能让add_reply_on_id_input_search直接返回一个MessageSegment对象)
|
不在这里MessageSegment()的话也assert不了(指不能让add_reply_on_id_input_search直接返回一个MessageSegment对象)
|
||||||
amen
|
amen
|
||||||
|
@ -67,7 +67,7 @@ async def test_del_sub(app: App):
|
|||||||
ctx.should_call_send(
|
ctx.should_call_send(
|
||||||
event,
|
event,
|
||||||
Message(
|
Message(
|
||||||
"订阅的帐号为:\n1 weibo 明日方舟Arknights 6279793937\n [图文] 明日方舟\n请输入要删除的订阅的序号"
|
"订阅的帐号为:\n1 weibo 明日方舟Arknights 6279793937\n [图文] 明日方舟\n请输入要删除的订阅的序号\n输入'取消'中止"
|
||||||
),
|
),
|
||||||
True,
|
True,
|
||||||
)
|
)
|
||||||
@ -85,3 +85,30 @@ async def test_del_sub(app: App):
|
|||||||
ctx.should_finished()
|
ctx.should_finished()
|
||||||
subs = config.list_subscribe(10000, "group")
|
subs = config.list_subscribe(10000, "group")
|
||||||
assert len(subs) == 0
|
assert len(subs) == 0
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_del_empty_sub(app: App):
|
||||||
|
from nonebot.adapters.onebot.v11.bot import Bot
|
||||||
|
from nonebot.adapters.onebot.v11.message import Message
|
||||||
|
from nonebot_bison.config import Config
|
||||||
|
from nonebot_bison.config_manager import del_sub_matcher
|
||||||
|
from nonebot_bison.platform import platform_manager
|
||||||
|
|
||||||
|
config = Config()
|
||||||
|
config.user_target.truncate()
|
||||||
|
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()
|
||||||
|
ctx.should_finished()
|
||||||
|
ctx.should_call_send(
|
||||||
|
event,
|
||||||
|
"暂无已订阅账号\n请使用“添加订阅”命令添加订阅",
|
||||||
|
True,
|
||||||
|
)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user