mirror of
https://github.com/katanemo/plano.git
synced 2026-04-26 01:06:25 +02:00
* Some fixes on model server * Remove prompt_prefilling message * Fix logging * Fix poetry issues * Improve logging and update the support for text truncation * Fix tests * Fix tests * Fix tests * Fix modelserver tests * Update modelserver tests
41 lines
1.1 KiB
Python
41 lines
1.1 KiB
Python
import os
|
|
import pytest
|
|
import requests
|
|
import logging
|
|
import yaml
|
|
|
|
|
|
MODEL_SERVER_ENDPOINT = os.getenv(
|
|
"MODEL_SERVER_ENDPOINT", "http://localhost:51000/function_calling"
|
|
)
|
|
|
|
# Load test data from YAML file
|
|
script_dir = os.path.dirname(__file__)
|
|
|
|
# Construct the full path to the YAML file
|
|
yaml_file_path = os.path.join(script_dir, "test_hallucination_data.yaml")
|
|
|
|
# Load test data from YAML file
|
|
with open(yaml_file_path, "r") as file:
|
|
test_data_yaml = yaml.safe_load(file)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"test_data",
|
|
[
|
|
pytest.param(test_case, id=test_case["id"])
|
|
for test_case in test_data_yaml["test_cases"]
|
|
],
|
|
)
|
|
def test_model_server(test_data):
|
|
input = test_data["input"]
|
|
expected = test_data["expected"]
|
|
|
|
response = requests.post(MODEL_SERVER_ENDPOINT, json=input)
|
|
assert response.status_code == 200
|
|
assert response.headers["content-type"] == "application/json"
|
|
|
|
response_json = response.json()
|
|
assert response_json
|
|
metadata = response_json.get("metadata", {})
|
|
assert (metadata["hallucination"].lower() == "true") == expected[0]["hallucination"]
|