更好的Bot运行检查

This commit is contained in:
AkashiCoin 2024-08-27 23:30:14 +08:00
parent ab1d0d22dd
commit ee11893074
2 changed files with 39 additions and 13 deletions

View File

@ -2,9 +2,9 @@ name: 检查bot是否运行正常
on:
push:
branches: [ "dev", "main"]
branches: ["dev", "main"]
pull_request:
branches: [ "dev", "main"]
branches: ["dev", "main"]
jobs:
bot-check:
@ -24,14 +24,21 @@ jobs:
# Poetry cache depends on OS, Python version and Poetry version.
- name: Cache Poetry cache
id: cache-poetry
uses: actions/cache@v3
with:
path: ~/.cache/pypoetry
key: poetry-cache-${{ runner.os }}-${{ steps.setup_python.outputs.python-version }}
- name: Cache Data cache
uses: actions/cache@v3
with:
path: ~/data
key: data-cache-${{ runner.os }}-${{ steps.setup_python.outputs.python-version }}
- name: Install dependencies
if: steps.cache-poetry.outputs.cache-hit != 'true'
run: |
mv scripts/bot_check.py bot_check.py
rm -rf poetry.lock
poetry source remove ali
poetry install --no-root
@ -40,4 +47,5 @@ jobs:
- name: Check bot run
id: bot_check_run
run: |
poetry run python3 bot_check.py
mv scripts/bot_check.py bot_check.py
poetry run python3 bot_check.py

View File

@ -1,6 +1,9 @@
import os
import re
import asyncio
import nonebot
from nonebot.log import logger
# from nonebot.adapters.discord import Adapter as DiscordAdapter
from nonebot.adapters.dodo import Adapter as DoDoAdapter
@ -9,37 +12,52 @@ from nonebot.adapters.onebot.v11 import Adapter as OneBotV11Adapter
nonebot.init()
from zhenxun.services.db_context import init, disconnect
driver = nonebot.get_driver()
driver.register_adapter(OneBotV11Adapter)
driver.register_adapter(KaiheilaAdapter)
driver.register_adapter(DoDoAdapter)
# driver.register_adapter(DiscordAdapter)
driver.on_startup(init)
driver.on_shutdown(disconnect)
# nonebot.load_builtin_plugins("echo")
nonebot.load_plugins("zhenxun/builtin_plugins")
nonebot.load_plugins("zhenxun/plugins")
all_plugins = [name.replace(":", ".") for name in nonebot.get_available_plugin_names()]
print("所有插件:", all_plugins)
logger.info(f"所有插件:{all_plugins}")
loaded_plugins = tuple(
re.sub(r"^zhenxun\.(plugins|builtin_plugins)\.", "", plugin.module_name)
for plugin in nonebot.get_loaded_plugins()
)
print("已加载插件:", loaded_plugins)
logger.info(f"已加载插件:{loaded_plugins}")
for plugin in all_plugins.copy():
if plugin.startswith(("platform",)):
print(f"平台插件:{plugin}")
logger.info(f"平台插件:{plugin}")
elif plugin.endswith(loaded_plugins):
print(f"已加载插件:{plugin}")
logger.info(f"已加载插件:{plugin}")
else:
print(f"未加载插件:{plugin}")
logger.info(f"未加载插件:{plugin}")
continue
all_plugins.remove(plugin)
if all_plugins:
print("出现未加载的插件:", all_plugins)
logger.info(f"出现未加载的插件:{all_plugins}")
exit(1)
else:
print("所有插件均已加载")
logger.info("所有插件均已加载")
@driver.on_startup
async def _():
task = asyncio.create_task(asyncio.sleep(1))
task.add_done_callback(lambda _: driver._lifespan.on_ready(os._exit(0)))
nonebot.run()