mirror of
https://github.com/tencentmusic/supersonic.git
synced 2025-12-10 02:46:56 +00:00
105 lines
4.1 KiB
Python
105 lines
4.1 KiB
Python
#!/usr/bin/env python
|
||
# -*- encoding: utf-8 -*-
|
||
# -----------------------------------------------------------------------------------
|
||
'''
|
||
@filename : batchmark.py
|
||
@time : 2024/06/20
|
||
@author : zhaodongsheng
|
||
@Version : 1.0
|
||
@description : 批量问答测试
|
||
'''
|
||
# -----------------------------------------------------------------------------------
|
||
import pandas as pd
|
||
import json
|
||
import requests
|
||
import time
|
||
import jwt
|
||
import traceback
|
||
|
||
class BatchTest:
|
||
def __init__(self, url, agentId, chatId, userName):
|
||
self.base_url = url + '/api/chat/query/'
|
||
self.agentId = agentId
|
||
self.auth_token = self.__get_authorization(userName)
|
||
self.chatId = chatId
|
||
|
||
def parse(self, query_text):
|
||
url = self.base_url + 'parse'
|
||
data = {
|
||
'queryText': query_text,
|
||
'agentId': self.agentId,
|
||
'chatId': self.chatId,
|
||
}
|
||
headers = {
|
||
'Authorization': 'Bearer ' + self.auth_token,
|
||
'Content-Type': 'application/json',
|
||
}
|
||
|
||
response = requests.post(url, headers=headers, data=json.dumps(data))
|
||
return response.json()
|
||
|
||
def execute(self, agentId, query_text, queryId):
|
||
url = self.base_url + 'execute'
|
||
data = {
|
||
'agentId': agentId,
|
||
'queryText': query_text,
|
||
'parseId': 1,
|
||
'chatId': self.chatId,
|
||
'queryId': queryId,
|
||
}
|
||
headers = {
|
||
'Authorization': 'Bearer ' + self.auth_token,
|
||
'Content-Type': 'application/json',
|
||
}
|
||
|
||
response = requests.post(url, headers=headers, data=json.dumps(data))
|
||
return response.json()
|
||
|
||
def read_question_from_csv(self, filePath):
|
||
df = pd.read_csv(filePath)
|
||
return df
|
||
|
||
def __get_authorization(self, userName):
|
||
# secret 请和 com.tencent.supersonic.auth.api.authentication.config.AuthenticationConfig.tokenAppSecret 保持一致
|
||
secret = "WIaO9YRRVt+7QtpPvyWsARFngnEcbaKBk783uGFwMrbJBaochsqCH62L4Kijcb0sZCYoSsiKGV/zPml5MnZ3uQ=="
|
||
exp = time.time() + 100000000
|
||
token= jwt.encode({"token_user_name": userName,"exp": exp}, secret, algorithm="HS512")
|
||
return token
|
||
|
||
|
||
def benchmark(url:str, agentId:str, chatId:str, filePath:str, userName:str):
|
||
batch_test = BatchTest(url, agentId, chatId, userName)
|
||
df = batch_test.read_question_from_csv(filePath)
|
||
for index, row in df.iterrows():
|
||
question = row['question']
|
||
print('start to ask question:', question)
|
||
# 捕获异常,防止程序中断
|
||
try:
|
||
parse_resp = batch_test.parse(question)
|
||
batch_test.execute(agentId, question, parse_resp['data']['queryId'])
|
||
except Exception as e:
|
||
print('error:', e)
|
||
traceback.print_exc()
|
||
continue
|
||
time.sleep(1)
|
||
|
||
if __name__ == '__main__':
|
||
|
||
import argparse
|
||
parser = argparse.ArgumentParser()
|
||
parser.add_argument('-u', '--url', type=str, required=True, help='url:问答系统url,例如:https://chatdata-dev.test.com')
|
||
parser.add_argument('-a', '--agentId', type=str, required=True, help='agentId:助手ID')
|
||
parser.add_argument('-c', '--chatId', type=str, required=True, help='chatId:会话ID,需要通过浏览器开发者模式获取')
|
||
parser.add_argument('-f', '--filePath', type=str, required=True, help='filePath:问题文件路径, csv格式. 请提前上传到benchmark/data目录下')
|
||
parser.add_argument('-p', '--userName', type=str, required=True, help='userName:用户名,用户获取登录token')
|
||
args = parser.parse_args()
|
||
|
||
print('批量测试配置信息[url:', args.url,'agentId:', args.agentId, 'chatId:', args.chatId, 'filePath:', args.filePath, 'userName:', args.userName, ']')
|
||
print('请确认输入的压力测试信息是否正确:')
|
||
print('1. Yes')
|
||
print('2. No')
|
||
confirm = input()
|
||
if confirm == '1' or confirm == 'Yes' or confirm == 'yes' or confirm == 'YES':
|
||
benchmark(args.url, args.agentId, args.chatId, args.filePath, args.userName)
|
||
else:
|
||
print('请重新输入压力测试配置信息: url, agentId, chatId, filePath, userName') |