2019-10-21 17:09:41 +00:00
|
|
|
#!/usr/bin/env bash
|
2021-09-12 12:35:27 +00:00
|
|
|
# Tags: no-replicated-database, no-parallel, no-fasttest
|
|
|
|
# Tag no-replicated-database: grep -c
|
2019-10-21 17:09:41 +00:00
|
|
|
|
|
|
|
CURDIR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
|
2020-12-28 11:46:53 +00:00
|
|
|
# shellcheck source=../shell_config.sh
|
2020-08-01 00:51:12 +00:00
|
|
|
. "$CURDIR"/../shell_config.sh
|
2019-10-21 17:09:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
$CLICKHOUSE_CLIENT -q "DROP DICTIONARY IF EXISTS dict1"
|
|
|
|
|
|
|
|
# Simple layout, but with two keys
|
|
|
|
$CLICKHOUSE_CLIENT -q "
|
|
|
|
CREATE DICTIONARY dict1
|
|
|
|
(
|
|
|
|
key1 UInt64,
|
|
|
|
key2 UInt64,
|
|
|
|
value String
|
|
|
|
)
|
|
|
|
PRIMARY KEY key1, key2
|
|
|
|
LAYOUT(HASHED())
|
2020-12-18 13:26:11 +00:00
|
|
|
SOURCE(CLICKHOUSE(HOST 'localhost' PORT tcpPort() USER 'default' TABLE 'table_for_dict1' DB '$CLICKHOUSE_DATABASE'))
|
2019-10-21 17:09:41 +00:00
|
|
|
LIFETIME(MIN 1 MAX 10)
|
|
|
|
" 2>&1 | grep -c 'Primary key for simple dictionary must contain exactly one element'
|
|
|
|
|
|
|
|
|
|
|
|
# Simple layout, but with non existing key
|
|
|
|
$CLICKHOUSE_CLIENT -q "
|
|
|
|
CREATE DICTIONARY dict1
|
|
|
|
(
|
|
|
|
key1 UInt64,
|
|
|
|
key2 UInt64,
|
|
|
|
value String
|
|
|
|
)
|
|
|
|
PRIMARY KEY non_existing_column
|
|
|
|
LAYOUT(HASHED())
|
2020-12-18 13:26:11 +00:00
|
|
|
SOURCE(CLICKHOUSE(HOST 'localhost' PORT tcpPort() USER 'default' TABLE 'table_for_dict1' DB '$CLICKHOUSE_DATABASE'))
|
2019-10-21 17:09:41 +00:00
|
|
|
LIFETIME(MIN 1 MAX 10)
|
|
|
|
" 2>&1 | grep -c "Unknown key attribute 'non_existing_column'"
|
|
|
|
|
|
|
|
# Complex layout, with non existing key
|
|
|
|
$CLICKHOUSE_CLIENT -q "
|
|
|
|
CREATE DICTIONARY dict1
|
|
|
|
(
|
|
|
|
key1 UInt64,
|
|
|
|
key2 UInt64,
|
|
|
|
value String
|
|
|
|
)
|
|
|
|
PRIMARY KEY non_existing_column, key1
|
|
|
|
LAYOUT(COMPLEX_KEY_HASHED())
|
2020-12-18 13:26:11 +00:00
|
|
|
SOURCE(CLICKHOUSE(HOST 'localhost' PORT tcpPort() USER 'default' TABLE 'table_for_dict1' DB '$CLICKHOUSE_DATABASE'))
|
2019-10-21 17:09:41 +00:00
|
|
|
LIFETIME(MIN 1 MAX 10)
|
|
|
|
" 2>&1 | grep -c "Unknown key attribute 'non_existing_column'"
|
|
|
|
|
|
|
|
# No layout
|
|
|
|
$CLICKHOUSE_CLIENT -q "
|
|
|
|
CREATE DICTIONARY dict1
|
|
|
|
(
|
|
|
|
key1 UInt64,
|
|
|
|
key2 UInt64,
|
|
|
|
value String
|
|
|
|
)
|
|
|
|
PRIMARY KEY key2, key1
|
2020-12-18 13:26:11 +00:00
|
|
|
SOURCE(CLICKHOUSE(HOST 'localhost' PORT tcpPort() USER 'default' TABLE 'table_for_dict1' DB '$CLICKHOUSE_DATABASE'))
|
2019-10-21 17:09:41 +00:00
|
|
|
LIFETIME(MIN 1 MAX 10)
|
|
|
|
" 2>&1 | grep -c "Cannot create dictionary with empty layout"
|
|
|
|
|
|
|
|
# No PK
|
|
|
|
$CLICKHOUSE_CLIENT -q "
|
|
|
|
CREATE DICTIONARY dict1
|
|
|
|
(
|
|
|
|
key1 UInt64,
|
|
|
|
key2 UInt64,
|
|
|
|
value String
|
|
|
|
)
|
|
|
|
LAYOUT(COMPLEX_KEY_HASHED())
|
2020-12-18 13:26:11 +00:00
|
|
|
SOURCE(CLICKHOUSE(HOST 'localhost' PORT tcpPort() USER 'default' TABLE 'table_for_dict1' DB '$CLICKHOUSE_DATABASE'))
|
2019-10-21 17:09:41 +00:00
|
|
|
LIFETIME(MIN 1 MAX 10)
|
|
|
|
" 2>&1 | grep -c "Cannot create dictionary without primary key"
|
|
|
|
|
|
|
|
# No lifetime
|
|
|
|
$CLICKHOUSE_CLIENT -q "
|
|
|
|
CREATE DICTIONARY dict1
|
|
|
|
(
|
|
|
|
key1 UInt64,
|
|
|
|
key2 UInt64,
|
|
|
|
value String
|
|
|
|
)
|
|
|
|
PRIMARY KEY key2, key1
|
|
|
|
LAYOUT(COMPLEX_KEY_HASHED())
|
2020-12-18 13:26:11 +00:00
|
|
|
SOURCE(CLICKHOUSE(HOST 'localhost' PORT tcpPort() USER 'default' TABLE 'table_for_dict1' DB '$CLICKHOUSE_DATABASE'))
|
2019-10-21 17:09:41 +00:00
|
|
|
" 2>&1 | grep -c "Cannot create dictionary with empty lifetime"
|
|
|
|
|
|
|
|
# No source
|
|
|
|
$CLICKHOUSE_CLIENT -q "
|
|
|
|
CREATE DICTIONARY dict1
|
|
|
|
(
|
|
|
|
key1 UInt64,
|
|
|
|
key2 UInt64,
|
|
|
|
value String
|
|
|
|
)
|
|
|
|
PRIMARY KEY non_existing_column, key1
|
|
|
|
LAYOUT(COMPLEX_KEY_HASHED())
|
|
|
|
LIFETIME(MIN 1 MAX 10)
|
|
|
|
" 2>&1 | grep -c "Cannot create dictionary with empty source"
|
|
|
|
|
|
|
|
|
|
|
|
# Complex layout, but with one key
|
|
|
|
$CLICKHOUSE_CLIENT -q "
|
|
|
|
CREATE DICTIONARY dict1
|
|
|
|
(
|
|
|
|
key1 UInt64,
|
|
|
|
key2 UInt64,
|
|
|
|
value String
|
|
|
|
)
|
|
|
|
PRIMARY KEY key1
|
|
|
|
LAYOUT(COMPLEX_KEY_HASHED())
|
2020-12-18 13:26:11 +00:00
|
|
|
SOURCE(CLICKHOUSE(HOST 'localhost' PORT tcpPort() USER 'default' TABLE 'table_for_dict1' DB '$CLICKHOUSE_DATABASE'))
|
2019-10-21 17:09:41 +00:00
|
|
|
LIFETIME(MIN 1 MAX 10)
|
|
|
|
" || exit 1
|
|
|
|
|
|
|
|
|
|
|
|
$CLICKHOUSE_CLIENT -q "DROP DICTIONARY IF EXISTS dict1"
|