| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 |
- #!/bin/bash
- PROG=${0##*/}
- build_dir="build-ci-debug"
- # Print Color Commands
- red=$(tput setaf 1)
- green=$(tput setaf 2)
- yellow=$(tput setaf 3)
- blue=$(tput setaf 4)
- magenta=$(tput setaf 5)
- cyan=$(tput setaf 6)
- normal=$(tput sgr0)
- # Print Help Message
- ####################
- print_full_help() {
- cat << EOF
- Usage: $PROG [OPTION]... <test_regex> (test_number)
- Debug specific ctest program.
- Options:
- -h, --help display this help and exit
- -g run in gdb mode
- Arguments:
- <test_regex> (Mandatory) Supply one regex to the script to filter tests
- (test_number) (Optional) Test number to run a specific test
- Example:
- $PROG test-tokenizer
- $PROG test-tokenizer 3
- EOF
- }
- abort() {
- echo "Error: $1" >&2
- cat << EOF >&2
- Usage: $PROG [OPTION]... <test_regex> (test_number)
- Debug specific ctest program.
- Refer to --help for full instructions.
- EOF
- exit 1
- }
- # Dependency Sanity Check
- #########################
- check_dependency() {
- command -v "$1" >/dev/null 2>&1 || {
- abort "$1 is required but not found. Please install it and try again."
- }
- }
- check_dependency ctest
- check_dependency cmake
- # Step 0: Check the args
- ########################
- if [ x"$1" = x"-h" ] || [ x"$1" = x"--help" ]; then
- print_full_help >&2
- exit 0
- fi
- # Parse command-line options
- gdb_mode=false
- while getopts "g" opt; do
- case $opt in
- g)
- gdb_mode=true
- echo "gdb_mode Mode Enabled"
- ;;
- esac
- done
- # Shift the option parameters
- shift $((OPTIND - 1))
- # Positionial Argument Processing : <test_regex>
- if [ -z "${1}" ]; then
- abort "Test regex is required"
- else
- test_suite=${1:-}
- fi
- # Positionial Argument Processing : (test_number)
- test_number=${2:-}
- # Step 1: Reset and Setup folder context
- ########################################
- ## Sanity check that we are actually in a git repo
- repo_root=$(git rev-parse --show-toplevel)
- if [ ! -d "$repo_root" ]; then
- abort "Not in a Git repository."
- fi
- ## Reset folder to root context of git repo and Create and enter build directory
- pushd "$repo_root"
- rm -rf "$build_dir" && mkdir "$build_dir" || abort "Failed to make $build_dir"
- # Step 2: Setup Build Environment and Compile Test Binaries
- ###########################################################
- # Note: test-eval-callback requires -DLLAMA_CURL
- cmake -B "./$build_dir" -DCMAKE_BUILD_TYPE=Debug -DLLAMA_CUDA=1 -DLLAMA_CURL=1 || abort "Failed to build enviroment"
- pushd "$build_dir"
- make -j || abort "Failed to compile"
- popd > /dev/null || exit 1
- # Step 3: Find all tests available that matches REGEX
- ####################################################
- # Ctest Gather Tests
- # `-R test-tokenizer` : looks for all the test files named `test-tokenizer*` (R=Regex)
- # `-N` : "show-only" disables test execution & shows test commands that you can feed to GDB.
- # `-V` : Verbose Mode
- printf "\n\nGathering tests that fit REGEX: ${test_suite} ...\n"
- pushd "$build_dir"
- tests=($(ctest -R ${test_suite} -V -N | grep -E " +Test +#[0-9]+*" | cut -d':' -f2 | awk '{$1=$1};1'))
- if [ ${#tests[@]} -eq 0 ]; then
- abort "No tests avaliable... check your compliation process..."
- fi
- popd > /dev/null || exit 1
- # Step 4: Identify Test Command for Debugging
- #############################################
- # Select test number
- if [ -z $test_number ]; then
- # List out avaliable tests
- printf "Which test would you like to debug?\n"
- id=0
- for s in "${tests[@]}"
- do
- echo "Test# ${id}"
- echo " $s"
- ((id++))
- done
- # Prompt user which test they wanted to run
- printf "\nRun test#? "
- read test_number
- else
- printf "\nUser Already Requested #${test_number}\n"
- fi
- # Grab all tests commands
- pushd "$build_dir"
- sIFS=$IFS # Save Initial IFS (Internal Field Separator)
- IFS=$'\n' # Change IFS (Internal Field Separator) (So we split ctest output by newline rather than by spaces)
- test_args=($(ctest -R ${test_suite} -V -N | grep "Test command" | cut -d':' -f3 | awk '{$1=$1};1' )) # Get test args
- IFS=$sIFS # Reset IFS (Internal Field Separator)
- popd > /dev/null || exit 1
- # Grab specific test command
- single_test_name="${tests[test_number]}"
- single_test_command="${test_args[test_number]}"
- # Step 5: Execute or GDB Debug
- ##############################
- printf "${magenta}Running Test #${test_number}: ${single_test_name}${normal}\n"
- printf "${cyan}single_test_command: ${single_test_command}${normal}\n"
- if [ "$gdb_mode" = "true" ]; then
- # Execute debugger
- pushd "$repo_root" || exit 1
- eval "gdb --args ${single_test_command}"
- popd > /dev/null || exit 1
- else
- # Execute Test
- pushd "$repo_root" || exit 1
- eval "${single_test_command}"
- exit_code=$?
- popd > /dev/null || exit 1
- # Print Result
- printf "${blue}Ran Test #${test_number}: ${single_test_name}${normal}\n"
- printf "${yellow}Command: ${single_test_command}${normal}\n"
- if [ $exit_code -eq 0 ]; then
- printf "${green}TEST PASS${normal}\n"
- else
- printf "${red}TEST FAIL${normal}\n"
- fi
- fi
- # Return to the directory from which the user ran the command.
- popd > /dev/null || exit 1
|