Merge branch 'main' into main

This commit is contained in:
molanp 2024-12-19 01:31:38 +08:00 committed by GitHub
commit 0177146570
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 60 additions and 33 deletions

View File

@ -6,12 +6,14 @@ on:
paths: paths:
- zhenxun/** - zhenxun/**
- tests/** - tests/**
- .github/workflows/bot_check.yml
- bot.py - bot.py
pull_request: pull_request:
branches: ["main"] branches: ["main"]
paths: paths:
- zhenxun/** - zhenxun/**
- tests/** - tests/**
- .github/workflows/bot_check.yml
- bot.py - bot.py
jobs: jobs:
@ -57,15 +59,15 @@ jobs:
rm -rf poetry.lock rm -rf poetry.lock
poetry source remove aliyun poetry source remove aliyun
poetry install --no-root poetry install --no-root
- name: Install playwright - name: Install playwright
if: steps.cache-playwright.outputs.cache-hit != 'true' if: steps.cache-playwright.outputs.cache-hit != 'true'
run: | run: |
poetry run sudo apt-get update poetry run sudo apt-get update
poetry run sudo apt-get install -y libgstreamer-plugins-base1.0-0 libgstreamer1.0-0 gstreamer1.0-plugins-base gstreamer1.0-plugins-good gstreamer1.0-plugins-bad gstreamer1.0-libav flite x264 libx264-dev poetry run sudo apt-get install -y libgstreamer-plugins-base1.0-0 libgstreamer1.0-0 gstreamer1.0-plugins-base gstreamer1.0-plugins-good gstreamer1.0-plugins-bad gstreamer1.0-libav flite x264 libx264-dev
poetry run sudo playwright install-deps
poetry run pip install playwright poetry run pip install playwright
poetry run sudo playwright install poetry run playwright install-deps
poetry run playwright install
- name: Run tests - name: Run tests
run: poetry run pytest --cov=zhenxun --cov-report xml run: poetry run pytest --cov=zhenxun --cov-report xml

View File

@ -1,3 +1,4 @@
from collections.abc import Callable from collections.abc import Callable
from pathlib import Path from pathlib import Path
import platform import platform
@ -229,3 +230,7 @@ async def test_check_arm(
mock_template_to_pic.assert_awaited_once() mock_template_to_pic.assert_awaited_once()
mock_build_message.assert_called_once_with(mock_template_to_pic_return) mock_build_message.assert_called_once_with(mock_template_to_pic_return)
mock_build_message_return.send.assert_awaited_once() mock_build_message_return.send.assert_awaited_once()

View File

@ -57,7 +57,9 @@ async def test_update_all_plugin_basic_need_update(
) )
ctx.should_call_send( ctx.should_call_send(
event=event, event=event,
message=Message(message="已更新插件 识图\n共计1个插件! 重启后生效"), message=Message(
message="--已更新1个插件 0个失败 1个成功--\n* 以下插件更新成功:\n\t- 识图\n重启后生效" # noqa: E501
),
result=None, result=None,
bot=bot, bot=bot,
) )

View File

@ -256,12 +256,11 @@ class ShopManage:
result = await AsyncHttpx.gather_download_file( result = await AsyncHttpx.gather_download_file(
req_download_urls, req_paths req_download_urls, req_paths
) )
for _id, success in enumerate(result): for success in result:
if not success: if not success:
raise Exception("插件依赖文件下载失败") raise Exception("插件依赖文件下载失败")
else: logger.debug(f"插件依赖文件列表: {req_paths}", "插件管理")
logger.debug(f"插件依赖文件列表: {req_paths}", "插件管理") install_requirement(plugin_path)
install_requirement(plugin_path)
return True return True
raise Exception("插件下载失败") raise Exception("插件下载失败")
@ -389,34 +388,53 @@ class ShopManage:
""" """
data: dict[str, StorePluginInfo] = await cls.get_data() data: dict[str, StorePluginInfo] = await cls.get_data()
plugin_list = list(data.keys()) plugin_list = list(data.keys())
update_list = [] update_failed_list = []
update_success_list = []
result = "--已更新{}个插件 {}个失败 {}个成功--"
logger.info(f"尝试更新全部插件 {plugin_list}", "插件管理") logger.info(f"尝试更新全部插件 {plugin_list}", "插件管理")
for plugin_key in plugin_list: for plugin_key in plugin_list:
plugin_info = data[plugin_key] try:
plugin_list = await cls.get_loaded_plugins("module", "version") plugin_info = data[plugin_key]
suc_plugin = {p[0]: (p[1] or "Unknown") for p in plugin_list} plugin_list = await cls.get_loaded_plugins("module", "version")
if plugin_info.module not in [p[0] for p in plugin_list]: suc_plugin = {p[0]: (p[1] or "Unknown") for p in plugin_list}
logger.debug(f"插件 {plugin_key} 未安装,跳过", "插件管理") if plugin_info.module not in [p[0] for p in plugin_list]:
continue logger.debug(f"插件 {plugin_key} 未安装,跳过", "插件管理")
if cls.check_version_is_new(plugin_info, suc_plugin): continue
logger.debug(f"插件 {plugin_key} 已是最新版本,跳过", "插件管理") if cls.check_version_is_new(plugin_info, suc_plugin):
continue logger.debug(f"插件 {plugin_key} 已是最新版本,跳过", "插件管理")
logger.info(f"正在更新插件 {plugin_key}", "插件管理") continue
is_external = True logger.info(f"正在更新插件 {plugin_key}", "插件管理")
if plugin_info.github_url is None: is_external = True
plugin_info.github_url = DEFAULT_GITHUB_URL if plugin_info.github_url is None:
is_external = False plugin_info.github_url = DEFAULT_GITHUB_URL
await cls.install_plugin_with_repo( is_external = False
plugin_info.github_url, await cls.install_plugin_with_repo(
plugin_info.module_path, plugin_info.github_url,
plugin_info.is_dir, plugin_info.module_path,
is_external, plugin_info.is_dir,
) is_external,
update_list.append(plugin_key) )
if len(update_list) == 0: update_success_list.append(plugin_key)
except Exception as e:
logger.error(f"更新插件 {plugin_key} 失败: {e}", "插件管理")
update_failed_list.append(plugin_key)
if not update_success_list and not update_failed_list:
return "全部插件已是最新版本" return "全部插件已是最新版本"
return "已更新插件 {}\n共计{}个插件! 重启后生效".format( if update_success_list:
"\n- ".join(update_list), len(update_list) result += "\n* 以下插件更新成功:\n\t- {}".format(
"\n\t- ".join(update_success_list)
)
if update_failed_list:
result += "\n* 以下插件更新失败:\n\t- {}".format(
"\n\t- ".join(update_failed_list)
)
return (
result.format(
len(update_success_list) + len(update_failed_list),
len(update_failed_list),
len(update_success_list),
)
+ "\n重启后生效"
) )
@classmethod @classmethod