2021-01-17 08:48:48 -05:00
|
|
|
start_server {tags {"tracking network"}} {
|
2020-02-14 08:29:00 -05:00
|
|
|
# Create a deferred client we'll use to redirect invalidation
|
|
|
|
# messages to.
|
2020-11-09 15:54:47 -05:00
|
|
|
set rd_redirection [redis_deferring_client]
|
|
|
|
$rd_redirection client id
|
|
|
|
set redir_id [$rd_redirection read]
|
|
|
|
$rd_redirection subscribe __redis__:invalidate
|
|
|
|
$rd_redirection read ; # Consume the SUBSCRIBE reply.
|
2020-02-14 08:29:00 -05:00
|
|
|
|
2020-11-09 15:54:47 -05:00
|
|
|
# Create another client that's not used as a redirection client
|
|
|
|
# We should always keep this client's buffer clean
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
|
|
|
|
# Client to be used for SET and GET commands
|
|
|
|
# We don't read this client's buffer
|
|
|
|
set rd_sg [redis_client]
|
|
|
|
|
|
|
|
proc clean_all {} {
|
|
|
|
uplevel {
|
2021-02-21 02:34:46 -05:00
|
|
|
# We should make r TRACKING off first. If r is in RESP3,
|
|
|
|
# r FLUSH ALL will send us tracking-redir-broken or other
|
|
|
|
# info which will not be consumed.
|
|
|
|
r CLIENT TRACKING off
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd QUIT
|
|
|
|
$rd_redirection QUIT
|
|
|
|
set rd [redis_deferring_client]
|
|
|
|
set rd_redirection [redis_deferring_client]
|
|
|
|
$rd_redirection client id
|
|
|
|
set redir_id [$rd_redirection read]
|
|
|
|
$rd_redirection subscribe __redis__:invalidate
|
|
|
|
$rd_redirection read ; # Consume the SUBSCRIBE reply.
|
|
|
|
r FLUSHALL
|
|
|
|
r HELLO 2
|
|
|
|
r config set tracking-table-max-keys 1000000
|
|
|
|
}
|
|
|
|
}
|
2020-04-22 05:24:19 -04:00
|
|
|
|
2020-02-14 08:29:00 -05:00
|
|
|
test {Clients are able to enable tracking and redirect it} {
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
2020-02-14 08:29:00 -05:00
|
|
|
} {*OK}
|
|
|
|
|
|
|
|
test {The other connection is able to get invalidations} {
|
2021-06-09 08:13:24 -04:00
|
|
|
r SET a{t} 1
|
|
|
|
r SET b{t} 1
|
|
|
|
r GET a{t}
|
|
|
|
r INCR b{t} ; # This key should not be notified, since it wasn't fetched.
|
|
|
|
r INCR a{t}
|
2020-11-09 15:54:47 -05:00
|
|
|
set keys [lindex [$rd_redirection read] 2]
|
2020-02-14 08:29:00 -05:00
|
|
|
assert {[llength $keys] == 1}
|
2021-06-09 08:13:24 -04:00
|
|
|
assert {[lindex $keys 0] eq {a{t}}}
|
2020-02-14 08:29:00 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
test {The client is now able to disable tracking} {
|
|
|
|
# Make sure to add a few more keys in the tracking list
|
|
|
|
# so that we can check for leaks, as a side effect.
|
2021-06-09 08:13:24 -04:00
|
|
|
r MGET a{t} b{t} c{t} d{t} e{t} f{t} g{t}
|
2020-02-14 08:29:00 -05:00
|
|
|
r CLIENT TRACKING off
|
2021-02-21 02:34:46 -05:00
|
|
|
} {*OK}
|
2020-02-14 08:29:00 -05:00
|
|
|
|
|
|
|
test {Clients can enable the BCAST mode with the empty prefix} {
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on BCAST REDIRECT $redir_id
|
2020-02-14 08:29:00 -05:00
|
|
|
} {*OK*}
|
|
|
|
|
|
|
|
test {The connection gets invalidation messages about all the keys} {
|
2021-06-09 08:13:24 -04:00
|
|
|
r MSET a{t} 1 b{t} 2 c{t} 3
|
2020-11-09 15:54:47 -05:00
|
|
|
set keys [lsort [lindex [$rd_redirection read] 2]]
|
2021-06-09 08:13:24 -04:00
|
|
|
assert {$keys eq {a{t} b{t} c{t}}}
|
2020-02-14 08:29:00 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
test {Clients can enable the BCAST mode with prefixes} {
|
|
|
|
r CLIENT TRACKING off
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on BCAST REDIRECT $redir_id PREFIX a: PREFIX b:
|
2020-02-14 08:29:00 -05:00
|
|
|
r MULTI
|
2021-06-09 08:13:24 -04:00
|
|
|
r INCR a:1{t}
|
|
|
|
r INCR a:2{t}
|
|
|
|
r INCR b:1{t}
|
|
|
|
r INCR b:2{t}
|
2021-02-21 02:34:46 -05:00
|
|
|
# we should not get this key
|
2021-06-09 08:13:24 -04:00
|
|
|
r INCR c:1{t}
|
2020-02-14 08:29:00 -05:00
|
|
|
r EXEC
|
|
|
|
# Because of the internals, we know we are going to receive
|
|
|
|
# two separated notifications for the two different prefixes.
|
2020-11-09 15:54:47 -05:00
|
|
|
set keys1 [lsort [lindex [$rd_redirection read] 2]]
|
|
|
|
set keys2 [lsort [lindex [$rd_redirection read] 2]]
|
2020-02-14 08:29:00 -05:00
|
|
|
set keys [lsort [list {*}$keys1 {*}$keys2]]
|
2021-06-09 08:13:24 -04:00
|
|
|
assert {$keys eq {a:1{t} a:2{t} b:1{t} b:2{t}}}
|
2020-02-14 08:29:00 -05:00
|
|
|
}
|
2020-11-09 15:54:47 -05:00
|
|
|
|
2020-02-14 08:29:00 -05:00
|
|
|
test {Adding prefixes to BCAST mode works} {
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on BCAST REDIRECT $redir_id PREFIX c:
|
2020-02-14 08:29:00 -05:00
|
|
|
r INCR c:1234
|
2020-11-09 15:54:47 -05:00
|
|
|
set keys [lsort [lindex [$rd_redirection read] 2]]
|
2020-02-14 08:29:00 -05:00
|
|
|
assert {$keys eq {c:1234}}
|
|
|
|
}
|
|
|
|
|
2020-04-22 05:24:19 -04:00
|
|
|
test {Tracking NOLOOP mode in standard mode works} {
|
|
|
|
r CLIENT TRACKING off
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id NOLOOP
|
2021-06-09 08:13:24 -04:00
|
|
|
r MGET otherkey1{t} loopkey{t} otherkey2{t}
|
|
|
|
$rd_sg SET otherkey1{t} 1; # We should get this
|
|
|
|
r SET loopkey{t} 1 ; # We should not get this
|
|
|
|
$rd_sg SET otherkey2{t} 1; # We should get this
|
2020-04-22 05:24:19 -04:00
|
|
|
# Because of the internals, we know we are going to receive
|
2021-02-21 02:34:46 -05:00
|
|
|
# two separated notifications for the two different keys.
|
2020-11-09 15:54:47 -05:00
|
|
|
set keys1 [lsort [lindex [$rd_redirection read] 2]]
|
|
|
|
set keys2 [lsort [lindex [$rd_redirection read] 2]]
|
2020-04-22 05:24:19 -04:00
|
|
|
set keys [lsort [list {*}$keys1 {*}$keys2]]
|
2021-06-09 08:13:24 -04:00
|
|
|
assert {$keys eq {otherkey1{t} otherkey2{t}}}
|
2020-04-22 05:24:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
test {Tracking NOLOOP mode in BCAST mode works} {
|
|
|
|
r CLIENT TRACKING off
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on BCAST REDIRECT $redir_id NOLOOP
|
|
|
|
$rd_sg SET otherkey1 1; # We should get this
|
2020-04-22 05:24:19 -04:00
|
|
|
r SET loopkey 1 ; # We should not get this
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_sg SET otherkey2 1; # We should get this
|
2021-02-21 02:34:46 -05:00
|
|
|
# Because $rd_sg send command synchronously, we know we are
|
|
|
|
# going to receive two separated notifications.
|
2020-11-09 15:54:47 -05:00
|
|
|
set keys1 [lsort [lindex [$rd_redirection read] 2]]
|
|
|
|
set keys2 [lsort [lindex [$rd_redirection read] 2]]
|
2020-04-22 05:24:19 -04:00
|
|
|
set keys [lsort [list {*}$keys1 {*}$keys2]]
|
|
|
|
assert {$keys eq {otherkey1 otherkey2}}
|
|
|
|
}
|
|
|
|
|
2020-04-22 05:45:34 -04:00
|
|
|
test {Tracking gets notification of expired keys} {
|
|
|
|
r CLIENT TRACKING off
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on BCAST REDIRECT $redir_id NOLOOP
|
2020-04-22 05:45:34 -04:00
|
|
|
r SET mykey myval px 1
|
|
|
|
r SET mykeyotherkey myval ; # We should not get it
|
|
|
|
after 1000
|
2021-02-21 02:34:46 -05:00
|
|
|
set keys [lsort [lindex [$rd_redirection read] 2]]
|
2020-04-22 05:45:34 -04:00
|
|
|
assert {$keys eq {mykey}}
|
|
|
|
}
|
|
|
|
|
2021-06-22 00:35:59 -04:00
|
|
|
test {Tracking gets notification of lazy expired keys} {
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on BCAST REDIRECT $redir_id NOLOOP
|
|
|
|
# Use multi-exec to expose a race where the key gets an two invalidations
|
|
|
|
# in the same event loop, once by the client so filtered by NOLOOP, and
|
|
|
|
# the second one by the lazy expire
|
|
|
|
r MULTI
|
|
|
|
r SET mykey{t} myval px 1
|
|
|
|
r SET mykeyotherkey{t} myval ; # We should not get it
|
|
|
|
r DEBUG SLEEP 0.1
|
|
|
|
r GET mykey{t}
|
|
|
|
r EXEC
|
|
|
|
set keys [lsort [lindex [$rd_redirection read] 2]]
|
|
|
|
assert {$keys eq {mykey{t}}}
|
|
|
|
} {} {needs:debug}
|
|
|
|
|
2020-11-09 15:54:47 -05:00
|
|
|
test {HELLO 3 reply is correct} {
|
|
|
|
set reply [r HELLO 3]
|
2021-01-05 01:29:20 -05:00
|
|
|
assert_equal [dict get $reply proto] 3
|
2020-11-09 15:54:47 -05:00
|
|
|
}
|
|
|
|
|
2020-12-24 02:26:24 -05:00
|
|
|
test {HELLO without protover} {
|
|
|
|
set reply [r HELLO 3]
|
2021-01-05 01:29:20 -05:00
|
|
|
assert_equal [dict get $reply proto] 3
|
2020-12-24 02:26:24 -05:00
|
|
|
|
|
|
|
set reply [r HELLO]
|
2021-01-05 01:29:20 -05:00
|
|
|
assert_equal [dict get $reply proto] 3
|
2020-12-24 02:26:24 -05:00
|
|
|
|
|
|
|
set reply [r HELLO 2]
|
2021-01-05 01:29:20 -05:00
|
|
|
assert_equal [dict get $reply proto] 2
|
2020-12-24 02:26:24 -05:00
|
|
|
|
|
|
|
set reply [r HELLO]
|
2021-01-05 01:29:20 -05:00
|
|
|
assert_equal [dict get $reply proto] 2
|
2020-12-24 02:26:24 -05:00
|
|
|
|
2020-12-24 07:33:53 -05:00
|
|
|
# restore RESP3 for next test
|
|
|
|
r HELLO 3
|
2020-12-24 02:26:24 -05:00
|
|
|
}
|
|
|
|
|
2020-11-09 15:54:47 -05:00
|
|
|
test {RESP3 based basic invalidation} {
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_sg SET key1 2
|
|
|
|
r read
|
|
|
|
} {invalidate key1}
|
|
|
|
|
|
|
|
test {RESP3 tracking redirection} {
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_sg SET key1 2
|
|
|
|
set res [lindex [$rd_redirection read] 2]
|
|
|
|
assert {$res eq {key1}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Invalidations of previous keys can be redirected after switching to RESP3} {
|
2021-02-21 02:34:46 -05:00
|
|
|
r HELLO 2
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
r HELLO 3
|
|
|
|
$rd_sg SET key1 2
|
|
|
|
set res [lindex [$rd_redirection read] 2]
|
|
|
|
assert {$res eq {key1}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Invalidations of new keys can be redirected after switching to RESP3} {
|
|
|
|
r HELLO 3
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_sg SET key1 2
|
|
|
|
set res [lindex [$rd_redirection read] 2]
|
|
|
|
assert {$res eq {key1}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {RESP3 Client gets tracking-redir-broken push message after cached key changed when rediretion client is terminated} {
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_redirection QUIT
|
2021-02-21 02:34:46 -05:00
|
|
|
assert_equal OK [$rd_redirection read]
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_sg SET key1 2
|
|
|
|
set MAX_TRIES 100
|
2021-02-21 02:34:46 -05:00
|
|
|
set res -1
|
|
|
|
for {set i 0} {$i <= $MAX_TRIES && $res < 0} {incr i} {
|
2020-11-09 15:54:47 -05:00
|
|
|
set res [lsearch -exact [r PING] "tracking-redir-broken"]
|
|
|
|
}
|
|
|
|
assert {$res >= 0}
|
2021-02-21 02:34:46 -05:00
|
|
|
# Consume PING reply
|
|
|
|
assert_equal PONG [r read]
|
2020-11-09 15:54:47 -05:00
|
|
|
|
|
|
|
# Reinstantiating after QUIT
|
|
|
|
set rd_redirection [redis_deferring_client]
|
|
|
|
$rd_redirection CLIENT ID
|
|
|
|
set redir_id [$rd_redirection read]
|
|
|
|
$rd_redirection SUBSCRIBE __redis__:invalidate
|
|
|
|
$rd_redirection read ; # Consume the SUBSCRIBE reply
|
2021-02-21 02:34:46 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
test {Different clients can redirect to the same connection} {
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd CLIENT TRACKING on REDIRECT $redir_id
|
2021-02-21 02:34:46 -05:00
|
|
|
assert_equal OK [$rd read] ; # Consume the TRACKING reply
|
2021-06-09 08:13:24 -04:00
|
|
|
$rd_sg MSET key1{t} 1 key2{t} 1
|
|
|
|
r GET key1{t}
|
|
|
|
$rd GET key2{t}
|
2021-02-21 02:34:46 -05:00
|
|
|
assert_equal 1 [$rd read] ; # Consume the GET reply
|
2021-06-09 08:13:24 -04:00
|
|
|
$rd_sg INCR key1{t}
|
|
|
|
$rd_sg INCR key2{t}
|
2020-11-09 15:54:47 -05:00
|
|
|
set res1 [lindex [$rd_redirection read] 2]
|
|
|
|
set res2 [lindex [$rd_redirection read] 2]
|
2021-06-09 08:13:24 -04:00
|
|
|
assert {$res1 eq {key1{t}}}
|
|
|
|
assert {$res2 eq {key2{t}}}
|
2020-11-09 15:54:47 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
test {Different clients using different protocols can track the same key} {
|
|
|
|
$rd HELLO 3
|
2021-02-21 02:34:46 -05:00
|
|
|
set reply [$rd read] ; # Consume the HELLO reply
|
|
|
|
assert_equal 3 [dict get $reply proto]
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd CLIENT TRACKING on
|
2021-02-21 02:34:46 -05:00
|
|
|
assert_equal OK [$rd read] ; # Consume the TRACKING reply
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_sg set key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd GET key1
|
2021-02-21 02:34:46 -05:00
|
|
|
assert_equal 1 [$rd read] ; # Consume the GET reply
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_sg INCR key1
|
|
|
|
set res1 [lindex [$rd_redirection read] 2]
|
|
|
|
$rd PING ; # Non redirecting client has to talk to the server in order to get invalidation message
|
|
|
|
set res2 [lindex [split [$rd read] " "] 1]
|
2021-02-21 02:34:46 -05:00
|
|
|
assert_equal PONG [$rd read] ; # Consume the PING reply, which comes together with the invalidation message
|
2020-11-09 15:54:47 -05:00
|
|
|
assert {$res1 eq {key1}}
|
|
|
|
assert {$res2 eq {key1}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {No invalidation message when using OPTIN option} {
|
|
|
|
r CLIENT TRACKING on OPTIN REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1 ; # This key should not be notified, since OPTIN is on and CLIENT CACHING yes wasn't called
|
|
|
|
$rd_sg SET key1 2
|
|
|
|
# Preparing some message to consume on $rd_redirection so we don't get blocked
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd_sg SET key2 1
|
|
|
|
r GET key2 ; # This key should be notified
|
|
|
|
$rd_sg SET key2 2
|
|
|
|
set res [lindex [$rd_redirection read] 2]
|
|
|
|
assert {$res eq {key2}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Invalidation message sent when using OPTIN option with CLIENT CACHING yes} {
|
|
|
|
r CLIENT TRACKING on OPTIN REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 3
|
|
|
|
r CLIENT CACHING yes
|
|
|
|
r GET key1
|
|
|
|
$rd_sg SET key1 4
|
|
|
|
set res [lindex [$rd_redirection read] 2]
|
|
|
|
assert {$res eq {key1}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Invalidation message sent when using OPTOUT option} {
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on OPTOUT REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_sg SET key1 2
|
|
|
|
set res [lindex [$rd_redirection read] 2]
|
|
|
|
assert {$res eq {key1}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {No invalidation message when using OPTOUT option with CLIENT CACHING no} {
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r CLIENT CACHING no
|
|
|
|
r GET key1 ; # This key should not be notified, since OPTOUT is on and CLIENT CACHING no was called
|
|
|
|
$rd_sg SET key1 2
|
|
|
|
# Preparing some message to consume on $rd_redirection so we don't get blocked
|
|
|
|
$rd_sg SET key2 1
|
|
|
|
r GET key2 ; # This key should be notified
|
|
|
|
$rd_sg SET key2 2
|
|
|
|
set res [lindex [$rd_redirection read] 2]
|
|
|
|
assert {$res eq {key2}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Able to redirect to a RESP3 client} {
|
|
|
|
$rd_redirection UNSUBSCRIBE __redis__:invalidate ; # Need to unsub first before we can do HELLO 3
|
2021-02-21 02:34:46 -05:00
|
|
|
set res [$rd_redirection read] ; # Consume the UNSUBSCRIBE reply
|
|
|
|
assert_equal {__redis__:invalidate} [lindex $res 1]
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_redirection HELLO 3
|
2021-02-21 02:34:46 -05:00
|
|
|
set res [$rd_redirection read] ; # Consume the HELLO reply
|
|
|
|
assert_equal [dict get $reply proto] 3
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_redirection SUBSCRIBE __redis__:invalidate
|
2021-02-21 02:34:46 -05:00
|
|
|
set res [$rd_redirection read] ; # Consume the SUBSCRIBE reply
|
|
|
|
assert_equal {__redis__:invalidate} [lindex $res 1]
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_sg INCR key1
|
|
|
|
set res [lindex [$rd_redirection read] 1]
|
|
|
|
assert {$res eq {key1}}
|
2021-02-21 02:34:46 -05:00
|
|
|
$rd_redirection HELLO 2
|
|
|
|
set res [$rd_redirection read] ; # Consume the HELLO reply
|
|
|
|
assert_equal [dict get $res proto] 2
|
2020-11-09 15:54:47 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
test {After switching from normal tracking to BCAST mode, no invalidation message is produced for pre-BCAST keys} {
|
2021-02-21 02:34:46 -05:00
|
|
|
r CLIENT TRACKING off
|
|
|
|
r HELLO 3
|
|
|
|
r CLIENT TRACKING on
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_sg SET key1 1
|
2021-02-21 02:34:46 -05:00
|
|
|
r GET key1
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on BCAST
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_sg INCR key1
|
2021-02-21 02:34:46 -05:00
|
|
|
set inv_msg [r PING]
|
|
|
|
set ping_reply [r read]
|
2020-11-09 15:54:47 -05:00
|
|
|
assert {$inv_msg eq {invalidate key1}}
|
|
|
|
assert {$ping_reply eq {PONG}}
|
2021-01-08 03:00:35 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
test {BCAST with prefix collisions throw errors} {
|
|
|
|
set r [redis_client]
|
|
|
|
catch {$r CLIENT TRACKING ON BCAST PREFIX FOOBAR PREFIX FOO} output
|
|
|
|
assert_match {ERR Prefix 'FOOBAR'*'FOO'*} $output
|
|
|
|
|
|
|
|
catch {$r CLIENT TRACKING ON BCAST PREFIX FOO PREFIX FOOBAR} output
|
|
|
|
assert_match {ERR Prefix 'FOO'*'FOOBAR'*} $output
|
|
|
|
|
|
|
|
$r CLIENT TRACKING ON BCAST PREFIX FOO PREFIX BAR
|
|
|
|
catch {$r CLIENT TRACKING ON BCAST PREFIX FO} output
|
|
|
|
assert_match {ERR Prefix 'FO'*'FOO'*} $output
|
|
|
|
|
|
|
|
catch {$r CLIENT TRACKING ON BCAST PREFIX BARB} output
|
|
|
|
assert_match {ERR Prefix 'BARB'*'BAR'*} $output
|
|
|
|
|
|
|
|
$r CLIENT TRACKING OFF
|
|
|
|
}
|
2020-11-09 15:54:47 -05:00
|
|
|
|
2020-05-14 05:27:31 -04:00
|
|
|
test {Tracking gets notification on tracking table key eviction} {
|
|
|
|
r CLIENT TRACKING off
|
2020-11-09 15:54:47 -05:00
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id NOLOOP
|
2021-06-09 08:13:24 -04:00
|
|
|
r MSET key1{t} 1 key2{t} 2
|
2020-05-14 05:27:31 -04:00
|
|
|
# Let the server track the two keys for us
|
2021-06-09 08:13:24 -04:00
|
|
|
r MGET key1{t} key2{t}
|
2020-05-14 05:27:31 -04:00
|
|
|
# Force the eviction of all the keys but one:
|
|
|
|
r config set tracking-table-max-keys 1
|
|
|
|
# Note that we may have other keys in the table for this client,
|
|
|
|
# since we disabled/enabled tracking multiple time with the same
|
|
|
|
# ID, and tracking does not do ID cleanups for performance reasons.
|
|
|
|
# So we check that eventually we'll receive one or the other key,
|
|
|
|
# otherwise the test will die for timeout.
|
|
|
|
while 1 {
|
2020-11-09 15:54:47 -05:00
|
|
|
set keys [lindex [$rd_redirection read] 2]
|
2021-06-09 08:13:24 -04:00
|
|
|
if {$keys eq {key1{t}} || $keys eq {key2{t}}} break
|
2020-05-14 05:27:31 -04:00
|
|
|
}
|
|
|
|
# We should receive an expire notification for one of
|
|
|
|
# the two keys (only one must remain)
|
2021-06-09 08:13:24 -04:00
|
|
|
assert {$keys eq {key1{t}} || $keys eq {key2{t}}}
|
2020-05-14 05:27:31 -04:00
|
|
|
}
|
|
|
|
|
2020-11-09 15:54:47 -05:00
|
|
|
test {Invalidation message received for flushall} {
|
|
|
|
clean_all
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_sg FLUSHALL
|
|
|
|
set msg [$rd_redirection read]
|
|
|
|
assert {[lindex msg 2] eq {} }
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Invalidation message received for flushdb} {
|
|
|
|
clean_all
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_sg FLUSHDB
|
|
|
|
set msg [$rd_redirection read]
|
|
|
|
assert {[lindex msg 2] eq {} }
|
|
|
|
}
|
|
|
|
|
2021-04-20 01:16:27 -04:00
|
|
|
test {Test ASYNC flushall} {
|
|
|
|
clean_all
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
r GET key1
|
|
|
|
r GET key2
|
|
|
|
assert_equal [s 0 tracking_total_keys] 2
|
|
|
|
$rd_sg FLUSHALL ASYNC
|
|
|
|
assert_equal [s 0 tracking_total_keys] 0
|
|
|
|
assert_equal [lindex [$rd_redirection read] 2] {}
|
|
|
|
}
|
|
|
|
|
2020-11-09 15:54:47 -05:00
|
|
|
# Keys are defined to be evicted 100 at a time by default.
|
|
|
|
# If after eviction the number of keys still surpasses the limit
|
|
|
|
# defined in tracking-table-max-keys, we increases eviction
|
|
|
|
# effort to 200, and then 300, etc.
|
|
|
|
# This test tests this effort incrementation.
|
|
|
|
test {Server is able to evacuate enough keys when num of keys surpasses limit by more than defined initial effort} {
|
|
|
|
clean_all
|
|
|
|
set NUM_OF_KEYS_TO_TEST 250
|
|
|
|
set TRACKING_TABLE_MAX_KEYS 1
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
for {set i 0} {$i < $NUM_OF_KEYS_TO_TEST} {incr i} {
|
|
|
|
$rd_sg SET key$i $i
|
|
|
|
r GET key$i
|
|
|
|
}
|
|
|
|
r config set tracking-table-max-keys $TRACKING_TABLE_MAX_KEYS
|
|
|
|
# If not enough keys are evicted, we won't get enough invalidation
|
|
|
|
# messages, and "$rd_redirection read" will block.
|
|
|
|
# If too many keys are evicted, we will get too many invalidation
|
|
|
|
# messages, and the assert will fail.
|
|
|
|
for {set i 0} {$i < $NUM_OF_KEYS_TO_TEST - $TRACKING_TABLE_MAX_KEYS} {incr i} {
|
|
|
|
$rd_redirection read
|
|
|
|
}
|
|
|
|
$rd_redirection PING
|
|
|
|
assert {[$rd_redirection read] eq {pong {}}}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {Tracking info is correct} {
|
|
|
|
clean_all
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
$rd_sg SET key2 2
|
|
|
|
r GET key1
|
|
|
|
r GET key2
|
|
|
|
$rd CLIENT TRACKING on BCAST PREFIX prefix:
|
2021-02-21 02:34:46 -05:00
|
|
|
assert [string match *OK* [$rd read]]
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_sg SET prefix:key1 1
|
|
|
|
$rd_sg SET prefix:key2 2
|
|
|
|
set info [r info]
|
|
|
|
regexp "\r\ntracking_total_items:(.*?)\r\n" $info _ total_items
|
|
|
|
regexp "\r\ntracking_total_keys:(.*?)\r\n" $info _ total_keys
|
|
|
|
regexp "\r\ntracking_total_prefixes:(.*?)\r\n" $info _ total_prefixes
|
2021-02-21 02:34:46 -05:00
|
|
|
regexp "\r\ntracking_clients:(.*?)\r\n" $info _ tracking_clients
|
2020-11-09 15:54:47 -05:00
|
|
|
assert {$total_items == 2}
|
|
|
|
assert {$total_keys == 2}
|
|
|
|
assert {$total_prefixes == 1}
|
2021-02-21 02:34:46 -05:00
|
|
|
assert {$tracking_clients == 2}
|
|
|
|
}
|
|
|
|
|
|
|
|
test {CLIENT GETREDIR provides correct client id} {
|
|
|
|
set res [r CLIENT GETREDIR]
|
|
|
|
assert_equal $redir_id $res
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
set res [r CLIENT GETREDIR]
|
|
|
|
assert_equal -1 $res
|
|
|
|
r CLIENT TRACKING on
|
|
|
|
set res [r CLIENT GETREDIR]
|
|
|
|
assert_equal 0 $res
|
2020-11-09 15:54:47 -05:00
|
|
|
}
|
|
|
|
|
2020-12-27 06:14:39 -05:00
|
|
|
test {CLIENT TRACKINGINFO provides reasonable results when tracking off} {
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {off} $flags
|
|
|
|
set redirect [dict get $res redirect]
|
|
|
|
assert_equal {-1} $redirect
|
|
|
|
set prefixes [dict get $res prefixes]
|
|
|
|
assert_equal {} $prefixes
|
|
|
|
}
|
|
|
|
|
|
|
|
test {CLIENT TRACKINGINFO provides reasonable results when tracking on} {
|
|
|
|
r CLIENT TRACKING on
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {on} $flags
|
|
|
|
set redirect [dict get $res redirect]
|
|
|
|
assert_equal {0} $redirect
|
|
|
|
set prefixes [dict get $res prefixes]
|
|
|
|
assert_equal {} $prefixes
|
|
|
|
}
|
|
|
|
|
|
|
|
test {CLIENT TRACKINGINFO provides reasonable results when tracking on with options} {
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id noloop
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {on noloop} $flags
|
|
|
|
set redirect [dict get $res redirect]
|
|
|
|
assert_equal $redir_id $redirect
|
|
|
|
set prefixes [dict get $res prefixes]
|
|
|
|
assert_equal {} $prefixes
|
|
|
|
}
|
|
|
|
|
|
|
|
test {CLIENT TRACKINGINFO provides reasonable results when tracking optin} {
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on optin
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {on optin} $flags
|
|
|
|
set redirect [dict get $res redirect]
|
|
|
|
assert_equal {0} $redirect
|
|
|
|
set prefixes [dict get $res prefixes]
|
|
|
|
assert_equal {} $prefixes
|
|
|
|
|
|
|
|
r CLIENT CACHING yes
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {on optin caching-yes} $flags
|
|
|
|
}
|
|
|
|
|
|
|
|
test {CLIENT TRACKINGINFO provides reasonable results when tracking optout} {
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on optout
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {on optout} $flags
|
|
|
|
set redirect [dict get $res redirect]
|
|
|
|
assert_equal {0} $redirect
|
|
|
|
set prefixes [dict get $res prefixes]
|
|
|
|
assert_equal {} $prefixes
|
|
|
|
|
|
|
|
r CLIENT CACHING no
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {on optout caching-no} $flags
|
|
|
|
}
|
|
|
|
|
|
|
|
test {CLIENT TRACKINGINFO provides reasonable results when tracking bcast mode} {
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on BCAST PREFIX foo PREFIX bar
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {on bcast} $flags
|
|
|
|
set redirect [dict get $res redirect]
|
|
|
|
assert_equal {0} $redirect
|
|
|
|
set prefixes [lsort [dict get $res prefixes]]
|
|
|
|
assert_equal {bar foo} $prefixes
|
2021-02-21 02:34:46 -05:00
|
|
|
|
|
|
|
r CLIENT TRACKING off
|
|
|
|
r CLIENT TRACKING on BCAST
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set prefixes [dict get $res prefixes]
|
|
|
|
assert_equal {{}} $prefixes
|
|
|
|
}
|
|
|
|
|
|
|
|
test {CLIENT TRACKINGINFO provides reasonable results when tracking redir broken} {
|
|
|
|
clean_all
|
|
|
|
r HELLO 3
|
|
|
|
r CLIENT TRACKING on REDIRECT $redir_id
|
|
|
|
$rd_sg SET key1 1
|
|
|
|
r GET key1
|
|
|
|
$rd_redirection QUIT
|
|
|
|
assert_equal OK [$rd_redirection read]
|
|
|
|
$rd_sg SET key1 2
|
|
|
|
set res [lsearch -exact [r read] "tracking-redir-broken"]
|
|
|
|
assert {$res >= 0}
|
|
|
|
set res [r client trackinginfo]
|
|
|
|
set flags [dict get $res flags]
|
|
|
|
assert_equal {on broken_redirect} $flags
|
|
|
|
set redirect [dict get $res redirect]
|
|
|
|
assert_equal $redir_id $redirect
|
|
|
|
set prefixes [dict get $res prefixes]
|
|
|
|
assert_equal {} $prefixes
|
2020-12-27 06:14:39 -05:00
|
|
|
}
|
|
|
|
|
2020-11-09 15:54:47 -05:00
|
|
|
$rd_redirection close
|
|
|
|
$rd close
|
2020-02-14 08:29:00 -05:00
|
|
|
}
|