2021-06-22 05:50:17 -04:00
|
|
|
source tests/support/cli.tcl
|
|
|
|
|
2021-03-01 09:04:44 -05:00
|
|
|
test {CONFIG SET port number} {
|
|
|
|
start_server {} {
|
2021-03-01 13:53:02 -05:00
|
|
|
if {$::tls} { set port_cfg tls-port} else { set port_cfg port }
|
|
|
|
|
2021-03-01 09:04:44 -05:00
|
|
|
# available port
|
|
|
|
set avail_port [find_available_port $::baseport $::portcount]
|
2021-03-01 13:53:02 -05:00
|
|
|
set rd [redis [srv 0 host] [srv 0 port] 0 $::tls]
|
|
|
|
$rd CONFIG SET $port_cfg $avail_port
|
2021-03-01 09:04:44 -05:00
|
|
|
$rd close
|
2021-03-01 13:53:02 -05:00
|
|
|
set rd [redis [srv 0 host] $avail_port 0 $::tls]
|
2021-03-01 09:04:44 -05:00
|
|
|
$rd PING
|
|
|
|
|
|
|
|
# already inuse port
|
2021-03-01 13:53:02 -05:00
|
|
|
catch {$rd CONFIG SET $port_cfg $::test_server_port} e
|
2021-03-01 09:04:44 -05:00
|
|
|
assert_match {*Unable to listen on this port*} $e
|
|
|
|
$rd close
|
|
|
|
|
|
|
|
# make sure server still listening on the previous port
|
2021-03-01 13:53:02 -05:00
|
|
|
set rd [redis [srv 0 host] $avail_port 0 $::tls]
|
2021-03-01 09:04:44 -05:00
|
|
|
$rd PING
|
|
|
|
$rd close
|
|
|
|
}
|
2021-06-09 08:13:24 -04:00
|
|
|
} {} {external:skip}
|
2021-03-01 09:04:44 -05:00
|
|
|
|
|
|
|
test {CONFIG SET bind address} {
|
|
|
|
start_server {} {
|
|
|
|
# non-valid address
|
2021-04-27 11:02:23 -04:00
|
|
|
catch {r CONFIG SET bind "999.999.999.999"} e
|
2021-03-01 09:04:44 -05:00
|
|
|
assert_match {*Failed to bind to specified addresses*} $e
|
|
|
|
|
|
|
|
# make sure server still bound to the previous address
|
2021-03-01 13:53:02 -05:00
|
|
|
set rd [redis [srv 0 host] [srv 0 port] 0 $::tls]
|
2021-03-01 09:04:44 -05:00
|
|
|
$rd PING
|
|
|
|
$rd close
|
|
|
|
}
|
2021-06-09 08:13:24 -04:00
|
|
|
} {} {external:skip}
|
2021-06-22 05:50:17 -04:00
|
|
|
|
|
|
|
start_server {config "minimal.conf" tags {"external:skip"}} {
|
|
|
|
test {Default bind address configuration handling} {
|
|
|
|
# Default is explicit and sane
|
|
|
|
assert_equal "* -::*" [lindex [r CONFIG GET bind] 1]
|
|
|
|
|
|
|
|
# CONFIG REWRITE acknowledges this as a default
|
|
|
|
r CONFIG REWRITE
|
|
|
|
assert_equal 0 [count_message_lines [srv 0 config_file] bind]
|
|
|
|
|
|
|
|
# Removing the bind address works
|
|
|
|
r CONFIG SET bind ""
|
|
|
|
assert_equal "" [lindex [r CONFIG GET bind] 1]
|
|
|
|
|
|
|
|
# No additional clients can connect
|
|
|
|
catch {redis_client} err
|
|
|
|
assert_match {*connection refused*} $err
|
|
|
|
|
|
|
|
# CONFIG REWRITE handles empty bindaddr
|
|
|
|
r CONFIG REWRITE
|
|
|
|
assert_equal 1 [count_message_lines [srv 0 config_file] bind]
|
|
|
|
|
|
|
|
# Make sure we're able to restart
|
|
|
|
restart_server 0 0 0 0
|
|
|
|
|
|
|
|
# Make sure bind parameter is as expected and server handles binding
|
|
|
|
# accordingly.
|
|
|
|
assert_equal {bind {}} [rediscli_exec 0 config get bind]
|
|
|
|
catch {reconnect 0} err
|
|
|
|
assert_match {*connection refused*} $err
|
|
|
|
|
|
|
|
assert_equal {OK} [rediscli_exec 0 config set bind *]
|
|
|
|
reconnect 0
|
|
|
|
r ping
|
|
|
|
} {PONG}
|
|
|
|
|
|
|
|
proc get_nonloopback_addr {} {
|
|
|
|
set addrlist [list {}]
|
|
|
|
catch { set addrlist [exec hostname -I] }
|
|
|
|
return [lindex $addrlist 0]
|
|
|
|
}
|
|
|
|
|
|
|
|
proc get_nonloopback_client {} {
|
|
|
|
return [redis [get_nonloopback_addr] [srv 0 "port"] 0 $::tls]
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Protected mode works as expected} {
|
|
|
|
# Get a non-loopback address of this instance for this test.
|
|
|
|
set myaddr [get_nonloopback_addr]
|
|
|
|
if {$myaddr != "" && ![string match {127.*} $myaddr]} {
|
|
|
|
# Non-loopback client shoudl fail by default
|
|
|
|
set r2 [get_nonloopback_client]
|
|
|
|
catch {$r2 ping} err
|
|
|
|
assert_match {*DENIED*} $err
|
|
|
|
|
|
|
|
# Bind configuration should not matter
|
|
|
|
assert_equal {OK} [r config set bind "*"]
|
|
|
|
set r2 [get_nonloopback_client]
|
|
|
|
catch {$r2 ping} err
|
|
|
|
assert_match {*DENIED*} $err
|
|
|
|
|
|
|
|
# Setting a password should disable protected mode
|
|
|
|
assert_equal {OK} [r config set requirepass "secret"]
|
|
|
|
set r2 [redis $myaddr [srv 0 "port"] 0 $::tls]
|
|
|
|
assert_equal {OK} [$r2 auth secret]
|
|
|
|
assert_equal {PONG} [$r2 ping]
|
|
|
|
|
|
|
|
# Clearing the password re-enables protected mode
|
|
|
|
assert_equal {OK} [r config set requirepass ""]
|
|
|
|
set r2 [redis $myaddr [srv 0 "port"] 0 $::tls]
|
|
|
|
assert_match {*DENIED*} $err
|
|
|
|
|
|
|
|
# Explicitly disabling protected-mode works
|
|
|
|
assert_equal {OK} [r config set protected-mode no]
|
|
|
|
set r2 [redis $myaddr [srv 0 "port"] 0 $::tls]
|
|
|
|
assert_equal {PONG} [$r2 ping]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|