mirror of
				https://github.com/ggml-org/llama.cpp.git
				synced 2025-10-30 08:42:00 +00:00 
			
		
		
		
	 be20e7f49d
			
		
	
	be20e7f49d
	
	
	
		
			
			* re-organize docs * add link among docs * add link to build docs * fix style * de-duplicate sections
		
			
				
	
	
		
			105 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Debugging Tests Tips
 | |
| 
 | |
| ## How to run & execute or debug a specific test without anything else to keep the feedback loop short?
 | |
| 
 | |
| There is a script called debug-test.sh in the scripts folder whose parameter takes a REGEX and an optional test number.
 | |
| 
 | |
| For example, running the following command will output an interactive list from which you can select a test. It takes this form:
 | |
| 
 | |
| `debug-test.sh [OPTION]... <test_regex> <test_number>`
 | |
| 
 | |
| It will then build & run in the debugger for you.
 | |
| 
 | |
| To just execute a test and get back a PASS or FAIL message run:
 | |
| 
 | |
| ```bash
 | |
| ./scripts/debug-test.sh test-tokenizer
 | |
| ```
 | |
| 
 | |
| To test in GDB use the `-g` flag to enable gdb test mode.
 | |
| 
 | |
| ```bash
 | |
| ./scripts/debug-test.sh -g test-tokenizer
 | |
| 
 | |
| # Once in the debugger, i.e. at the chevrons prompt, setting a breakpoint could be as follows:
 | |
| >>> b main
 | |
| ```
 | |
| 
 | |
| To speed up the testing loop, if you know your test number you can just run it similar to below:
 | |
| 
 | |
| ```bash
 | |
| ./scripts/debug-test.sh test 23
 | |
| ```
 | |
| 
 | |
| For further reference use `debug-test.sh -h` to print help.
 | |
| 
 | |
|  
 | |
| 
 | |
| ### How does the script work?
 | |
| If you want to be able to use the concepts contained in the script separately, the important ones are briefly outlined below.
 | |
| 
 | |
| #### Step 1: Reset and Setup folder context
 | |
| 
 | |
| From base of this repository, let's create `build-ci-debug` as our build context.
 | |
| 
 | |
| ```bash
 | |
| rm -rf build-ci-debug && mkdir build-ci-debug && cd build-ci-debug
 | |
| ```
 | |
| 
 | |
| #### Step 2: Setup Build Environment and Compile Test Binaries
 | |
| 
 | |
| Setup and trigger a build under debug mode. You may adapt the arguments as needed, but in this case these are sane defaults.
 | |
| 
 | |
| ```bash
 | |
| cmake -DCMAKE_BUILD_TYPE=Debug -DLLAMA_CUDA=1 -DLLAMA_FATAL_WARNINGS=ON ..
 | |
| make -j
 | |
| ```
 | |
| 
 | |
| #### Step 3: Find all tests available that matches REGEX
 | |
| 
 | |
| The output of this command will give you the command & arguments needed to run GDB.
 | |
| 
 | |
| * `-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
 | |
| 
 | |
| ```bash
 | |
| ctest -R "test-tokenizer" -V -N
 | |
| ```
 | |
| 
 | |
| This may return output similar to below (focusing on key lines to pay attention to):
 | |
| 
 | |
| ```bash
 | |
| ...
 | |
| 1: Test command: ~/llama.cpp/build-ci-debug/bin/test-tokenizer-0 "~/llama.cpp/tests/../models/ggml-vocab-llama-spm.gguf"
 | |
| 1: Working Directory: .
 | |
| Labels: main
 | |
|   Test  #1: test-tokenizer-0-llama-spm
 | |
| ...
 | |
| 4: Test command: ~/llama.cpp/build-ci-debug/bin/test-tokenizer-0 "~/llama.cpp/tests/../models/ggml-vocab-falcon.gguf"
 | |
| 4: Working Directory: .
 | |
| Labels: main
 | |
|   Test  #4: test-tokenizer-0-falcon
 | |
| ...
 | |
| ```
 | |
| 
 | |
| #### Step 4: Identify Test Command for Debugging
 | |
| 
 | |
| So for test #1 above we can tell these two pieces of relevant information:
 | |
| * Test Binary: `~/llama.cpp/build-ci-debug/bin/test-tokenizer-0`
 | |
| * Test GGUF Model: `~/llama.cpp/tests/../models/ggml-vocab-llama-spm.gguf`
 | |
| 
 | |
| #### Step 5: Run GDB on test command
 | |
| 
 | |
| Based on the ctest 'test command' report above we can then run a gdb session via this command below:
 | |
| 
 | |
| ```bash
 | |
| gdb --args ${Test Binary} ${Test GGUF Model}
 | |
| ```
 | |
| 
 | |
| Example:
 | |
| 
 | |
| ```bash
 | |
| gdb --args ~/llama.cpp/build-ci-debug/bin/test-tokenizer-0 "~/llama.cpp/tests/../models/ggml-vocab-llama-spm.gguf"
 | |
| ```
 |