ClickHouse/dbms/tests/queries/0_stateless/00633_materialized_view_and_too_many_parts_zookeeper.sh
2019-03-20 23:04:49 +03:00

40 lines
2.2 KiB
Bash
Executable File

#!/usr/bin/env bash
set -e
CURDIR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
. $CURDIR/../shell_config.sh
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.root"
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.a"
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.b"
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.c"
${CLICKHOUSE_CLIENT} --query "CREATE TABLE test.root (d UInt64) ENGINE = ReplicatedMergeTree('/clickhouse/test/root', '1') ORDER BY d"
${CLICKHOUSE_CLIENT} --query "CREATE MATERIALIZED VIEW test.a (d UInt64) ENGINE = ReplicatedMergeTree('/clickhouse/test/a', '1') ORDER BY d AS SELECT * FROM test.root"
${CLICKHOUSE_CLIENT} --query "CREATE MATERIALIZED VIEW test.b (d UInt64) ENGINE = ReplicatedMergeTree('/clickhouse/test/b', '1') ORDER BY d SETTINGS parts_to_delay_insert=1, parts_to_throw_insert=1 AS SELECT * FROM test.root"
${CLICKHOUSE_CLIENT} --query "CREATE MATERIALIZED VIEW test.c (d UInt64) ENGINE = ReplicatedMergeTree('/clickhouse/test/c', '1') ORDER BY d AS SELECT * FROM test.root"
${CLICKHOUSE_CLIENT} --query "INSERT INTO test.root VALUES (1)";
${CLICKHOUSE_CLIENT} --query "SELECT _table, d FROM merge('test', '^[abc]\$') ORDER BY _table"
if ${CLICKHOUSE_CLIENT} --query "INSERT INTO test.root VALUES (2)" 2>/dev/null; then
echo "FAIL\nExpected 'too many parts' on table test.b"
fi
echo
${CLICKHOUSE_CLIENT} --query "SELECT _table, d FROM merge('test', '^[abc]\$') ORDER BY _table"
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.root"
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.a"
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.b"
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.c"
# Deduplication check for non-replicated root table
echo
${CLICKHOUSE_CLIENT} --query "CREATE TABLE test.root (d UInt64) ENGINE = Null"
${CLICKHOUSE_CLIENT} --query "CREATE MATERIALIZED VIEW test.a (d UInt64) ENGINE = ReplicatedMergeTree('/clickhouse/test/a', '1') ORDER BY d AS SELECT * FROM test.root"
${CLICKHOUSE_CLIENT} --query "INSERT INTO test.root VALUES (1)";
${CLICKHOUSE_CLIENT} --query "INSERT INTO test.root VALUES (1)";
${CLICKHOUSE_CLIENT} --query "SELECT * FROM test.a";
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.root"
${CLICKHOUSE_CLIENT} --query "DROP TABLE IF EXISTS test.a"