2019-09-12 03:56:54 -04:00
|
|
|
source tests/support/cli.tcl
|
|
|
|
|
2016-11-18 07:10:29 -05:00
|
|
|
start_server {tags {"wait"}} {
|
|
|
|
start_server {} {
|
|
|
|
set slave [srv 0 client]
|
|
|
|
set slave_host [srv 0 host]
|
|
|
|
set slave_port [srv 0 port]
|
|
|
|
set master [srv -1 client]
|
|
|
|
set master_host [srv -1 host]
|
|
|
|
set master_port [srv -1 port]
|
|
|
|
|
|
|
|
test {Setup slave} {
|
|
|
|
$slave slaveof $master_host $master_port
|
|
|
|
wait_for_condition 50 100 {
|
|
|
|
[s 0 master_link_status] eq {up}
|
|
|
|
} else {
|
|
|
|
fail "Replication not started."
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {WAIT should acknowledge 1 additional copy of the data} {
|
|
|
|
$master set foo 0
|
|
|
|
$master incr foo
|
|
|
|
$master incr foo
|
|
|
|
$master incr foo
|
|
|
|
assert {[$master wait 1 5000] == 1}
|
|
|
|
assert {[$slave get foo] == 3}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {WAIT should not acknowledge 2 additional copies of the data} {
|
|
|
|
$master incr foo
|
|
|
|
assert {[$master wait 2 1000] <= 1}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {WAIT should not acknowledge 1 additional copy if slave is blocked} {
|
2020-08-23 03:17:43 -04:00
|
|
|
set cmd [rediscli $slave_host $slave_port "debug sleep 5"]
|
2019-09-12 03:56:54 -04:00
|
|
|
exec {*}$cmd > /dev/null 2> /dev/null &
|
2016-11-18 07:10:29 -05:00
|
|
|
after 1000 ;# Give redis-cli the time to execute the command.
|
|
|
|
$master set foo 0
|
|
|
|
$master incr foo
|
|
|
|
$master incr foo
|
|
|
|
$master incr foo
|
|
|
|
assert {[$master wait 1 3000] == 0}
|
|
|
|
}
|
2021-01-08 02:36:54 -05:00
|
|
|
|
|
|
|
test {WAIT implicitly blocks on client pause since ACKs aren't sent} {
|
|
|
|
$master multi
|
|
|
|
$master incr foo
|
|
|
|
$master client pause 10000 write
|
|
|
|
$master exec
|
|
|
|
assert {[$master wait 1 1000] == 0}
|
|
|
|
$master client unpause
|
|
|
|
assert {[$master wait 1 1000] == 1}
|
|
|
|
}
|
2016-11-18 07:10:29 -05:00
|
|
|
}}
|