mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-10 20:40:24 +01:00
fed0108491
* A little documentation that shares my quick tips for working in the repository. * Update startup-testing-debugging.md * script that shows a menu of tests to pick from & run the debugger on * debug-test.sh: Refactor CLI help message * debug-test.sh: documentation update * debug-test.sh: CLI Help output corrections * debug-test.sh: minor doc fix --------- authored-by: Josh Ramer <ubuntu@ip-172-31-32-53.ec2.internal> Assisted-by: brian khuu <mofosyne@gmail.com>
89 lines
2.7 KiB
Markdown
89 lines
2.7 KiB
Markdown
# Debugging Tests Tips
|
|
|
|
## How to run & 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.
|
|
|
|
```bash
|
|
./scripts/debug-test.sh test-tokenizer
|
|
|
|
# Once in the debugger, i.e. at the chevrons prompt, setting a breakpoint could be as follows:
|
|
>>> b main
|
|
```
|
|
|
|
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.1: Identify Test Command for Debugging
|
|
|
|
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
|
|
...
|
|
```
|
|
|
|
So for test #1 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 3.2: 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"
|
|
```
|