redict/tests/unit/moduleapi/keyspecs.tcl
Itamar Haber f810510bb2
Adds utils/gen-commands-json.py (#9958)
Following #9656, this script generates a "commands.json" file from the output
of the new COMMAND. The output of this script is used in redis/redis-doc#1714
and by redis/redis-io#259. This also converts a couple of rogue dashes (in 
'key-specs' and 'multiple-token' flags) to underscores (continues #9959).
2021-12-27 19:31:13 +02:00

67 lines
3.6 KiB
Tcl

set testmodule [file normalize tests/modules/keyspecs.so]
start_server {tags {"modules"}} {
r module load $testmodule
test "Module key specs: Legacy" {
set reply [r command info kspec.legacy]
# Verify (first, last, step)
assert_equal [lindex [lindex $reply 0] 3] 1
assert_equal [lindex [lindex $reply 0] 4] 2
assert_equal [lindex [lindex $reply 0] 5] 1
# create a dict for easy lookup
unset -nocomplain mydict
foreach {k v} [lindex [lindex $reply 0] 7] {
dict append mydict $k $v
}
# Verify key-specs
set keyspecs [dict get $mydict key_specs]
assert_equal [lindex $keyspecs 0] {flags read begin_search {type index spec {index 1}} find_keys {type range spec {lastkey 0 keystep 1 limit 0}}}
assert_equal [lindex $keyspecs 1] {flags write begin_search {type index spec {index 2}} find_keys {type range spec {lastkey 0 keystep 1 limit 0}}}
}
test "Module key specs: Complex specs, case 1" {
set reply [r command info kspec.complex1]
# Verify (first, last, step)
assert_equal [lindex [lindex $reply 0] 3] 1
assert_equal [lindex [lindex $reply 0] 4] 1
assert_equal [lindex [lindex $reply 0] 5] 1
# create a dict for easy lookup
unset -nocomplain mydict
foreach {k v} [lindex [lindex $reply 0] 7] {
dict append mydict $k $v
}
# Verify key-specs
set keyspecs [dict get $mydict key_specs]
assert_equal [lindex $keyspecs 0] {flags {} begin_search {type index spec {index 1}} find_keys {type range spec {lastkey 0 keystep 1 limit 0}}}
assert_equal [lindex $keyspecs 1] {flags write begin_search {type keyword spec {keyword STORE startfrom 2}} find_keys {type range spec {lastkey 0 keystep 1 limit 0}}}
assert_equal [lindex $keyspecs 2] {flags read begin_search {type keyword spec {keyword KEYS startfrom 2}} find_keys {type keynum spec {keynumidx 0 firstkey 1 keystep 1}}}
}
test "Module key specs: Complex specs, case 2" {
set reply [r command info kspec.complex2]
# Verify (first, last, step)
assert_equal [lindex [lindex $reply 0] 3] 1
assert_equal [lindex [lindex $reply 0] 4] 2
assert_equal [lindex [lindex $reply 0] 5] 1
# create a dict for easy lookup
unset -nocomplain mydict
foreach {k v} [lindex [lindex $reply 0] 7] {
dict append mydict $k $v
}
# Verify key-specs
set keyspecs [dict get $mydict key_specs]
assert_equal [lindex $keyspecs 0] {flags write begin_search {type keyword spec {keyword STORE startfrom 5}} find_keys {type range spec {lastkey 0 keystep 1 limit 0}}}
assert_equal [lindex $keyspecs 1] {flags read begin_search {type index spec {index 1}} find_keys {type range spec {lastkey 0 keystep 1 limit 0}}}
assert_equal [lindex $keyspecs 2] {flags read begin_search {type index spec {index 2}} find_keys {type range spec {lastkey 0 keystep 1 limit 0}}}
assert_equal [lindex $keyspecs 3] {flags write begin_search {type index spec {index 3}} find_keys {type keynum spec {keynumidx 0 firstkey 1 keystep 1}}}
assert_equal [lindex $keyspecs 4] {flags write begin_search {type keyword spec {keyword MOREKEYS startfrom 5}} find_keys {type range spec {lastkey -1 keystep 1 limit 0}}}
}
test "Module command list filtering" {
;# Note: we piggyback this tcl file to test the general functionality of command list filtering
set reply [r command list filterby module keyspecs]
assert_equal [lsort $reply] {kspec.complex1 kspec.complex2 kspec.legacy}
}
}