ClickHouse/tests/queries/0_stateless/01164_detach_attach_partition_race.sh

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

54 lines
1.4 KiB
Bash
Raw Normal View History

2021-11-24 19:45:10 +00:00
#!/usr/bin/env bash
# Tags: race
CURDIR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
# shellcheck source=../shell_config.sh
. "$CURDIR"/../shell_config.sh
$CLICKHOUSE_CLIENT -q "drop table if exists mt"
$CLICKHOUSE_CLIENT -q "create table mt (n int) engine=MergeTree order by n settings parts_to_throw_insert=5000"
2021-11-24 19:45:10 +00:00
$CLICKHOUSE_CLIENT -q "insert into mt values (1)"
$CLICKHOUSE_CLIENT -q "insert into mt values (2)"
$CLICKHOUSE_CLIENT -q "insert into mt values (3)"
function thread_insert()
{
2023-07-07 11:57:12 +00:00
local TIMELIMIT=$((SECONDS+$1))
while [ $SECONDS -lt "$TIMELIMIT" ]; do
$CLICKHOUSE_CLIENT -q "insert into mt values (rand())";
done
2021-11-24 19:45:10 +00:00
}
function thread_detach_attach()
{
2023-07-07 11:57:12 +00:00
local TIMELIMIT=$((SECONDS+$1))
while [ $SECONDS -lt "$TIMELIMIT" ]; do
$CLICKHOUSE_CLIENT -q "alter table mt detach partition id 'all'";
$CLICKHOUSE_CLIENT -q "alter table mt attach partition id 'all'";
done
2021-11-24 19:45:10 +00:00
}
function thread_drop_detached()
{
2023-07-07 11:57:12 +00:00
local TIMELIMIT=$((SECONDS+$1))
while [ $SECONDS -lt "$TIMELIMIT" ]; do
$CLICKHOUSE_CLIENT --allow_drop_detached 1 -q "alter table mt drop detached partition id 'all'";
done
2021-11-24 19:45:10 +00:00
}
export -f thread_insert;
export -f thread_detach_attach;
export -f thread_drop_detached;
2021-11-24 19:45:10 +00:00
TIMEOUT=10
2023-07-07 11:57:12 +00:00
thread_insert $TIMEOUT &
thread_detach_attach $TIMEOUT 2> /dev/null &
thread_detach_attach $TIMEOUT 2> /dev/null &
thread_drop_detached $TIMEOUT 2> /dev/null &
2021-11-24 19:45:10 +00:00
wait
$CLICKHOUSE_CLIENT -q "drop table mt"