|
| 1 | +#!/bin/bash |
| 2 | +# Copyright (C) 2024 Intel Corporation |
| 3 | +# SPDX-License-Identifier: Apache-2.0 |
| 4 | + |
| 5 | +set -e |
| 6 | +source ./common.sh |
| 7 | + |
| 8 | +IMAGE_REPO=${IMAGE_REPO:-"opea"} |
| 9 | +IMAGE_TAG=${IMAGE_TAG:-"latest"} |
| 10 | +echo "REGISTRY=IMAGE_REPO=${IMAGE_REPO}" |
| 11 | +echo "TAG=IMAGE_TAG=${IMAGE_TAG}" |
| 12 | +export REGISTRY=${IMAGE_REPO} |
| 13 | +export TAG=${IMAGE_TAG} |
| 14 | + |
| 15 | +WORKPATH=$(dirname "$PWD") |
| 16 | +LOG_PATH="$WORKPATH/tests" |
| 17 | + |
| 18 | +ip_address=$(hostname -I | awk '{print $1}') |
| 19 | +HOST_IP=$ip_address |
| 20 | + |
| 21 | +COMPOSE_FILE="compose.yaml" |
| 22 | +EC_RAG_SERVICE_PORT=16010 |
| 23 | +#MODEL_PATH="$WORKPATH/models" |
| 24 | +MODEL_PATH="/home/media/models" |
| 25 | +HF_ENDPOINT=https://hf-mirror.com |
| 26 | + |
| 27 | + |
| 28 | +function build_docker_images() { |
| 29 | + cd $WORKPATH/docker_image_build |
| 30 | + echo "Build all the images with --no-cache, check docker_image_build.log for details..." |
| 31 | + service_list="server ui ecrag" |
| 32 | + docker compose -f build.yaml build ${service_list} --no-cache > ${LOG_PATH}/docker_image_build.log |
| 33 | + |
| 34 | + docker images && sleep 1s |
| 35 | +} |
| 36 | + |
| 37 | +function start_services() { |
| 38 | + export MODEL_PATH=${MODEL_PATH} |
| 39 | + export HOST_IP=${HOST_IP} |
| 40 | + export LLM_MODEL=${LLM_MODEL} |
| 41 | + export HF_ENDPOINT=${HF_ENDPOINT} |
| 42 | + export vLLM_ENDPOINT=${vLLM_ENDPOINT} |
| 43 | + export HUGGINGFACEHUB_API_TOKEN=${HUGGINGFACEHUB_API_TOKEN} |
| 44 | + export no_proxy="localhost, 127.0.0.1, 192.168.1.1" |
| 45 | + |
| 46 | + cd $WORKPATH/docker_compose/intel/gpu/arc |
| 47 | + |
| 48 | + # Start Docker Containers |
| 49 | + docker compose -f $COMPOSE_FILE up -d > ${LOG_PATH}/start_services_with_compose.log |
| 50 | + sleep 20 |
| 51 | +} |
| 52 | + |
| 53 | +function validate_rag() { |
| 54 | + cd $WORKPATH/tests |
| 55 | + |
| 56 | + # setup pipeline |
| 57 | + validate_services \ |
| 58 | + "${HOST_IP}:${EC_RAG_SERVICE_PORT}/v1/settings/pipelines" \ |
| 59 | + "active" \ |
| 60 | + "pipeline" \ |
| 61 | + "edgecraftrag-server" \ |
| 62 | + '@configs/test_pipeline_local_llm.json' |
| 63 | + |
| 64 | + # add data |
| 65 | + validate_services \ |
| 66 | + "${HOST_IP}:${EC_RAG_SERVICE_PORT}/v1/data" \ |
| 67 | + "Done" \ |
| 68 | + "data" \ |
| 69 | + "edgecraftrag-server" \ |
| 70 | + '@configs/test_data.json' |
| 71 | + |
| 72 | + # query |
| 73 | + validate_services \ |
| 74 | + "${HOST_IP}:${EC_RAG_SERVICE_PORT}/v1/chatqna" \ |
| 75 | + "1234567890" \ |
| 76 | + "query" \ |
| 77 | + "vllm-openvino-server" \ |
| 78 | + '{"messages":"What is the test id?"}' |
| 79 | +} |
| 80 | + |
| 81 | +function validate_megaservice() { |
| 82 | + # Curl the Mega Service |
| 83 | + validate_services \ |
| 84 | + "${HOST_IP}:16011/v1/chatqna" \ |
| 85 | + "1234567890" \ |
| 86 | + "query" \ |
| 87 | + "vllm-openvino-server" \ |
| 88 | + '{"messages":"What is the test id?"}' |
| 89 | +} |
| 90 | + |
| 91 | +function stop_docker() { |
| 92 | + cd $WORKPATH/docker_compose/intel/gpu/arc |
| 93 | + docker compose -f $COMPOSE_FILE down |
| 94 | +} |
| 95 | + |
| 96 | + |
| 97 | +function main() { |
| 98 | + mkdir -p $LOG_PATH |
| 99 | + |
| 100 | + stop_docker |
| 101 | + if [[ "$IMAGE_REPO" == "opea" ]]; then build_docker_images; fi |
| 102 | + start_services |
| 103 | + echo "EC_RAG service started" && sleep 1s |
| 104 | + |
| 105 | + validate_rag |
| 106 | + validate_megaservice |
| 107 | + |
| 108 | + stop_docker |
| 109 | + echo y | docker system prune |
| 110 | + |
| 111 | +} |
| 112 | + |
| 113 | +main |
0 commit comments