Skip to content

Commit

Permalink
introduce integrationtest2
Browse files Browse the repository at this point in the history
  • Loading branch information
bb7133 committed Oct 11, 2024
1 parent b334ea5 commit 3e834e3
Show file tree
Hide file tree
Showing 9 changed files with 691 additions and 186 deletions.
205 changes: 19 additions & 186 deletions tests/integrationtest/run-tests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -13,49 +13,12 @@
# See the License for the specific language governing permissions and
# limitations under the License.

set -x

TIDB_TEST_STORE_NAME=$TIDB_TEST_STORE_NAME
TIKV_PATH=$TIKV_PATH
START_TIDB_CLUSTER=$START_TIDB_CLUSTER

# Variables to set paths for each server binary
TIDB_BIN="./third_bin/tidb-server"
TIKV_BIN="./third_bin/tikv-server"
PD_BIN="./third_bin/pd-server"
DUMPLING_BIN="./third_bin/dumpling"
TICDC_BIN="./third_bin/cdc"
TIFLASH_BIN="./third_bin/tiflash-server"

# Variables to set data directories
PD_DATA_DIR="./data/pd_data"
PD_DATA_DIR2="./data/pd_data2"
TIKV_DATA_DIR="./data/tikv_data"
TIKV_DATA_DIR2="./data/tikv_data2"
TIFLASH_DATA_DIR="./data/tiflash_data"
TIFLASH_DATA_DIR2="./data/tiflash_data2"
TICDC_DATA_DIR="./data/ticdc_data"

rm -rf ./data
mkdir ./data

TIDB_LOG_FILE="./logs/tidb.log"
TIDB_LOG_FILE2="./logs/tidb2.log"
TIKV_LOG_FILE="./logs/tikv.log"
TIKV_LOG_FILE2="./logs/tikv2.log"
TIFLASH_LOG_FILE="./logs/tiflash.log"
TIFLASH_LOG_FILE2="./logs/tiflash2.log"
PD_LOG_FILE="./logs/pd.log"
PD_LOG_FILE2="./logs/pd2.log"
TICDC_LOG_FILE="./logs/ticdc.log"

rm -rf ./logs
mkdir ./logs

build=1
mysql_tester="./mysql_tester"
tidb_server=""
ticdc_server=$TICDC_BIN
portgenerator=""
mysql_tester_log="./integration-test.out"
tests=""
Expand Down Expand Up @@ -249,155 +212,22 @@ rm -rf $mysql_tester_log
ports=($(find_multiple_available_ports 4000 2))
port=${ports[0]}
status=${ports[1]}
# PD Server Configuration
start_pd_server() {
client_port=${1:-2379}
peer_port=${2:-2380}
data_dir=${3:-$PD_DATA_DIR}
log_dir=${4:-$PD_LOG_FILE}

echo "Starting PD server..."
mkdir -p $data_dir

$PD_BIN --name="pd" --data-dir="$data_dir" --log-file="$log_dir" \
--client-urls="http://127.0.0.1:$client_port" \
--peer-urls="http://127.0.0.1:$peer_port" \
--advertise-client-urls="http://127.0.0.1:$client_port" \
--advertise-peer-urls="http://127.0.0.1:$peer_port" &
# --config="config/pd.toml"
sleep 5 # Wait for PD to sart
}

# TiKV Server Configuration
start_tikv_server() {
pd_client_port=${1:-2379}
tikv_port=${2:-20160}
tikv_status_port=${3:-20180}
data_dir=${4:-$TIKV_DATA_DIR}
log_dir=${5:-$TIKV_LOG_FILE}

echo "Starting TiKV server..."
mkdir -p $data_dir

$TIKV_BIN --pd="http://127.0.0.1:$pd_client_port" \
--addr="127.0.0.1:$tikv_port" \
--advertise-addr="127.0.0.1:$tikv_port" \
--status-addr="127.0.0.1:$tikv_status_port" \
--data-dir="$data_dir" \
--log-file="$log_dir" &
sleep 5 # Wait for TiKV to connect to PD
}

# TiFlash Server Configuration
start_tiflash_server() {
echo "Starting TiFlash server..."
mkdir -p $TIFLASH_DATA_DIR
$TIFLASH_BIN --data-dir=$TIFLASH_DATA_DIR --log-file=tiflash.log &

sleep 5 # Wait for TiFlash to connect
}

function start_tidb_server()
{
pd_client_addr=${1:-127.0.0.1:2379}
tidb_port=${2:-4000}
tidb_status_port=${3:-10080}
log_file=${4:-$TIDB_LOG_FILE}

config_file="config.toml"
if [[ $enabled_new_collation = 0 ]]; then
config_file="disable_new_collation.toml"
fi
echo "start tidb-server, log file: $log_file"
echo "start tidb-server, log file: $mysql_tester_log"
if [ "${TIDB_TEST_STORE_NAME}" = "tikv" ]; then
$tidb_server -P "$tidb_port" \
-status "$tidb_status_port" \
-config $config_file \
-store tikv \
-path "${pd_client_addr}" > $log_file 2>&1 &
$tidb_server -P "$port" -status "$status" -config $config_file -store tikv -path "${TIKV_PATH}" > $mysql_tester_log 2>&1 &
SERVER_PID=$!
else
$tidb_server -P "$tidb_port" \
-status "$tidb_status_port" \
-config $config_file \
-store unistore \
-path "" > $log_file 2>&1 &
$tidb_server -P "$port" -status "$status" -config $config_file -store unistore -path "" > $mysql_tester_log 2>&1 &
SERVER_PID=$!
fi
echo "tidb-server(PID: $SERVER_PID) started, port: $tidb_port"
}

function start_ticdc_server() {
pd_client_addr=${1:-http://127.0.0.1:2379}
ticdc_port=${2:-8300}
downstream_port=${3:-4100}

echo "Starting TiCDC server..."
mkdir -p $TICDC_DATA_DIR
$TICDC_BIN server --pd=$pd_client_addr --addr=127.0.0.1:$ticdc_port --data-dir=$TICDC_DATA_DIR --log-file=$TICDC_LOG_FILE &
sleep 5 # Wait for TiCDC to connect

$TICDC_BIN cli changefeed create --server=127.0.0.1:$ticdc_port --sink-uri="mysql://root:@127.0.0.1:$downstream_port/" --changefeed-id="simple-replication-task"
sleep 5 # Wait for changefeed to connect
}

function start_tidb_cluster()
{
local ports=($(find_multiple_available_ports 2379 2))
if [ $? -ne 0 ]; then
echo "Error: Could not find multiple available ports." >&2
exit 1
fi
pd_client_port=${ports[0]}
pd_peer_port=${ports[1]}
upstream_pd_client_port=$pd_client_port
start_pd_server $pd_client_port $pd_peer_port $PD_DATA_DIR $PD_LOG_FILE

local ports=($(find_multiple_available_ports 20160 2))
if [ $? -ne 0 ]; then
echo "Error: Could not find multiple available ports." >&2
exit 1
fi
tikv_port=${ports[0]}
tikv_status_port=${ports[1]}
start_tikv_server $pd_client_port $tikv_port $tikv_status_port $TIKV_DATA_DIR $TIKV_LOG_FILE

tidb_port=$(find_available_port 4000)
# Tricky: update `port` here.
port=$tidb_port
tidb_status_port=$(find_available_port 10080)
start_tidb_server "127.0.0.1:$pd_client_port" $tidb_port $tidb_status_port $TIDB_LOG_FILE

local ports=($(find_multiple_available_ports 2379 2))
if [ $? -ne 0 ]; then
echo "Error: Could not find multiple available ports." >&2
exit 1
fi
pd_client_port=${ports[0]}
pd_peer_port=${ports[1]}
start_pd_server $pd_client_port $pd_peer_port $PD_DATA_DIR2 $PD_LOG_FILE2

local ports=($(find_multiple_available_ports 20160 2))
if [ $? -ne 0 ]; then
echo "Error: Could not find multiple available ports." >&2
exit 1
fi
tikv_port=${ports[0]}
tikv_status_port=${ports[1]}
start_tikv_server $pd_client_port $tikv_port $tikv_status_port $TIKV_DATA_DIR2 $TIKV_LOG_FILE2

tidb_port=$(find_available_port 4000)
tidb_status_port=$(find_available_port 10080)
start_tidb_server "127.0.0.1:$pd_client_port" $tidb_port $tidb_status_port $TIDB_LOG_FILE2

echo "TiDB cluster started successfully!"
read -p "Press [Enter] key to go on..."

ticdc_port=$(find_available_port 8300)
start_ticdc_server "http://127.0.0.1:$upstream_pd_client_port" $ticdc_port $tidb_port

echo "TiCDC started successfully!"
read -p "Press [Enter] key to go on..."
echo "tidb-server(PID: $SERVER_PID) started"
}

function run_mysql_tester()
Expand Down Expand Up @@ -474,21 +304,24 @@ function check_case_name() {
check_case_name
if [[ $collation_opt = 0 || $collation_opt = 2 ]]; then
enabled_new_collation=0
else
enabled_new_collation=1
start_tidb_server
run_mysql_tester
kill -15 $SERVER_PID
while ps -p $SERVER_PID > /dev/null; do
sleep 1
done
check_data_race
fi

if [ -z "$START_TIDB_CLUSTER" ]; then
if [[ $collation_opt = 1 || $collation_opt = 2 ]]; then
enabled_new_collation=1
start_tidb_server
else
start_tidb_cluster
run_mysql_tester
kill -15 $SERVER_PID
while ps -p $SERVER_PID > /dev/null; do
sleep 1
done
check_data_race
fi

run_mysql_tester
kill -15 $SERVER_PID
while ps -p $SERVER_PID > /dev/null; do
sleep 1
done
check_data_race

echo "integrationtest passed!"
90 changes: 90 additions & 0 deletions tests/integrationtest2/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
# IntegrationTest

IntegrationTest is a integration test command tool, also with some useful test cases for TiDB execute plan logic, we can run case via `run-tests.sh`.

```
Usage: ./run-tests.sh [options]
-h: Print this help message.
-s <tidb-server-path>: Use tidb-server in <tidb-server-path> for testing.
eg. "./run-tests.sh -s ./integrationtest_tidb-server"
-b <y|Y|n|N>: "y" or "Y" for building test binaries [default "y" if this option is not specified].
"n" or "N" for not to build.
The building of tidb-server will be skiped if "-s <tidb-server-path>" is provided.
-r <test-name>|all: Run tests in file "t/<test-name>.test" and record result to file "r/<test-name>.result".
"all" for running all tests and record their results.
-t <test-name>: Run tests in file "t/<test-name>.test".
This option will be ignored if "-r <test-name>" is provided.
Run all tests if this option is not provided.
-v <vendor-path>: Add <vendor-path> to $GOPATH.
-p <portgenerator-path>: Use port generator in <portgenerator-path> for generating port numbers.
```

## How it works

IntegrationTest will read test case in `t/*.test`, and execute them in TiDB server with `s/*.json` stat, and compare integration result in `r/*.result`.

For convenience, we can generate new `*.result` and `*.json` from execute by use `-r` parameter for `run-tests.sh`

## Usage

### Regression Execute Plan Modification

After modify code and before commit, please run this command under TiDB root folder.

```sh
make dev
```

or

```sh
make integrationtest
```

It will identify execute plan change.

### Generate New Result from Execute

Add a new test file in `t/` folder, file name should ended with `.test`. Or add new test queries at the end of some files. Then run shell below, it will generate results based on last execution.

```sh
cd tests/integrationtest
./run-tests.sh -r [casename]
```

## How to debug integration test

### Visual Studio Code

1. Add or create a configuration to `.vscode/launch.json`, an example is shown below. If you want to change some configurations, such as using `TiKV` to run integration tests or others, you can modify `pkg/config/config.toml.example`.

```json
{
"version": "0.2.0",
"configurations": [
{
"name": "Debug TiDB With Default Config",
"type": "go",
"request": "launch",
"mode": "auto",
"program": "${fileWorkspaceFolder}/cmd/tidb-server",
"args": ["--config=${fileWorkspaceFolder}/pkg/config/config.toml.example"]
}
]
}
```

2. To run `TiDB-Server`, you could bring up **Run and Debug** view, select the **Run and Debug** icon in the **Activity Bar** on the side of VS Code. You can also use shortcut **F5**.

3. Use any mysql client application you like to run SQLs in integration test, the default port is `4000` and default user is `root` without password. Taking `mysql` as an example, you can use `mysql --comments --host 127.0.0.1 --port 4000 -u root` command to do this.

### Goland

You could follow <https://pingcap.github.io/tidb-dev-guide/get-started/setup-an-ide.html#run-or-debug> to run a `TiDB-Server` with or without `TiKV`. Then use any mysql client application you like to run SQLs.
32 changes: 32 additions & 0 deletions tests/integrationtest2/config.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
# Copyright 2021 PingCAP, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

lease = "0"
host = "127.0.0.1"
new_collations_enabled_on_first_bootstrap = true
enable-table-lock = true

[status]
status-host = "127.0.0.1"

[performance]
stats-lease = "0"

[tikv-client.async-commit]
safe-window = 0
allowed-clock-drift = 0

[experimental]
enable-new-charset = true
allow-expression-index = true
Loading

0 comments on commit 3e834e3

Please sign in to comment.