#!/usr/bin/expect -f

log_user 0
set timeout 5
match_max 100000
# A default timeout action is to do nothing, change it to fail
expect_after {
    timeout {
        exit 1
    }
}

set basedir [file dirname $argv0]
spawn bash -c "source $basedir/../shell_config.sh ; \$CLICKHOUSE_CLIENT_BINARY \$CLICKHOUSE_CLIENT_OPT"
expect ":) "

send -- "DROP TABLE IF EXISTS test_01179\r"
expect "Ok."

send -- "CREATE TABLE test_01179 (date DateTime) ENGINE=Memory()\r"
expect "Ok."

send -- "INSERT INTO test_01179 values ('2020-01-01')\r"
expect "Ok."

send -- "INSERT INTO test_01179 values ('2020-01-01'); \r"
expect "Ok."

send -- "INSERT INTO test_01179 values ('2020-01-01'); (1) \r"
expect "Cannot read data after semicolon"

send -- "SELECT date, count() FROM test_01179 GROUP BY date FORMAT TSV\r"
expect "2020-01-01 00:00:00\t3"

send -- "DROP TABLE test_01179\r"
expect "Ok."

send -- "\4"
expect eof