2019-07-24 12:58:15 +03:00
|
|
|
set testmodule [file normalize tests/modules/infotest.so]
|
|
|
|
|
|
|
|
# Return value for INFO property
|
|
|
|
proc field {info property} {
|
|
|
|
if {[regexp "\r\n$property:(.*?)\r\n" $info _ value]} {
|
|
|
|
set _ $value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
start_server {tags {"modules"}} {
|
|
|
|
r module load $testmodule log-key 0
|
|
|
|
|
2019-11-03 15:02:25 +02:00
|
|
|
test {module reading info} {
|
|
|
|
# check string, integer and float fields
|
|
|
|
assert_equal [r info.gets replication role] "master"
|
2019-11-04 07:57:52 +02:00
|
|
|
assert_equal [r info.getc replication role] "master"
|
2019-11-03 15:02:25 +02:00
|
|
|
assert_equal [r info.geti stats expired_keys] 0
|
|
|
|
assert_equal [r info.getd stats expired_stale_perc] 0
|
|
|
|
|
2019-11-04 08:50:29 +02:00
|
|
|
# check signed and unsigned
|
|
|
|
assert_equal [r info.geti infotest infotest_global] -2
|
|
|
|
assert_equal [r info.getu infotest infotest_uglobal] -2
|
|
|
|
|
2019-11-03 15:02:25 +02:00
|
|
|
# the above are always 0, try module info that is non-zero
|
|
|
|
assert_equal [r info.geti infotest_italian infotest_due] 2
|
|
|
|
set tre [r info.getd infotest_italian infotest_tre]
|
|
|
|
assert {$tre > 3.2 && $tre < 3.4 }
|
|
|
|
|
|
|
|
# search using the wrong section
|
|
|
|
catch { [r info.gets badname redis_version] } e
|
|
|
|
assert_match {*not found*} $e
|
|
|
|
|
|
|
|
# check that section filter works
|
|
|
|
assert { [string match "*usec_per_call*" [r info.gets all cmdstat_info.gets] ] }
|
|
|
|
catch { [r info.gets default cmdstat_info.gets] ] } e
|
|
|
|
assert_match {*not found*} $e
|
|
|
|
}
|
|
|
|
|
2019-07-24 12:58:15 +03:00
|
|
|
test {module info all} {
|
|
|
|
set info [r info all]
|
|
|
|
# info all does not contain modules
|
|
|
|
assert { ![string match "*Spanish*" $info] }
|
2019-09-30 20:47:35 +03:00
|
|
|
assert { ![string match "*infotest_*" $info] }
|
2019-07-24 12:58:15 +03:00
|
|
|
assert { [string match "*used_memory*" $info] }
|
|
|
|
}
|
|
|
|
|
|
|
|
test {module info everything} {
|
|
|
|
set info [r info everything]
|
|
|
|
# info everything contains all default sections, but not ones for crash report
|
2019-08-18 10:01:57 +03:00
|
|
|
assert { [string match "*infotest_global*" $info] }
|
2019-07-24 12:58:15 +03:00
|
|
|
assert { [string match "*Spanish*" $info] }
|
|
|
|
assert { [string match "*Italian*" $info] }
|
|
|
|
assert { [string match "*used_memory*" $info] }
|
|
|
|
assert { ![string match "*Klingon*" $info] }
|
|
|
|
field $info infotest_dos
|
|
|
|
} {2}
|
|
|
|
|
|
|
|
test {module info modules} {
|
|
|
|
set info [r info modules]
|
|
|
|
# info all does not contain modules
|
|
|
|
assert { [string match "*Spanish*" $info] }
|
2019-08-18 10:01:57 +03:00
|
|
|
assert { [string match "*infotest_global*" $info] }
|
2019-07-24 12:58:15 +03:00
|
|
|
assert { ![string match "*used_memory*" $info] }
|
|
|
|
}
|
|
|
|
|
|
|
|
test {module info one module} {
|
|
|
|
set info [r info INFOTEST]
|
|
|
|
# info all does not contain modules
|
|
|
|
assert { [string match "*Spanish*" $info] }
|
|
|
|
assert { ![string match "*used_memory*" $info] }
|
2019-08-18 10:01:57 +03:00
|
|
|
field $info infotest_global
|
|
|
|
} {-2}
|
2019-07-24 12:58:15 +03:00
|
|
|
|
|
|
|
test {module info one section} {
|
|
|
|
set info [r info INFOTEST_SPANISH]
|
|
|
|
assert { ![string match "*used_memory*" $info] }
|
|
|
|
assert { ![string match "*Italian*" $info] }
|
2019-08-18 10:01:57 +03:00
|
|
|
assert { ![string match "*infotest_global*" $info] }
|
2019-07-24 12:58:15 +03:00
|
|
|
field $info infotest_uno
|
|
|
|
} {one}
|
|
|
|
|
2019-08-18 09:41:45 +03:00
|
|
|
test {module info dict} {
|
|
|
|
set info [r info infotest_keyspace]
|
|
|
|
set keyspace [field $info infotest_db0]
|
|
|
|
set keys [scan [regexp -inline {keys\=([\d]*)} $keyspace] keys=%d]
|
|
|
|
} {3}
|
2019-07-24 12:58:15 +03:00
|
|
|
|
2021-02-15 17:08:53 +02:00
|
|
|
test {module info unsafe fields} {
|
|
|
|
set info [r info infotest_unsafe]
|
|
|
|
assert_match {*infotest_unsafe_field:value=1*} $info
|
|
|
|
}
|
|
|
|
|
2022-01-23 16:05:06 +08:00
|
|
|
test "Unload the module - infotest" {
|
|
|
|
assert_equal {OK} [r module unload infotest]
|
|
|
|
}
|
|
|
|
|
2019-08-18 09:41:45 +03:00
|
|
|
# TODO: test crash report.
|
2019-07-24 12:58:15 +03:00
|
|
|
}
|