2019-10-24 09:38:52 +03:00
|
|
|
set testmodule [file normalize tests/modules/misc.so]
|
|
|
|
|
|
|
|
start_server {tags {"modules"}} {
|
|
|
|
r module load $testmodule
|
|
|
|
|
|
|
|
test {test RM_Call} {
|
|
|
|
set info [r test.call_info commandstats]
|
|
|
|
# cmdstat is not in a default section, so we also test an argument was passed
|
|
|
|
assert { [string match "*cmdstat_module*" $info] }
|
|
|
|
}
|
|
|
|
|
|
|
|
test {test RM_Call args array} {
|
|
|
|
set info [r test.call_generic info commandstats]
|
|
|
|
# cmdstat is not in a default section, so we also test an argument was passed
|
|
|
|
assert { [string match "*cmdstat_module*" $info] }
|
|
|
|
}
|
|
|
|
|
2021-02-28 13:11:18 +01:00
|
|
|
test {test RM_Call recursive} {
|
|
|
|
set info [r test.call_generic test.call_generic info commandstats]
|
|
|
|
assert { [string match "*cmdstat_module*" $info] }
|
|
|
|
}
|
|
|
|
|
2020-10-11 17:21:58 +03:00
|
|
|
test {test redis version} {
|
|
|
|
set version [s redis_version]
|
|
|
|
assert_equal $version [r test.redisversion]
|
|
|
|
}
|
|
|
|
|
2019-11-04 18:04:35 +01:00
|
|
|
test {test long double conversions} {
|
|
|
|
set ld [r test.ld_conversion]
|
|
|
|
assert {[string match $ld "0.00000000000000001"]}
|
|
|
|
}
|
|
|
|
|
2019-11-04 19:30:31 +02:00
|
|
|
test {test module db commands} {
|
|
|
|
r set x foo
|
|
|
|
set key [r test.randomkey]
|
|
|
|
assert_equal $key "x"
|
|
|
|
assert_equal [r test.dbsize] 1
|
|
|
|
r test.flushall
|
|
|
|
assert_equal [r test.dbsize] 0
|
|
|
|
}
|
|
|
|
|
2021-10-18 21:21:19 +02:00
|
|
|
test {test module keyexists} {
|
|
|
|
r set x foo
|
|
|
|
assert_equal 1 [r test.keyexists x]
|
|
|
|
r del x
|
|
|
|
assert_equal 0 [r test.keyexists x]
|
|
|
|
}
|
|
|
|
|
2021-06-10 20:39:33 +08:00
|
|
|
test {test module lru api} {
|
2019-11-10 09:04:39 +02:00
|
|
|
r config set maxmemory-policy allkeys-lru
|
2019-11-04 19:30:31 +02:00
|
|
|
r set x foo
|
|
|
|
set lru [r test.getlru x]
|
2019-11-10 09:04:39 +02:00
|
|
|
assert { $lru <= 1000 }
|
|
|
|
set was_set [r test.setlru x 100000]
|
|
|
|
assert { $was_set == 1 }
|
2019-11-04 19:30:31 +02:00
|
|
|
set idle [r object idletime x]
|
|
|
|
assert { $idle >= 100 }
|
|
|
|
set lru [r test.getlru x]
|
2019-11-10 09:04:39 +02:00
|
|
|
assert { $lru >= 100000 }
|
|
|
|
r config set maxmemory-policy allkeys-lfu
|
|
|
|
set lru [r test.getlru x]
|
|
|
|
assert { $lru == -1 }
|
|
|
|
set was_set [r test.setlru x 100000]
|
|
|
|
assert { $was_set == 0 }
|
2019-11-04 19:30:31 +02:00
|
|
|
}
|
2019-11-10 09:04:39 +02:00
|
|
|
r config set maxmemory-policy allkeys-lru
|
|
|
|
|
2021-06-10 20:39:33 +08:00
|
|
|
test {test module lfu api} {
|
2019-11-10 09:04:39 +02:00
|
|
|
r config set maxmemory-policy allkeys-lfu
|
|
|
|
r set x foo
|
|
|
|
set lfu [r test.getlfu x]
|
|
|
|
assert { $lfu >= 1 }
|
|
|
|
set was_set [r test.setlfu x 100]
|
|
|
|
assert { $was_set == 1 }
|
|
|
|
set freq [r object freq x]
|
|
|
|
assert { $freq <= 100 }
|
|
|
|
set lfu [r test.getlfu x]
|
|
|
|
assert { $lfu <= 100 }
|
|
|
|
r config set maxmemory-policy allkeys-lru
|
|
|
|
set lfu [r test.getlfu x]
|
|
|
|
assert { $lfu == -1 }
|
|
|
|
set was_set [r test.setlfu x 100]
|
|
|
|
assert { $was_set == 0 }
|
|
|
|
}
|
|
|
|
|
2020-08-17 17:46:54 +03:00
|
|
|
test {test module clientinfo api} {
|
|
|
|
# Test basic sanity and SSL flag
|
|
|
|
set info [r test.clientinfo]
|
|
|
|
set ssl_flag [expr $::tls ? {"ssl:"} : {":"}]
|
|
|
|
|
|
|
|
assert { [dict get $info db] == 9 }
|
|
|
|
assert { [dict get $info flags] == "${ssl_flag}::::" }
|
|
|
|
|
|
|
|
# Test MULTI flag
|
|
|
|
r multi
|
|
|
|
r test.clientinfo
|
|
|
|
set info [lindex [r exec] 0]
|
|
|
|
assert { [dict get $info flags] == "${ssl_flag}::::multi" }
|
|
|
|
|
|
|
|
# Test TRACKING flag
|
|
|
|
r client tracking on
|
|
|
|
set info [r test.clientinfo]
|
|
|
|
assert { [dict get $info flags] == "${ssl_flag}::tracking::" }
|
|
|
|
}
|
2020-10-11 16:11:31 +03:00
|
|
|
|
2020-10-11 17:11:42 +03:00
|
|
|
test {test module getclientcert api} {
|
|
|
|
set cert [r test.getclientcert]
|
|
|
|
|
|
|
|
if {$::tls} {
|
|
|
|
assert {$cert != ""}
|
|
|
|
} else {
|
|
|
|
assert {$cert == ""}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-11 16:11:31 +03:00
|
|
|
test {test detached thread safe cnotext} {
|
|
|
|
r test.log_tsctx "info" "Test message"
|
|
|
|
verify_log_message 0 "*<misc> Test message*" 0
|
|
|
|
}
|
2021-03-01 00:18:14 -06:00
|
|
|
|
|
|
|
test {test RM_Call CLIENT INFO} {
|
|
|
|
assert_match "*fd=-1*" [r test.call_generic client info]
|
|
|
|
}
|
2021-11-23 09:38:25 +01:00
|
|
|
|
|
|
|
test {Unsafe command names are sanitized in INFO output} {
|
|
|
|
r test.weird:cmd
|
|
|
|
set info [r info commandstats]
|
|
|
|
assert_match {*cmdstat_test.weird_cmd:calls=1*} $info
|
|
|
|
}
|
2022-01-13 12:36:03 +03:00
|
|
|
|
|
|
|
test {test monotonic time} {
|
|
|
|
set x [r test.monotonic_time]
|
|
|
|
assert { [r test.monotonic_time] >= $x }
|
|
|
|
}
|
2022-01-23 16:05:06 +08:00
|
|
|
|
|
|
|
test "Unload the module - misc" {
|
|
|
|
assert_equal {OK} [r module unload misc]
|
|
|
|
}
|
2019-10-24 09:38:52 +03:00
|
|
|
}
|