import base64 | |
import os | |
import sys | |
# Ajoutez le chemin du dossier parent pour que Python puisse trouver handler.py | |
sys.path.insert(0, os.path.abspath(os.path.join(os.path.dirname(__file__)))) | |
from handler import EndpointHandler # Assurez-vous que handler.py est dans le même dossier ou dans le PYTHONPATH | |
# --- Configuration pour le test local --- | |
# Le chemin vers le modèle n'est pas utilisé par notre handler car il charge le modèle par son ID | |
# Mais l'EndpointHandler attend un argument `path`. | |
# Pour le test local, on peut passer une chaîne vide ou un point. | |
MODEL_PATH_FOR_HANDLER = "." | |
# Chemin vers votre vidéo de test | |
# Assurez-vous que ce chemin est correct par rapport à l'endroit où vous exécutez ce script | |
VIDEO_FILE_PATH = "../../static/video-test.mp4" # Ajustez ce chemin si nécessaire | |
# --- Initialisation du handler --- | |
print("Initialisation du EndpointHandler...") | |
# Pour le test local, le token n'est pas nécessaire car le modèle est chargé depuis le Hub public. | |
# Si votre modèle était privé, vous devriez définir os.environ["HUGGING_FACE_HUB_TOKEN"] = "votre_token" | |
handler = EndpointHandler(path=MODEL_PATH_FOR_HANDLER) | |
print("EndpointHandler initialisé.") | |
# --- Préparation du payload (simule l'entrée de l'API) --- | |
print(f"Lecture de la vidéo de test: {VIDEO_FILE_PATH}") | |
try: | |
with open(VIDEO_FILE_PATH, "rb") as f: | |
video_bytes = f.read() | |
encoded_video = base64.b64encode(video_bytes).decode("utf-8") | |
except FileNotFoundError: | |
print(f"Erreur: Le fichier vidéo {VIDEO_FILE_PATH} n'a pas été trouvé.") | |
exit() | |
# Le payload doit correspondre à ce que votre handler.__call__ attend | |
# C'est-à-dire un dictionnaire avec une clé "inputs" qui contient une liste de messages | |
# et le contenu vidéo encodé en base64 sous la clé "data". | |
payload = { | |
"inputs": [ | |
{ | |
"role": "user", | |
"content": [ | |
{"type": "text", "text": "Describe this video in detail"}, | |
{"type": "video", "data": encoded_video} # Ici, on passe la vidéo encodée | |
] | |
} | |
], | |
"parameters": { | |
"max_new_tokens": 128 # Paramètres d'inférence optionnels | |
} | |
} | |
# --- Exécution de l'inférence --- | |
print("Lancement de l'inférence locale (cela peut prendre du temps)...") | |
try: | |
result = handler(payload) | |
print("\n--- Résultat de l'inférence ---") | |
print(result) | |
except Exception as e: | |
print(f"\nErreur lors de l'inférence: {e}") |