ClickHouse/tests/integration/test_undrop_query/test.py

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

59 lines
1.5 KiB
Python
Raw Normal View History

2023-03-21 12:14:26 +00:00
import pytest
import uuid
import random
import logging
import time
from helpers.cluster import ClickHouseCluster
cluster = ClickHouseCluster(__file__)
node = cluster.add_instance("node", main_configs=["configs/with_delay_config.xml"])
@pytest.fixture(scope="module")
def started_cluster():
try:
cluster.start()
yield cluster
finally:
cluster.shutdown()
def test_undrop_drop_and_undrop_loop(started_cluster):
count = 0
while count < 10:
random_sec = random.randint(0, 10)
table_uuid = uuid.uuid1().__str__()
logging.info(
"random_sec: " + random_sec.__str__() + ", table_uuid: " + table_uuid
)
node.query(
2024-03-20 17:04:35 +00:00
"create table test_undrop_loop"
2023-03-21 12:14:26 +00:00
+ count.__str__()
+ " UUID '"
+ table_uuid
2024-03-20 17:04:35 +00:00
+ "' (id Int32) Engine=MergeTree() order by id;"
2023-03-21 12:14:26 +00:00
)
2024-03-20 17:04:35 +00:00
node.query("drop table test_undrop_loop" + count.__str__() + ";")
2023-03-21 12:14:26 +00:00
time.sleep(random_sec)
if random_sec >= 5:
error = node.query_and_get_error(
2024-03-20 17:04:35 +00:00
"undrop table test_undrop_loop"
2023-03-21 12:14:26 +00:00
+ count.__str__()
2024-03-20 17:04:35 +00:00
+ " uuid '"
2023-03-21 12:14:26 +00:00
+ table_uuid
+ "';"
2023-03-21 12:14:26 +00:00
)
assert "UNKNOWN_TABLE" in error
2024-03-20 17:04:35 +00:00
else:
2023-03-21 12:14:26 +00:00
node.query(
2024-03-20 17:04:35 +00:00
"undrop table test_undrop_loop"
2023-03-21 12:14:26 +00:00
+ count.__str__()
2024-03-20 17:04:35 +00:00
+ " uuid '"
2023-03-21 12:14:26 +00:00
+ table_uuid
+ "';"
2023-03-21 12:14:26 +00:00
)
count = count + 1