mirror of
https://github.com/Balshgit/gpt_chat_bot.git
synced 2025-09-10 17:20:41 +03:00
add bug report action (#71)
* add bug report * add admin section to env
This commit is contained in:
parent
29204f1592
commit
460123ef28
@ -22,6 +22,12 @@ class BotStagesEnum(StrEnum):
|
||||
help = "help"
|
||||
|
||||
|
||||
class BotCommands(StrEnum):
|
||||
help = "help"
|
||||
bug_report = "bug_report"
|
||||
website = "website"
|
||||
|
||||
|
||||
class BotEntryPoints(StrEnum):
|
||||
start_routes = "start_routes"
|
||||
end = "end"
|
||||
|
@ -6,7 +6,8 @@ from loguru import logger
|
||||
from telegram import InlineKeyboardMarkup, Update
|
||||
from telegram.ext import ContextTypes
|
||||
|
||||
from constants import BotEntryPoints
|
||||
from constants import BotCommands, BotEntryPoints
|
||||
from core.bot.app import get_bot
|
||||
from core.bot.keyboards import main_keyboard
|
||||
from core.bot.services import ChatGptService, SpeechToTextService
|
||||
from settings.config import settings
|
||||
@ -36,9 +37,7 @@ async def about_bot(update: Update, context: ContextTypes.DEFAULT_TYPE) -> None:
|
||||
chatgpt_service = ChatGptService.build()
|
||||
model = await chatgpt_service.get_current_chatgpt_model()
|
||||
await update.effective_message.reply_text(
|
||||
f"Бот использует бесплатную модель *{model}* для ответов на вопросы.\nПринимает запросы на разных языках."
|
||||
f"\n\nБот так же умеет переводить русские голосовые сообщения в текст. Просто пришлите или перешлите "
|
||||
f"голосовуху боту и получите поток сознания в виде текста, но без знаков препинания.",
|
||||
f"Бот использует бесплатную модель *{model}* для ответов на вопросы.\nПринимает запросы на разных языках.",
|
||||
parse_mode="Markdown",
|
||||
)
|
||||
|
||||
@ -64,6 +63,20 @@ async def help_command(update: Update, context: ContextTypes.DEFAULT_TYPE) -> No
|
||||
)
|
||||
|
||||
|
||||
async def bug_report(update: Update, context: ContextTypes.DEFAULT_TYPE) -> None:
|
||||
"""Send a message when the command /bug-report is issued."""
|
||||
|
||||
if not update.effective_message:
|
||||
return
|
||||
async with get_bot(settings.TELEGRAM_API_TOKEN) as bot:
|
||||
await bot.send_message(chat_id=settings.ADMIN_CHAT_ID, text=f"Bug report from user: {update.effective_user}")
|
||||
await update.effective_message.reply_text(
|
||||
f"Спасибо за баг репорт.\n"
|
||||
f"Можете попробовать воспользоваться веб версией /{BotCommands.website}, выбрав различные GPT модели",
|
||||
parse_mode="Markdown",
|
||||
)
|
||||
|
||||
|
||||
async def github(update: Update, context: ContextTypes.DEFAULT_TYPE) -> None:
|
||||
"""Send a message when the command /help is issued."""
|
||||
|
||||
@ -79,7 +92,11 @@ async def ask_question(update: Update, context: ContextTypes.DEFAULT_TYPE) -> No
|
||||
if not update.message:
|
||||
return
|
||||
|
||||
await update.message.reply_text("Пожалуйста, подождите, ответ в среднем занимает 10-15 секунд")
|
||||
await update.message.reply_text(
|
||||
f"Ответ в среднем занимает 10-15 секунд.\n"
|
||||
f"- Список команд: /{BotCommands.help}\n"
|
||||
f"- Сообщить об ошибке: /{BotCommands.bug_report}",
|
||||
)
|
||||
|
||||
chatgpt_service = ChatGptService.build()
|
||||
logger.warning("question asked", user=update.message.from_user, question=update.message.text)
|
||||
|
@ -9,11 +9,12 @@ from telegram.ext import (
|
||||
filters,
|
||||
)
|
||||
|
||||
from constants import BotEntryPoints, BotStagesEnum
|
||||
from constants import BotCommands, BotEntryPoints, BotStagesEnum
|
||||
from core.bot.commands import (
|
||||
about_bot,
|
||||
about_me,
|
||||
ask_question,
|
||||
bug_report,
|
||||
github,
|
||||
help_command,
|
||||
start_command,
|
||||
@ -32,7 +33,10 @@ class BotEventHandlers:
|
||||
|
||||
bot_event_handlers = BotEventHandlers()
|
||||
|
||||
bot_event_handlers.add_handler(CommandHandler("help", help_command))
|
||||
bot_event_handlers.add_handler(CommandHandler(BotCommands.help, help_command))
|
||||
bot_event_handlers.add_handler(CommandHandler(BotCommands.website, website))
|
||||
bot_event_handlers.add_handler(CommandHandler(BotCommands.bug_report, bug_report))
|
||||
|
||||
bot_event_handlers.add_handler(MessageHandler(filters.TEXT & ~filters.COMMAND, ask_question))
|
||||
bot_event_handlers.add_handler(MessageHandler(filters.VOICE | filters.AUDIO, voice_recognize))
|
||||
bot_event_handlers.add_handler(
|
||||
|
@ -9,9 +9,11 @@ WORKERS_COUNT=1
|
||||
RELOAD="true"
|
||||
DEBUG="true"
|
||||
|
||||
# ==== admin =====
|
||||
SUPERUSER="user"
|
||||
SUPERUSER_PASSWORD="hackme"
|
||||
SALT="change me"
|
||||
ADMIN_CHAT_ID="123456789"
|
||||
|
||||
# ==== sentry ====
|
||||
ENABLE_SENTRY="false"
|
||||
|
@ -71,6 +71,7 @@ class AppSettings(SentrySettings, LoggingSettings, BaseSettings):
|
||||
SUPERUSER: str | None = None
|
||||
SUPERUSER_PASSWORD: SecretStr | None = None
|
||||
SALT: SecretStr | None = None
|
||||
ADMIN_CHAT_ID: int | None = None
|
||||
|
||||
# telegram settings
|
||||
TELEGRAM_API_TOKEN: str = "123456789:AABBCCDDEEFFaabbccddeeff-1234567890"
|
||||
|
@ -210,9 +210,7 @@ async def test_about_bot_callback_action(
|
||||
|
||||
assert mocked_reply_text.call_args.args == (
|
||||
f"Бот использует бесплатную модель *{model_with_highest_priority.model}* для ответов на вопросы.\n"
|
||||
f"Принимает запросы на разных языках.\n\nБот так же умеет переводить русские голосовые сообщения в текст. "
|
||||
f"Просто пришлите или перешлите голосовуху боту и получите поток сознания в виде текста, "
|
||||
f"но без знаков препинания.",
|
||||
f"Принимает запросы на разных языках.",
|
||||
)
|
||||
assert mocked_reply_text.call_args.kwargs == {"parse_mode": "Markdown"}
|
||||
|
||||
@ -234,6 +232,35 @@ async def test_website_callback_action(
|
||||
assert mocked_reply_text.call_args.args == ("Веб версия: http://localhost/chat/",)
|
||||
|
||||
|
||||
async def test_bug_report_action(
|
||||
main_application: Application,
|
||||
test_settings: AppSettings,
|
||||
) -> None:
|
||||
with (
|
||||
mock.patch.object(telegram._message.Message, "reply_text") as mocked_reply_text,
|
||||
mock.patch.object(
|
||||
telegram._bot.Bot, "send_message", return_value=lambda *args, **kwargs: (args, kwargs)
|
||||
) as mocked_send_message,
|
||||
):
|
||||
bot_update = BotUpdateFactory(message=BotMessageFactory.create_instance(text="/bug_report"))
|
||||
|
||||
await main_application.bot_app.application.process_update(
|
||||
update=Update.de_json(data=bot_update, bot=main_application.bot_app.bot)
|
||||
)
|
||||
|
||||
assert mocked_reply_text.call_args.args == (
|
||||
"Спасибо за баг репорт.\n"
|
||||
"Можете попробовать воспользоваться веб версией /website, выбрав различные GPT модели",
|
||||
)
|
||||
from_user = bot_update["message"]["from"]
|
||||
assert mocked_send_message.call_args.kwargs["text"] == (
|
||||
f"Bug report from user: "
|
||||
f"User(first_name='{from_user['first_name']}', id={from_user['id']}, is_bot={from_user['is_bot']}, "
|
||||
f"language_code='{from_user['language_code']}', last_name='{from_user['last_name']}', "
|
||||
f"username='{from_user['username']}')"
|
||||
)
|
||||
|
||||
|
||||
async def test_ask_question_action(
|
||||
dbsession: Session,
|
||||
main_application: Application,
|
||||
@ -254,7 +281,9 @@ async def test_ask_question_action(
|
||||
)
|
||||
assert_that(mocked_send_message.call_args_list[0].kwargs).is_equal_to(
|
||||
{
|
||||
"text": "Пожалуйста, подождите, ответ в среднем занимает 10-15 секунд",
|
||||
"text": (
|
||||
"Ответ в среднем занимает 10-15 секунд.\n- Список команд: /help\n- Сообщить об ошибке: /bug_report"
|
||||
),
|
||||
"chat_id": bot_update["message"]["chat"]["id"],
|
||||
},
|
||||
include=["text", "chat_id"],
|
||||
|
@ -84,7 +84,7 @@ class BotInfoFactory(factory.DictFactory):
|
||||
class BotEntitleFactory(factory.DictFactory):
|
||||
type = "bot_command"
|
||||
offset = 0
|
||||
length = 7
|
||||
length = 42
|
||||
|
||||
|
||||
class BotMessageFactory(factory.DictFactory):
|
||||
|
Loading…
x
Reference in New Issue
Block a user