Skip to content

Commit

Permalink
*(ticdc): add integration test for safe mode (#11678)
Browse files Browse the repository at this point in the history
close #11679
  • Loading branch information
lidezhu authored Oct 23, 2024
1 parent 76ebb37 commit ade045e
Show file tree
Hide file tree
Showing 6 changed files with 93 additions and 1 deletion.
2 changes: 1 addition & 1 deletion tests/integration_tests/run_group.sh
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ group_num=${group#G}
# Other tests that only support mysql: batch_update_to_no_batch ddl_reentrant
# changefeed_fast_fail changefeed_resume_with_checkpoint_ts sequence
# multi_cdc_cluster capture_suicide_while_balance_table
mysql_only="bdr_mode capture_suicide_while_balance_table syncpoint syncpoint_check_ts server_config_compatibility changefeed_dup_error_restart"
mysql_only="bdr_mode capture_suicide_while_balance_table syncpoint syncpoint_check_ts server_config_compatibility changefeed_dup_error_restart safe_mode"
mysql_only_http="http_api http_api_tls api_v2 http_api_tls_with_user_auth cli_tls_with_auth"
mysql_only_consistent_replicate="consistent_replicate_ddl consistent_replicate_gbk consistent_replicate_nfs consistent_replicate_storage_file consistent_replicate_storage_file_large_value consistent_replicate_storage_s3 consistent_partition_table"

Expand Down
29 changes: 29 additions & 0 deletions tests/integration_tests/safe_mode/conf/diff_config.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
# diff Configuration.

check-thread-count = 4

export-fix-sql = true

check-struct-only = false

[task]
output-dir = "/tmp/tidb_cdc_test/safe_mode/sync_diff/output"

source-instances = ["mysql1"]

target-instance = "tidb0"

target-check-tables = ["safe_mode.t"]

[data-sources]
[data-sources.mysql1]
host = "127.0.0.1"
port = 4000
user = "root"
password = ""

[data-sources.tidb0]
host = "127.0.0.1"
port = 3306
user = "root"
password = ""
5 changes: 5 additions & 0 deletions tests/integration_tests/safe_mode/data/create_table.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
drop database if exists `safe_mode`;
create database `safe_mode`;
use `safe_mode`;

create table t(id int key, a varchar(200));
3 changes: 3 additions & 0 deletions tests/integration_tests/safe_mode/data/insert.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
use `safe_mode`;
insert into t values(1, "hello");
insert into t values(2, "world");
4 changes: 4 additions & 0 deletions tests/integration_tests/safe_mode/data/update.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
use `safe_mode`;
-- update non key column
update t set a = "hello2" where id = 1;
update t set a = "world2" where id = 2;
51 changes: 51 additions & 0 deletions tests/integration_tests/safe_mode/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
#!/bin/bash

set -eu

CUR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
source $CUR/../_utils/test_prepare
WORK_DIR=$OUT_DIR/$TEST_NAME
CDC_BINARY=cdc.test
SINK_TYPE=$1

function run() {
if [ "$SINK_TYPE" != "mysql" ]; then
return
fi

rm -rf $WORK_DIR && mkdir -p $WORK_DIR

start_tidb_cluster --workdir $WORK_DIR

cd $WORK_DIR

run_sql_file $CUR/data/create_table.sql ${UP_TIDB_HOST} ${UP_TIDB_PORT}
run_sql_file $CUR/data/create_table.sql ${DOWN_TIDB_HOST} ${DOWN_TIDB_PORT}

# insert data into upstream but not downstream
run_sql_file $CUR/data/insert.sql ${UP_TIDB_HOST} ${UP_TIDB_PORT}

run_cdc_server --workdir $WORK_DIR --binary $CDC_BINARY

case $SINK_TYPE in
*) SINK_URI="mysql://normal:[email protected]:3306/?safe-mode=true" ;;
esac
run_cdc_cli changefeed create --sink-uri="$SINK_URI"

# test update sql can be split into delete + replace at all times in safe mode
# otherwise the update sql will have no effect on the downstream and the downstream will have no data.
sleep 10
run_sql_file $CUR/data/update.sql ${UP_TIDB_HOST} ${UP_TIDB_PORT}

run_sql "CREATE TABLE safe_mode.finish_mark (a int primary key);"
sleep 30
check_table_exists "safe_mode.finish_mark" ${DOWN_TIDB_HOST} ${DOWN_TIDB_PORT} 60
check_sync_diff $WORK_DIR $CUR/conf/diff_config.toml

cleanup_process $CDC_BINARY
}

trap stop_tidb_cluster EXIT
run $*
check_logs $WORK_DIR
echo "[$(date)] <<<<<< run test case $TEST_NAME success! >>>>>>"

0 comments on commit ade045e

Please sign in to comment.