2025-01-21 20:52:28 +08:00
|
|
|
#
|
|
|
|
|
# Copyright 2025 The InfiniFlow Authors. All Rights Reserved.
|
|
|
|
|
#
|
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
|
#
|
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
#
|
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
|
# limitations under the License.
|
|
|
|
|
#
|
|
|
|
|
|
2024-10-31 14:07:23 +08:00
|
|
|
import os
|
2025-04-01 13:39:07 +08:00
|
|
|
|
2024-10-31 14:07:23 +08:00
|
|
|
import pytest
|
|
|
|
|
import requests
|
2025-03-06 20:22:17 +08:00
|
|
|
|
2025-04-01 13:39:07 +08:00
|
|
|
HOST_ADDRESS = os.getenv("HOST_ADDRESS", "http://127.0.0.1:9380")
|
2025-06-05 12:04:09 +08:00
|
|
|
ZHIPU_AI_API_KEY = os.getenv("ZHIPU_AI_API_KEY")
|
2025-05-22 11:59:12 +08:00
|
|
|
if ZHIPU_AI_API_KEY is None:
|
|
|
|
|
pytest.exit("Error: Environment variable ZHIPU_AI_API_KEY must be set")
|
2025-01-21 20:52:28 +08:00
|
|
|
|
2024-11-26 18:21:15 +08:00
|
|
|
# def generate_random_email():
|
|
|
|
|
# return 'user_' + ''.join(random.choices(string.ascii_lowercase + string.digits, k=8))+'@1.com'
|
2024-10-23 22:58:27 +08:00
|
|
|
|
2025-04-01 13:39:07 +08:00
|
|
|
|
2024-11-26 18:21:15 +08:00
|
|
|
def generate_email():
|
2025-04-01 13:39:07 +08:00
|
|
|
return "user_123@1.com"
|
2024-11-26 18:21:15 +08:00
|
|
|
|
2025-01-21 20:52:28 +08:00
|
|
|
|
2024-11-26 18:21:15 +08:00
|
|
|
EMAIL = generate_email()
|
2024-10-23 22:58:27 +08:00
|
|
|
# password is "123"
|
2025-04-01 13:39:07 +08:00
|
|
|
PASSWORD = """ctAseGvejiaSWWZ88T/m4FQVOpQyUvP+x7sXtdv3feqZACiQleuewkUi35E16wSd5C5QcnkkcV9cYc8TKPTRZlxappDuirxghxoOvFcJxFU4ixLsD
|
2024-10-23 22:58:27 +08:00
|
|
|
fN33jCHRoDUW81IH9zjij/vaw8IbVyb6vuwg6MX6inOEBRRzVbRYxXOu1wkWY6SsI8X70oF9aeLFp/PzQpjoe/YbSqpTq8qqrmHzn9vO+yvyYyvmDsphXe
|
2025-04-01 13:39:07 +08:00
|
|
|
X8f7fp9c7vUsfOCkM+gHY3PadG+QHa7KI7mzTKgUTZImK6BZtfRBATDTthEUbbaTewY4H0MnWiCeeDhcbeQao6cFy1To8pE3RpmxnGnS8BsBn8w=="""
|
2024-10-23 22:58:27 +08:00
|
|
|
|
2025-01-21 20:52:28 +08:00
|
|
|
|
2024-10-23 22:58:27 +08:00
|
|
|
def register():
|
2026-04-24 10:25:15 +08:00
|
|
|
url = HOST_ADDRESS + "/api/v1/users"
|
2024-10-23 22:58:27 +08:00
|
|
|
name = "user"
|
2025-01-21 20:52:28 +08:00
|
|
|
register_data = {"email": EMAIL, "nickname": name, "password": PASSWORD}
|
|
|
|
|
res = requests.post(url=url, json=register_data)
|
2024-10-23 22:58:27 +08:00
|
|
|
res = res.json()
|
2024-11-05 11:02:31 +08:00
|
|
|
if res.get("code") != 0:
|
|
|
|
|
raise Exception(res.get("message"))
|
2024-10-23 22:58:27 +08:00
|
|
|
|
2025-01-21 20:52:28 +08:00
|
|
|
|
2024-10-23 22:58:27 +08:00
|
|
|
def login():
|
2026-04-24 10:25:15 +08:00
|
|
|
url = HOST_ADDRESS + "/api/v1/auth/login"
|
2025-01-21 20:52:28 +08:00
|
|
|
login_data = {"email": EMAIL, "password": PASSWORD}
|
|
|
|
|
response = requests.post(url=url, json=login_data)
|
2024-10-23 22:58:27 +08:00
|
|
|
res = response.json()
|
2025-01-21 20:52:28 +08:00
|
|
|
if res.get("code") != 0:
|
2024-11-05 11:02:31 +08:00
|
|
|
raise Exception(res.get("message"))
|
2024-10-23 22:58:27 +08:00
|
|
|
auth = response.headers["Authorization"]
|
|
|
|
|
return auth
|
|
|
|
|
|
2025-01-21 20:52:28 +08:00
|
|
|
|
2024-10-23 22:58:27 +08:00
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
|
def get_api_key_fixture():
|
2024-11-28 17:37:46 +08:00
|
|
|
try:
|
|
|
|
|
register()
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
2024-10-23 22:58:27 +08:00
|
|
|
auth = login()
|
2026-04-08 15:26:18 +08:00
|
|
|
url = HOST_ADDRESS + "/v1/system/tokens"
|
2024-10-23 22:58:27 +08:00
|
|
|
auth = {"Authorization": auth}
|
2025-01-21 20:52:28 +08:00
|
|
|
response = requests.post(url=url, headers=auth)
|
2024-10-23 22:58:27 +08:00
|
|
|
res = response.json()
|
2024-11-05 11:02:31 +08:00
|
|
|
if res.get("code") != 0:
|
|
|
|
|
raise Exception(res.get("message"))
|
2024-10-23 22:58:27 +08:00
|
|
|
return res["data"].get("token")
|
|
|
|
|
|
2025-01-21 20:52:28 +08:00
|
|
|
|
2024-11-21 15:39:25 +08:00
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
|
def get_auth():
|
2024-11-26 18:21:15 +08:00
|
|
|
try:
|
|
|
|
|
register()
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
2024-11-21 15:39:25 +08:00
|
|
|
auth = login()
|
|
|
|
|
return auth
|
|
|
|
|
|
2025-01-21 20:52:28 +08:00
|
|
|
|
2024-11-21 15:39:25 +08:00
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
|
def get_email():
|
|
|
|
|
return EMAIL
|
2025-05-22 11:59:12 +08:00
|
|
|
|
|
|
|
|
|
2026-05-29 17:39:41 +08:00
|
|
|
def get_added_models(auth, factory_name):
|
|
|
|
|
url = HOST_ADDRESS + "/api/v1/models"
|
|
|
|
|
authorization = {"Authorization": auth}
|
|
|
|
|
response = requests.get(url=url, headers=authorization)
|
|
|
|
|
res = response.json()
|
|
|
|
|
if res.get("code") != 0:
|
|
|
|
|
raise Exception(res.get("message"))
|
|
|
|
|
added_factory = {model["provider_name"] for model in res.get("data", [])}
|
|
|
|
|
if factory_name in added_factory:
|
|
|
|
|
return True
|
|
|
|
|
return False
|
|
|
|
|
|
2025-05-22 11:59:12 +08:00
|
|
|
|
2026-05-29 17:39:41 +08:00
|
|
|
def add_model_instance(auth):
|
|
|
|
|
add_provider_api = HOST_ADDRESS + "/api/v1/providers"
|
|
|
|
|
authorization = {"Authorization": auth}
|
|
|
|
|
add_provider_response = requests.put(url=add_provider_api, headers=authorization, json={"provider_name": "ZHIPU-AI"})
|
|
|
|
|
add_provider_res = add_provider_response.json()
|
|
|
|
|
if add_provider_res.get("code") != 0:
|
|
|
|
|
pytest.exit(f"Critical error in add model provider: {add_provider_res.get('message')}")
|
|
|
|
|
|
|
|
|
|
add_instance_api = HOST_ADDRESS + "/api/v1/providers/ZHIPU-AI/instances"
|
|
|
|
|
add_instance_response = requests.post(url=add_instance_api, headers=authorization, json={
|
|
|
|
|
"instance_name": "CI",
|
|
|
|
|
"api_key": ZHIPU_AI_API_KEY,
|
|
|
|
|
"region": "default",
|
|
|
|
|
"base_url": ""
|
|
|
|
|
})
|
|
|
|
|
add_instance_res = add_instance_response.json()
|
|
|
|
|
if add_instance_res.get("code") != 0:
|
|
|
|
|
pytest.exit(f"Critical error in add model instance: {add_instance_res.get('message')}")
|
|
|
|
|
|
|
|
|
|
add_success = get_added_models(auth, "ZHIPU-AI")
|
|
|
|
|
if not add_success:
|
|
|
|
|
pytest.exit("Critical error in check added model: add model failed")
|
|
|
|
|
|
|
|
|
|
|
2025-05-22 11:59:12 +08:00
|
|
|
@pytest.fixture(scope="session", autouse=True)
|
|
|
|
|
def set_tenant_info(get_auth):
|
|
|
|
|
auth = get_auth
|
2026-05-29 17:39:41 +08:00
|
|
|
if not get_added_models(auth, "ZHIPU-AI"):
|
|
|
|
|
try:
|
|
|
|
|
add_model_instance(auth)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
pytest.exit(f"Error in set_tenant_info: {str(e)}")
|
|
|
|
|
url = HOST_ADDRESS + "/api/v1/models/default"
|
2025-05-22 11:59:12 +08:00
|
|
|
authorization = {"Authorization": get_auth}
|
2026-05-29 17:39:41 +08:00
|
|
|
# set chat model
|
|
|
|
|
set_default_llm_response = requests.patch(
|
|
|
|
|
url=url,
|
|
|
|
|
headers=authorization,
|
|
|
|
|
json={
|
|
|
|
|
"model_provider": "ZHIPU-AI",
|
|
|
|
|
"model_instance": "CI",
|
|
|
|
|
"model_type": "chat",
|
|
|
|
|
"model_name": "glm-4-flash"
|
|
|
|
|
})
|
|
|
|
|
llm_res = set_default_llm_response.json()
|
|
|
|
|
if llm_res.get("code") != 0:
|
|
|
|
|
raise Exception(llm_res.get("message"))
|
|
|
|
|
# set embedding model
|
|
|
|
|
set_default_embedding_response = requests.patch(
|
|
|
|
|
url=url,
|
|
|
|
|
headers=authorization,
|
|
|
|
|
json={
|
|
|
|
|
"model_provider": "Builtin",
|
|
|
|
|
"model_instance": "Local",
|
|
|
|
|
"model_type": "embedding",
|
|
|
|
|
"model_name": "BAAI/bge-small-en-v1.5"
|
|
|
|
|
})
|
|
|
|
|
embd_res = set_default_embedding_response.json()
|
|
|
|
|
if embd_res.get("code") != 0:
|
|
|
|
|
raise Exception(embd_res.get("message"))
|
|
|
|
|
# set image to text model
|
|
|
|
|
set_default_img2txt_response = requests.patch(
|
|
|
|
|
url=url,
|
|
|
|
|
headers=authorization,
|
|
|
|
|
json={
|
|
|
|
|
"model_provider": "ZHIPU-AI",
|
|
|
|
|
"model_instance": "CI",
|
|
|
|
|
"model_type": "vision",
|
|
|
|
|
"model_name": "glm-4v"
|
|
|
|
|
})
|
|
|
|
|
img2txt_res = set_default_img2txt_response.json()
|
|
|
|
|
if img2txt_res.get("code") != 0:
|
|
|
|
|
raise Exception(img2txt_res.get("message"))
|