88 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
| #!/bin/bash
 | |
| 
 | |
| # This is the script for us to try to cause the TDengine server or client to crash
 | |
| #    
 | |
| # PREPARATION
 | |
| #
 | |
| # 1. Build an compile the TDengine source code that comes with this script, in the same directory tree
 | |
| # 2. Please follow the direction in our README.md, and build TDengine in the build/ directory
 | |
| # 3. Adjust the configuration file if needed under build/test/cfg/taos.cfg
 | |
| # 4. Run the TDengine server instance: cd build; ./build/bin/taosd -c test/cfg
 | |
| # 5. Make sure you have a working Python3 environment: run /usr/bin/python3 --version, and you should get 3.6 or above
 | |
| # 6. Make sure you have the proper Python packages: # sudo apt install python3-setuptools python3-pip python3-distutils
 | |
| #
 | |
| # RUNNING THIS SCRIPT
 | |
| # 
 | |
| # This script assumes the source code directory is intact, and that the binaries has been built in the
 | |
| # build/ directory, as such, will will load the Python libraries in the directory tree, and also load
 | |
| # the TDengine client shared library (so) file, in the build/directory, as evidenced in the env
 | |
| # variables below.
 | |
| #
 | |
| # Running the script is simple, no parameter is needed (for now, but will change in the future).
 | |
| #
 | |
| # Happy Crashing...
 | |
| 
 | |
| 
 | |
| # Due to the heavy path name assumptions/usage, let us require that the user be in the current directory
 | |
| EXEC_DIR=`dirname "$0"`
 | |
| if [[ $EXEC_DIR != "." ]]
 | |
| then
 | |
|     echo "ERROR: Please execute `basename "$0"` in its own directory (for now anyway, pardon the dust)"
 | |
|     exit -1
 | |
| fi
 | |
| 
 | |
| CURR_DIR=`pwd`
 | |
| IN_TDINTERNAL="community"
 | |
| if [[ "$CURR_DIR" == *"$IN_TDINTERNAL"* ]]; then
 | |
|   TAOS_DIR=$CURR_DIR/../../..
 | |
|   TAOSD_DIR=`find $TAOS_DIR -name "taosd"|grep bin|head -n1`
 | |
|   LIB_DIR=`echo $TAOSD_DIR|rev|cut -d '/' -f 3,4,5,6,7|rev`/lib
 | |
| else
 | |
|   TAOS_DIR=$CURR_DIR/../..
 | |
|   TAOSD_DIR=`find $TAOS_DIR -name "taosd"|grep bin|head -n1`
 | |
|   LIB_DIR=`echo $TAOSD_DIR|rev|cut -d '/' -f 3,4,5,6|rev`/lib
 | |
| fi
 | |
| 
 | |
| # Now getting ready to execute Python
 | |
| # The following is the default of our standard dev env (Ubuntu 20.04), modify/adjust at your own risk
 | |
| PYTHON_EXEC=python3
 | |
| 
 | |
| # First we need to set up a path for Python to find our own TAOS modules, so that "import" can work.
 | |
| # export PYTHONPATH=$(pwd)/../../src/connector/python:$(pwd)
 | |
| # NOTE: we are now pointing outside the current github, per Wade on 7/7/2022, we'll be keeping connectors outside
 | |
| # and there does not seem to be a module to reference that.
 | |
| PROJECT_PARENT=$(pwd)/../../..
 | |
| TAOS_PYTHON_PROJECT_DIR=$PROJECT_PARENT/taos-connector-python 
 | |
| export PYTHONPATH=$TAOS_PYTHON_PROJECT_DIR:$(pwd)
 | |
| 
 | |
| # Then let us set up the library path so that our compiled SO file can be loaded by Python
 | |
| export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$LIB_DIR
 | |
| 
 | |
| # Now we are all let, and let's see if we can find a crash. Note we pass all params
 | |
| CRASH_GEN_EXEC=crash_gen_bootstrap.py
 | |
| if [[ $1 == '--valgrind' ]]; then
 | |
|   shift
 | |
|   export PYTHONMALLOC=malloc
 | |
|   VALGRIND_OUT=valgrind.out 
 | |
|   VALGRIND_ERR=valgrind.err
 | |
|   # How to generate valgrind suppression file: https://stackoverflow.com/questions/17159578/generating-suppressions-for-memory-leaks
 | |
|   # valgrind --leak-check=full --gen-suppressions=all --log-fd=9 python3.8 ./crash_gen.py $@ 9>>memcheck.log
 | |
|   echo Executing under VALGRIND, with STDOUT/ERR going to $VALGRIND_OUT and $VALGRIND_ERR, please watch them from a different terminal.
 | |
|   valgrind  \
 | |
|     --leak-check=yes \
 | |
|     --suppressions=crash_gen/valgrind_taos.supp \
 | |
|     $PYTHON_EXEC \
 | |
|     $CRASH_GEN_EXEC $@ > $VALGRIND_OUT 2> $VALGRIND_ERR 
 | |
| elif [[ $1 == '--helgrind' ]]; then
 | |
|   shift
 | |
|   HELGRIND_OUT=helgrind.out 
 | |
|   HELGRIND_ERR=helgrind.err
 | |
|   valgrind  \
 | |
|     --tool=helgrind \
 | |
|     $PYTHON_EXEC \
 | |
|     $CRASH_GEN_EXEC $@ > $HELGRIND_OUT 2> $HELGRIND_ERR
 | |
| else
 | |
|   $PYTHON_EXEC $CRASH_GEN_EXEC $@
 | |
| fi
 | |
| 
 |