mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-30 11:32:03 +00:00
52 lines
1.7 KiB
Python
52 lines
1.7 KiB
Python
import pytest
|
|
from helpers.cluster import ClickHouseCluster
|
|
import logging
|
|
|
|
cluster = ClickHouseCluster(__file__)
|
|
node = cluster.add_instance(
|
|
"node", main_configs=["configs/overrides.xml", "configs/clusters.xml"]
|
|
)
|
|
|
|
|
|
@pytest.fixture(scope="module")
|
|
def start_cluster():
|
|
try:
|
|
logging.info("Starting cluster...")
|
|
cluster.start()
|
|
logging.info("Cluster started")
|
|
|
|
yield cluster
|
|
finally:
|
|
cluster.shutdown()
|
|
|
|
|
|
def test_distibuted_settings(start_cluster):
|
|
node.query("")
|
|
node.query(
|
|
"""
|
|
CREATE TABLE data_1 (key Int) ENGINE Memory();
|
|
CREATE TABLE dist_1 as data_1 ENGINE Distributed(localhost_cluster, default, data_1) SETTINGS flush_on_detach = true;
|
|
SYSTEM STOP DISTRIBUTED SENDS dist_1;
|
|
INSERT INTO dist_1 SETTINGS prefer_localhost_replica=0 VALUES (1);
|
|
DETACH TABLE dist_1;
|
|
"""
|
|
)
|
|
assert "flush_on_detach = true" in node.query("SHOW CREATE dist_1")
|
|
# flush_on_detach=true, so data_1 should have 1 row
|
|
assert int(node.query("SELECT count() FROM data_1")) == 1
|
|
|
|
node.query(
|
|
"""
|
|
CREATE TABLE data_2 (key Int) ENGINE Memory();
|
|
CREATE TABLE dist_2 as data_2 ENGINE Distributed(localhost_cluster, default, data_2);
|
|
SYSTEM STOP DISTRIBUTED SENDS dist_2;
|
|
INSERT INTO dist_2 SETTINGS prefer_localhost_replica=0 VALUES (2);
|
|
DETACH TABLE dist_2;
|
|
"""
|
|
)
|
|
## Settings are not added to CREATE (only specific one, like index_granularity for MergeTree)
|
|
# assert "flush_on_detach = 0" in node.query("SHOW CREATE dist_2")
|
|
|
|
# But settins are applied (flush_on_detach=false in config, so data_2 should not have any rows)
|
|
assert int(node.query("SELECT count() FROM data_2")) == 0
|