tests.sh 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. #!/bin/bash
  2. # make sure we are in the right directory
  3. SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
  4. cd $SCRIPT_DIR
  5. #export LLAMA_CACHE="$SCRIPT_DIR/tmp"
  6. set -eux
  7. mkdir -p $SCRIPT_DIR/output
  8. PROJ_ROOT="$SCRIPT_DIR/../.."
  9. cd $PROJ_ROOT
  10. ###############
  11. arr_bin=()
  12. arr_hf=()
  13. arr_tmpl=() # chat template
  14. add_test() {
  15. local bin=$1
  16. local hf=$2
  17. local tmpl=${3:-""} # default to empty string if not provided
  18. arr_bin+=("$bin")
  19. arr_hf+=("$hf")
  20. arr_tmpl+=("$tmpl")
  21. }
  22. add_test "llama-mtmd-cli" "ggml-org/gemma-3-4b-it-GGUF:Q4_K_M"
  23. add_test "llama-mtmd-cli" "guinmoon/MobileVLM-3B-GGUF:Q4_K_M" "deepseek"
  24. add_test "llama-mtmd-cli" "THUDM/glm-edge-v-5b-gguf:Q4_K_M"
  25. add_test "llama-mtmd-cli" "second-state/Llava-v1.5-7B-GGUF:Q2_K" "vicuna"
  26. add_test "llama-mtmd-cli" "cjpais/llava-1.6-mistral-7b-gguf:Q3_K" "vicuna"
  27. add_test "llama-mtmd-cli" "ibm-research/granite-vision-3.2-2b-GGUF:Q4_K_M"
  28. add_test "llama-mtmd-cli" "second-state/MiniCPM-Llama3-V-2_5-GGUF:Q2_K" # model from openbmb is corrupted
  29. add_test "llama-mtmd-cli" "openbmb/MiniCPM-V-2_6-gguf:Q2_K"
  30. add_test "llama-mtmd-cli" "openbmb/MiniCPM-o-2_6-gguf:Q4_0"
  31. add_test "llama-qwen2vl-cli" "bartowski/Qwen2-VL-2B-Instruct-GGUF:Q4_K_M"
  32. # add_test "llama-mtmd-cli" "cmp-nct/Yi-VL-6B-GGUF:Q5_K" # this model has broken chat template, not usable
  33. ###############
  34. cmake --build build -j --target "${arr_bin[@]}"
  35. arr_res=()
  36. for i in "${!arr_bin[@]}"; do
  37. bin="${arr_bin[$i]}"
  38. hf="${arr_hf[$i]}"
  39. tmpl="${arr_tmpl[$i]}"
  40. echo "Running test with binary: $bin and HF model: $hf"
  41. echo ""
  42. echo ""
  43. output=$(\
  44. "$PROJ_ROOT/build/bin/$bin" \
  45. -hf "$hf" \
  46. --image $SCRIPT_DIR/test-1.jpeg \
  47. -p "what is the publisher name of the newspaper?" \
  48. --temp 0 -n 128 \
  49. ${tmpl:+--chat-template "$tmpl"} \
  50. 2>&1 | tee /dev/tty)
  51. echo "$output" > $SCRIPT_DIR/output/$bin-$(echo "$hf" | tr '/' '-').log
  52. if echo "$output" | grep -iq "new york"; then
  53. result="\033[32mOK\033[0m: $bin $hf"
  54. else
  55. result="\033[31mFAIL\033[0m: $bin $hf"
  56. fi
  57. echo -e "$result"
  58. arr_res+=("$result")
  59. echo ""
  60. echo ""
  61. echo ""
  62. echo "#################################################"
  63. echo "#################################################"
  64. echo ""
  65. echo ""
  66. done
  67. set +x
  68. for i in "${!arr_res[@]}"; do
  69. echo -e "${arr_res[$i]}"
  70. done
  71. echo ""
  72. echo "Output logs are saved in $SCRIPT_DIR/output"