mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-25 09:02:00 +00:00
47 lines
1.4 KiB
Python
47 lines
1.4 KiB
Python
from __future__ import print_function
|
|
|
|
import pytest
|
|
|
|
import helpers
|
|
from helpers.client import QueryRuntimeException
|
|
from helpers.cluster import ClickHouseCluster
|
|
|
|
cluster = ClickHouseCluster(__file__)
|
|
node = cluster.add_instance(
|
|
"node", main_configs=["configs/zookeeper_config.xml"], with_zookeeper=True
|
|
)
|
|
|
|
|
|
@pytest.fixture(scope="module")
|
|
def start_cluster():
|
|
try:
|
|
cluster.start()
|
|
|
|
yield cluster
|
|
finally:
|
|
cluster.shutdown()
|
|
|
|
|
|
def test_fetch_partition_with_outdated_parts(start_cluster):
|
|
node.query(
|
|
"CREATE TABLE simple (date Date, id UInt32) ENGINE = ReplicatedMergeTree('/clickhouse/tables/0/simple', 'node') ORDER BY tuple() PARTITION BY date;"
|
|
)
|
|
node.query("INSERT INTO simple VALUES ('2020-08-27', 1)")
|
|
|
|
node.query(
|
|
"CREATE TABLE simple2 (date Date, id UInt32) ENGINE = ReplicatedMergeTree('/clickhouse/tables/1/simple', 'node') ORDER BY tuple() PARTITION BY date;"
|
|
)
|
|
node.query("INSERT INTO simple2 VALUES ('2020-08-27', 2)")
|
|
node.query("INSERT INTO simple2 VALUES ('2020-08-27', 3)")
|
|
node.query("OPTIMIZE TABLE simple2 FINAL")
|
|
|
|
# until now both tables will have the same part
|
|
|
|
node.query(
|
|
"ALTER TABLE simple2 FETCH PARTITION '2020-08-27' FROM 'zookeeper2:/clickhouse/tables/0/simple';"
|
|
)
|
|
|
|
node.query("ALTER TABLE simple2 ATTACH PARTITION '2020-08-27';")
|
|
|
|
assert node.query("SELECT id FROM simple2 order by id").strip() == "1\n2\n3"
|