2018-03-29 06:46:13 -04:00
|
|
|
set testmodule [file normalize tests/modules/blockonkeys.so]
|
|
|
|
|
|
|
|
start_server {tags {"modules"}} {
|
|
|
|
r module load $testmodule
|
|
|
|
|
|
|
|
test {Module client blocked on keys (no metadata): No block} {
|
|
|
|
r del k
|
|
|
|
r fsl.push k 33
|
|
|
|
r fsl.push k 34
|
|
|
|
r fsl.bpop2 k 0
|
|
|
|
} {34 33}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (no metadata): Timeout} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
r fsl.push k 33
|
|
|
|
$rd fsl.bpop2 k 1
|
|
|
|
assert_equal {Request timedout} [$rd read]
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (no metadata): Blocked, case 1} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
r fsl.push k 33
|
|
|
|
$rd fsl.bpop2 k 0
|
|
|
|
r fsl.push k 34
|
|
|
|
assert_equal {34 33} [$rd read]
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (no metadata): Blocked, case 2} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
r fsl.push k 33
|
|
|
|
r fsl.push k 34
|
|
|
|
$rd fsl.bpop2 k 0
|
|
|
|
assert_equal {34 33} [$rd read]
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (with metadata): No block} {
|
|
|
|
r del k
|
|
|
|
r fsl.push k 34
|
|
|
|
r fsl.bpopgt k 30 0
|
|
|
|
} {34}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (with metadata): Timeout} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
2019-12-24 06:44:23 -05:00
|
|
|
$rd client id
|
|
|
|
set cid [$rd read]
|
2018-03-29 06:46:13 -04:00
|
|
|
r fsl.push k 33
|
|
|
|
$rd fsl.bpopgt k 35 1
|
|
|
|
assert_equal {Request timedout} [$rd read]
|
2019-12-24 06:44:23 -05:00
|
|
|
r client kill id $cid ;# try to smoke-out client-related memory leak
|
2018-03-29 06:46:13 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (with metadata): Blocked, case 1} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
2019-12-24 06:44:23 -05:00
|
|
|
$rd client id
|
|
|
|
set cid [$rd read]
|
2018-03-29 06:46:13 -04:00
|
|
|
r fsl.push k 33
|
|
|
|
$rd fsl.bpopgt k 33 0
|
|
|
|
r fsl.push k 34
|
|
|
|
assert_equal {34} [$rd read]
|
2019-12-24 06:44:23 -05:00
|
|
|
r client kill id $cid ;# try to smoke-out client-related memory leak
|
2018-03-29 06:46:13 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (with metadata): Blocked, case 2} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
$rd fsl.bpopgt k 35 0
|
|
|
|
r fsl.push k 33
|
|
|
|
r fsl.push k 34
|
|
|
|
r fsl.push k 35
|
|
|
|
r fsl.push k 36
|
|
|
|
assert_equal {36} [$rd read]
|
|
|
|
}
|
|
|
|
|
2019-12-24 06:44:23 -05:00
|
|
|
test {Module client blocked on keys (with metadata): Blocked, CLIENT KILL} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
$rd client id
|
|
|
|
set cid [$rd read]
|
|
|
|
$rd fsl.bpopgt k 35 0
|
|
|
|
r client kill id $cid ;# try to smoke-out client-related memory leak
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (with metadata): Blocked, CLIENT UNBLOCK TIMEOUT} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
$rd client id
|
|
|
|
set cid [$rd read]
|
|
|
|
$rd fsl.bpopgt k 35 0
|
|
|
|
r client unblock $cid timeout ;# try to smoke-out client-related memory leak
|
|
|
|
assert_equal {Request timedout} [$rd read]
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Module client blocked on keys (with metadata): Blocked, CLIENT UNBLOCK ERROR} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
$rd client id
|
|
|
|
set cid [$rd read]
|
|
|
|
$rd fsl.bpopgt k 35 0
|
|
|
|
r client unblock $cid error ;# try to smoke-out client-related memory leak
|
|
|
|
assert_error "*unblocked*" {$rd read}
|
|
|
|
}
|
|
|
|
|
2018-03-29 06:46:13 -04:00
|
|
|
test {Module client blocked on keys does not wake up on wrong type} {
|
|
|
|
r del k
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
$rd fsl.bpop2 k 0
|
|
|
|
r lpush k 12
|
|
|
|
r lpush k 13
|
|
|
|
r lpush k 14
|
|
|
|
r del k
|
|
|
|
r fsl.push k 33
|
|
|
|
r fsl.push k 34
|
|
|
|
assert_equal {34 33} [$rd read]
|
|
|
|
}
|
|
|
|
}
|