mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-18 21:51:57 +00:00
157 lines
8.0 KiB
Bash
157 lines
8.0 KiB
Bash
|
#!/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/" --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:" --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'
|
|||
|
|
|||
|
# Space is used in connection string (This is prohibited).
|
|||
|
runClient " clickhouse:" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
|||
|
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'
|
|||
|
|
|||
|
# Query is not first argument
|
|||
|
runClient --multiline "clickhouse://default:@$CLICKHOUSE_HOST/" 2>&1 | grep -o 'BAD_ARGUMENTS'
|
|||
|
# Query 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'
|