mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-07 16:14:52 +00:00
b75963d370
This PR formats all the `*.py` files found under the `tests/integration` folder. It also reorders the imports and cleans up a bunch of unused imports. The formatting also takes care of other things like wrapping lines and fixing spaces and indents such that the tests look more readable.
82 lines
2.7 KiB
Python
82 lines
2.7 KiB
Python
import pytest
|
|
from helpers.cluster import ClickHouseCluster
|
|
|
|
cluster = ClickHouseCluster(__file__)
|
|
|
|
node1 = cluster.add_instance('node1', with_zookeeper=True)
|
|
node2 = cluster.add_instance('node2', with_zookeeper=True)
|
|
|
|
# no adaptive granularity by default
|
|
node3 = cluster.add_instance('node3', image='yandex/clickhouse-server', tag='19.9.5.36', with_installed_binary=True,
|
|
stay_alive=True)
|
|
|
|
|
|
@pytest.fixture(scope="module")
|
|
def start_cluster():
|
|
try:
|
|
cluster.start()
|
|
|
|
yield cluster
|
|
finally:
|
|
cluster.shutdown()
|
|
|
|
|
|
def test_attach_detach(start_cluster):
|
|
node1.query("""
|
|
CREATE TABLE test (key UInt64)
|
|
ENGINE = ReplicatedMergeTree('/clickhouse/test', '1')
|
|
ORDER BY tuple()
|
|
SETTINGS index_granularity_bytes = 0""")
|
|
|
|
node1.query("INSERT INTO test VALUES (1), (2)")
|
|
|
|
node2.query("""
|
|
CREATE TABLE test (key UInt64)
|
|
ENGINE = ReplicatedMergeTree('/clickhouse/test', '2')
|
|
ORDER BY tuple() SETTINGS enable_mixed_granularity_parts = 0""")
|
|
|
|
node2.query("INSERT INTO test VALUES (3), (4)")
|
|
|
|
node1.query("SYSTEM SYNC REPLICA test", timeout=10)
|
|
node2.query("SYSTEM SYNC REPLICA test", timeout=10)
|
|
|
|
assert node1.query("SELECT COUNT() FROM test") == "4\n"
|
|
assert node2.query("SELECT COUNT() FROM test") == "4\n"
|
|
|
|
node1.query("DETACH TABLE test")
|
|
node2.query("DETACH TABLE test")
|
|
|
|
node1.query("ATTACH TABLE test")
|
|
node2.query("ATTACH TABLE test")
|
|
|
|
assert node1.query("SELECT COUNT() FROM test") == "4\n"
|
|
assert node2.query("SELECT COUNT() FROM test") == "4\n"
|
|
|
|
|
|
def test_mutate_with_mixed_granularity(start_cluster):
|
|
node3.query("""
|
|
CREATE TABLE test (date Date, key UInt64, value1 String, value2 String)
|
|
ENGINE = MergeTree
|
|
ORDER BY key PARTITION BY date""")
|
|
|
|
node3.query(
|
|
"INSERT INTO test SELECT toDate('2019-10-01') + number % 5, number, toString(number), toString(number * number) FROM numbers(500)")
|
|
|
|
assert node3.query("SELECT COUNT() FROM test") == "500\n"
|
|
|
|
node3.restart_with_latest_version()
|
|
|
|
assert node3.query("SELECT COUNT() FROM test") == "500\n"
|
|
|
|
node3.query("ALTER TABLE test MODIFY SETTING enable_mixed_granularity_parts = 1")
|
|
|
|
node3.query(
|
|
"INSERT INTO test SELECT toDate('2019-10-01') + number % 5, number, toString(number), toString(number * number) FROM numbers(500, 500)")
|
|
|
|
assert node3.query("SELECT COUNT() FROM test") == "1000\n"
|
|
assert node3.query("SELECT COUNT() FROM test WHERE key % 100 == 0") == "10\n"
|
|
|
|
node3.query("ALTER TABLE test DELETE WHERE key % 100 == 0", settings={"mutations_sync": "2"})
|
|
|
|
assert node3.query("SELECT COUNT() FROM test WHERE key % 100 == 0") == "0\n"
|