mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-18 04:12:19 +00:00
Add missing tests
This commit is contained in:
parent
d502a217e5
commit
caccc6da37
1
tests/integration/test_optimize_on_insert/__init__.py
Normal file
1
tests/integration/test_optimize_on_insert/__init__.py
Normal file
@ -0,0 +1 @@
|
|||||||
|
#!/usr/bin/env python3
|
48
tests/integration/test_optimize_on_insert/test.py
Normal file
48
tests/integration/test_optimize_on_insert/test.py
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
from helpers.client import QueryRuntimeException
|
||||||
|
from helpers.cluster import ClickHouseCluster
|
||||||
|
|
||||||
|
cluster = ClickHouseCluster(__file__)
|
||||||
|
node1 = cluster.add_instance('node1', with_zookeeper=True)
|
||||||
|
node2 = cluster.add_instance('node2', with_zookeeper=True)
|
||||||
|
|
||||||
|
@pytest.fixture(scope="module")
|
||||||
|
def start_cluster():
|
||||||
|
try:
|
||||||
|
cluster.start()
|
||||||
|
|
||||||
|
yield cluster
|
||||||
|
|
||||||
|
finally:
|
||||||
|
cluster.shutdown()
|
||||||
|
|
||||||
|
|
||||||
|
def get_data_files_for_table(node, table_name):
|
||||||
|
raw_output = node.exec_in_container(["bash", "-c", "ls /var/lib/clickhouse/data/default/{}".format(table_name)])
|
||||||
|
return raw_output.strip().split("\n")
|
||||||
|
|
||||||
|
def test_empty_parts_optimize(start_cluster):
|
||||||
|
for n, node in enumerate([node1, node2]):
|
||||||
|
node.query("""
|
||||||
|
CREATE TABLE empty (key UInt32, val UInt32, date Datetime)
|
||||||
|
ENGINE=ReplicatedSummingMergeTree('/clickhouse/01560_optimize_on_insert', '{}', val)
|
||||||
|
PARTITION BY date ORDER BY key;
|
||||||
|
""".format(n+1))
|
||||||
|
|
||||||
|
node1.query("INSERT INTO empty VALUES (1, 1, '2020-01-01'), (1, 1, '2020-01-01'), (1, -2, '2020-01-01')")
|
||||||
|
|
||||||
|
node2.query("SYSTEM SYNC REPLICA empty", timeout=15)
|
||||||
|
|
||||||
|
assert node1.query("SELECT * FROM empty") == ""
|
||||||
|
assert node2.query("SELECT * FROM empty") == ""
|
||||||
|
|
||||||
|
# No other tmp files exists
|
||||||
|
assert set(get_data_files_for_table(node1, "empty")) == {"detached", "format_version.txt"}
|
||||||
|
assert set(get_data_files_for_table(node2, "empty")) == {"detached", "format_version.txt"}
|
||||||
|
|
||||||
|
node1.query("INSERT INTO empty VALUES (1, 1, '2020-02-01'), (1, 1, '2020-02-01'), (1, -2, '2020-02-01')", settings={"insert_quorum": 2})
|
||||||
|
|
||||||
|
assert node1.query("SELECT * FROM empty") == ""
|
||||||
|
assert node2.query("SELECT * FROM empty") == ""
|
@ -0,0 +1 @@
|
|||||||
|
Check creating empty parts
|
@ -0,0 +1,36 @@
|
|||||||
|
DROP TABLE IF EXISTS empty1;
|
||||||
|
DROP TABLE IF EXISTS empty2;
|
||||||
|
|
||||||
|
SELECT 'Check creating empty parts';
|
||||||
|
|
||||||
|
CREATE TABLE empty1 (key UInt32, val UInt32, date Datetime)
|
||||||
|
ENGINE=ReplicatedSummingMergeTree('/clickhouse/01560_optimize_on_insert', '1', val)
|
||||||
|
PARTITION BY date ORDER BY key;
|
||||||
|
|
||||||
|
CREATE TABLE empty2 (key UInt32, val UInt32, date Datetime)
|
||||||
|
ENGINE=ReplicatedSummingMergeTree('/clickhouse/01560_optimize_on_insert', '2', val)
|
||||||
|
PARTITION BY date ORDER BY key;
|
||||||
|
|
||||||
|
INSERT INTO empty2 VALUES (1, 1, '2020-01-01'), (1, 1, '2020-01-01'), (1, -2, '2020-01-01');
|
||||||
|
|
||||||
|
SYSTEM SYNC REPLICA empty1;
|
||||||
|
|
||||||
|
SELECT * FROM empty1 ORDER BY key;
|
||||||
|
SELECT * FROM empty2 ORDER BY key;
|
||||||
|
|
||||||
|
SELECT table, partition, active FROM system.parts where table = 'empty1' and database=currentDatabase() and active = 1;
|
||||||
|
SELECT table, partition, active FROM system.parts where table = 'empty2' and database=currentDatabase() and active = 1;
|
||||||
|
|
||||||
|
DETACH table empty1;
|
||||||
|
DETACH table empty2;
|
||||||
|
ATTACH table empty1;
|
||||||
|
ATTACH table empty2;
|
||||||
|
|
||||||
|
SELECT * FROM empty1 ORDER BY key;
|
||||||
|
SELECT * FROM empty2 ORDER BY key;
|
||||||
|
|
||||||
|
SELECT table, partition, active FROM system.parts where table = 'empty1' and database=currentDatabase() and active = 1;
|
||||||
|
SELECT table, partition, active FROM system.parts where table = 'empty2' and database=currentDatabase() and active = 1;
|
||||||
|
|
||||||
|
DROP TABLE IF EXISTS empty1;
|
||||||
|
DROP TABLE IF EXISTS empty2;
|
Loading…
Reference in New Issue
Block a user