mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-15 10:52:30 +00:00
160 lines
8.1 KiB
Bash
Executable File
160 lines
8.1 KiB
Bash
Executable File
#!/usr/bin/env bash
|
||
|
||
CUR_DIR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
|
||
# shellcheck source=../shell_config.sh
|
||
. "$CUR_DIR"/../shell_config.sh
|
||
|
||
USER_INFOS=('default' '')
|
||
HOSTS_PORTS=("$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP" "$CLICKHOUSE_HOST" "$CLICKHOUSE_HOST:" ":$CLICKHOUSE_PORT_TCP" "127.0.0.1" "127.0.0.1:$CLICKHOUSE_PORT_TCP" "$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP,invalid_host:9000" "[0000:0000:0000:0000:0000:0000:0000:0001]" "[::1]" "[::1]:$CLICKHOUSE_PORT_TCP" "" )
|
||
DATABASES=("$CLICKHOUSE_DATABASE" "")
|
||
|
||
TEST_INDEX=0
|
||
|
||
function runClient()
|
||
{
|
||
$CLICKHOUSE_CLIENT_BINARY "$@" -q "SELECT $TEST_INDEX" --log_comment 02766_connection_string.sh --send_logs_level=warning
|
||
((++TEST_INDEX))
|
||
}
|
||
|
||
function testConnectionString()
|
||
{
|
||
if [ "$database" == "" ]; then
|
||
runClient "clickhouse:$1"
|
||
runClient "clickhouse:$1/"
|
||
else
|
||
runClient "clickhouse:$1/$database"
|
||
fi
|
||
}
|
||
|
||
function testConnectionWithUserName()
|
||
{
|
||
if [ "$user_info" == "" ] && [ "$host_port" == "" ]; then
|
||
testConnectionString "//"
|
||
testConnectionString ""
|
||
else
|
||
testConnectionString "//$user_info@$host_port"
|
||
fi
|
||
}
|
||
|
||
for user_info in "${USER_INFOS[@]}"
|
||
do
|
||
for host_port in "${HOSTS_PORTS[@]}"
|
||
do
|
||
for database in "${DATABASES[@]}"
|
||
do
|
||
testConnectionWithUserName
|
||
done
|
||
done
|
||
done
|
||
|
||
# Specific user and password
|
||
TEST_INDEX=500
|
||
TEST_USER_NAME="test_user_02771_$$"
|
||
TEST_USER_EMAIL_NAME="test_user_02771_$$@some_mail.com"
|
||
TEST_USER_EMAIL_NAME_ENCODED="test_user_02771_$$%40some_mail.com"
|
||
|
||
TEST_USER_PASSWORD="zyx%$&abc"
|
||
# %, $, & percent encoded
|
||
TEST_USER_PASSWORD_ENCODED="zyx%25%24%26abc"
|
||
|
||
$CLICKHOUSE_CLIENT -q "CREATE USER '$TEST_USER_NAME'"
|
||
$CLICKHOUSE_CLIENT -q "CREATE USER '$TEST_USER_EMAIL_NAME' IDENTIFIED WITH plaintext_password BY '$TEST_USER_PASSWORD'"
|
||
|
||
runClient "clickhouse://$TEST_USER_NAME@$CLICKHOUSE_HOST/$CLICKHOUSE_DATABASE"
|
||
runClient "clickhouse://$TEST_USER_EMAIL_NAME_ENCODED:$TEST_USER_PASSWORD_ENCODED@$CLICKHOUSE_HOST/$CLICKHOUSE_DATABASE"
|
||
|
||
$CLICKHOUSE_CLIENT -q "DROP USER '$TEST_USER_NAME'"
|
||
$CLICKHOUSE_CLIENT -q "DROP USER '$TEST_USER_EMAIL_NAME'"
|
||
|
||
# Percent-encoded database in non-ascii symbols
|
||
UTF8_DATABASE="БазаДанных_$$"
|
||
UTF8_DATABASE_PERCENT_ENCODED="%D0%91%D0%B0%D0%B7%D0%B0%D0%94%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_$$"
|
||
$CLICKHOUSE_CLIENT -q "CREATE DATABASE IF NOT EXISTS \`$UTF8_DATABASE\`"
|
||
runClient "clickhouse://default@$CLICKHOUSE_HOST/$UTF8_DATABASE_PERCENT_ENCODED"
|
||
$CLICKHOUSE_CLIENT -q "DROP DATABASE IF EXISTS \`$UTF8_DATABASE\`"
|
||
|
||
# clickhouse-client extra options cases
|
||
TEST_INDEX=1000
|
||
|
||
runClient "clickhouse://$CLICKHOUSE_HOST/" --user 'default'
|
||
runClient "clickhouse://$CLICKHOUSE_HOST/default" --user 'default'
|
||
runClient "clickhouse:" --database "$CLICKHOUSE_DATABASE"
|
||
|
||
# User 'default' and default host
|
||
runClient "clickhouse://default@"
|
||
|
||
# Invalid URI cases
|
||
TEST_INDEX=10000
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST/" --user 'default' 2>&1 | grep -o 'Bad arguments'
|
||
runClient "clickhouse://default:pswrd@$CLICKHOUSE_HOST/" --user 'default' 2>&1 | grep -o 'Bad arguments'
|
||
runClient "clickhouse://default:pswrd@$CLICKHOUSE_HOST/" --password 'pswrd' 2>&1 | grep -o 'Bad arguments'
|
||
runClient "clickhouse:///$CLICKHOUSE_DATABASE" --database "$CLICKHOUSE_DATABASE" 2>&1 | grep -o 'Bad arguments'
|
||
runClient "clickhouse://$CLICKHOUSE_HOST/$CLICKHOUSE_DATABASE" --database "$CLICKHOUSE_DATABASE" 2>&1 | grep -o 'Bad arguments'
|
||
runClient "clickhouse://$CLICKHOUSE_HOST/$CLICKHOUSE_DATABASE?s" --database "$CLICKHOUSE_DATABASE" 2>&1 | grep -o 'Bad arguments'
|
||
runClient "clickhouse:/$CLICKHOUSE_DATABASE?s" --database "$CLICKHOUSE_DATABASE" 2>&1 | grep -o 'Bad arguments'
|
||
|
||
runClient "http://" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "click_house:" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
|
||
TEST_INDEX=1000087
|
||
# Using connection string prohibits to use --host and --port options
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST/" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP/" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP/" --port "$CLICKHOUSE_PORT_TCP" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP/" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP/" --host "$CLICKHOUSE_HOST" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP/" --port "$CLICKHOUSE_PORT_TCP" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST/" --port "$CLICKHOUSE_PORT_TCP" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://$CLICKHOUSE_HOST/" --port "$CLICKHOUSE_PORT_TCP" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://:@$CLICKHOUSE_HOST/" --port "$CLICKHOUSE_PORT_TCP" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://$CLICKHOUSE_HOST/" --port "$CLICKHOUSE_PORT_TCP" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:" --port "$CLICKHOUSE_PORT_TCP" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://" --port "$CLICKHOUSE_PORT_TCP" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:///" --port "$CLICKHOUSE_PORT_TCP" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:///?" --port "$CLICKHOUSE_PORT_TCP" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://:/?" --port "$CLICKHOUSE_PORT_TCP" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:" --database "$CLICKHOUSE_DATABASE" --port "$CLICKHOUSE_PORT_TCP" --host "$CLICKHOUSE_HOST" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
|
||
# Using clickhouse-client and connection is prohibited
|
||
runClient "clickhouse:" --connection "connection" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
|
||
# Space is used in connection string (This is prohibited).
|
||
runClient " clickhouse:" 2>&1 | grep -o 'SYNTAX_ERROR'
|
||
runClient "clickhouse: " 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://host1 /" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://host1, host2/" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://host1 ,host2/" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://host1 host2/" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://host1/ database:" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://user :password@host1" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://user: password@host1" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
|
||
# Connection string is not first argument
|
||
runClient --multiline "clickhouse://default:@$CLICKHOUSE_HOST/" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
# Connection string used as the first and the second argument of client
|
||
runClient "clickhouse://default:@$CLICKHOUSE_HOST/" "clickhouse://default:@$CLICKHOUSE_HOST/" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
|
||
# Invalid hosts
|
||
runClient "clickhouse://host1,,," 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse://," 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
|
||
# Invalid parameters
|
||
runClient "clickhouse:?invalid_parameter" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:?invalid_parameter&secure" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:?s&invalid_parameter" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:?s&invalid_parameter=val" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:?invalid_parameter=arg" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
runClient "clickhouse:?invalid_parameter=arg&s" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
# Several users prohibited
|
||
runClient "clickhouse://user1@localhost,default@localhost/" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
# Using '@' in user name is prohibited. User name should be percent-encoded.
|
||
runClient "clickhouse://my_mail@email.com@host/" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
||
|
||
# Wrong input cases
|
||
TEST_INDEX=100000
|
||
# Invalid user name
|
||
runClient "clickhouse://non_exist_user@$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP/" 2>&1 | grep -o 'Authentication failed'
|
||
# Invalid password
|
||
runClient "clickhouse://default:invalid_password@$CLICKHOUSE_HOST:$CLICKHOUSE_PORT_TCP/" 2>&1 | grep -o 'Authentication failed'
|