Updated module tests to default to multithreaded and added tests for RM_CreateTimer while loading .rdb
Former-commit-id: e6091a2b7e328c5c279212c6eaf46d8135517326
This commit is contained in:
parent
e55ca3603c
commit
dc8d9feae8
@ -29,4 +29,6 @@ $TCLSH tests/test_helper.tcl \
|
||||
--single unit/moduleapi/blockedclient \
|
||||
--single unit/moduleapi/moduleloadsave \
|
||||
--single unit/moduleapi/getkeys \
|
||||
--single unit/moduleapi/timers \
|
||||
--config server-threads 3 \
|
||||
"${@}"
|
||||
|
@ -25,7 +25,7 @@ TEST_MODULES = \
|
||||
auth.so \
|
||||
keyspace_events.so \
|
||||
blockedclient.so \
|
||||
getkeys.so
|
||||
timers.so
|
||||
|
||||
|
||||
.PHONY: all
|
||||
|
76
tests/modules/timers.c
Normal file
76
tests/modules/timers.c
Normal file
@ -0,0 +1,76 @@
|
||||
#define REDISMODULE_EXPERIMENTAL_API
|
||||
#include "redismodule.h"
|
||||
#include <pthread.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sched.h>
|
||||
#include <unistd.h>
|
||||
#include <string.h>
|
||||
|
||||
static long current_timer_count = 0;
|
||||
static long total_timer_count;
|
||||
|
||||
void timerHandler(RedisModuleCtx *ctx, void *data) {
|
||||
REDISMODULE_NOT_USED(data);
|
||||
current_timer_count++;
|
||||
RedisModule_Log(ctx, "notice", "Timer %ld went off", current_timer_count);
|
||||
if (current_timer_count == total_timer_count){
|
||||
RedisModule_Log(ctx, "notice", "All timers fired successfully");
|
||||
}
|
||||
}
|
||||
|
||||
int elapsed(RedisModuleCtx *ctx, RedisModuleString **argv, int argc){
|
||||
REDISMODULE_NOT_USED(argc);
|
||||
REDISMODULE_NOT_USED(argv);
|
||||
RedisModule_ReplyWithLongLong(ctx, (long long)current_timer_count);
|
||||
return REDISMODULE_OK;
|
||||
}
|
||||
|
||||
enum TimerOrder {
|
||||
TIMERS_ASCENDING,
|
||||
TIMERS_DESCENDING,
|
||||
TIMERS_SAME
|
||||
};
|
||||
|
||||
int RedisModule_OnLoad(RedisModuleCtx *ctx, RedisModuleString **argv, int argc) {
|
||||
if (RedisModule_Init(ctx,"timer-spawn",1,REDISMODULE_APIVER_1)
|
||||
== REDISMODULE_ERR) return REDISMODULE_ERR;
|
||||
|
||||
enum TimerOrder mode;
|
||||
if (argc >= 1){
|
||||
const char * modeString = RedisModule_StringPtrLen(argv[0], NULL);
|
||||
if (strcmp(modeString, "ascending") == 0){
|
||||
mode = TIMERS_ASCENDING;
|
||||
} else if (strcmp(modeString, "descending") == 0){
|
||||
mode = TIMERS_DESCENDING;
|
||||
} else if (strcmp(modeString, "same") == 0){
|
||||
mode = TIMERS_SAME;
|
||||
} else {
|
||||
RedisModule_Log(ctx, "warning", "Invalid mode specified as first argument. Valid modes are: ascending, descending, and same");
|
||||
return REDISMODULE_ERR;
|
||||
}
|
||||
} else {
|
||||
mode = TIMERS_DESCENDING;
|
||||
}
|
||||
|
||||
long long user_timer_count;
|
||||
total_timer_count = (argc >= 2 && RedisModule_StringToLongLong(argv[1], &user_timer_count) == REDISMODULE_OK) ?
|
||||
(long)user_timer_count : 2500;
|
||||
|
||||
if (RedisModule_CreateCommand(ctx,"timer.elapsed", elapsed,"",0,0,0) == REDISMODULE_ERR)
|
||||
return REDISMODULE_ERR;
|
||||
|
||||
for (long i = 0; i < total_timer_count; i++){
|
||||
mstime_t period;
|
||||
if (mode == TIMERS_ASCENDING){
|
||||
period = i;
|
||||
} else if (mode == TIMERS_DESCENDING){
|
||||
period = total_timer_count - i;
|
||||
} else if (mode == TIMERS_SAME){
|
||||
period = total_timer_count;
|
||||
}
|
||||
RedisModule_CreateTimer(ctx, period, timerHandler, NULL);
|
||||
}
|
||||
|
||||
return REDISMODULE_OK;
|
||||
}
|
35
tests/unit/moduleapi/timers.tcl
Normal file
35
tests/unit/moduleapi/timers.tcl
Normal file
@ -0,0 +1,35 @@
|
||||
set testmodule [file normalize tests/modules/timers.so]
|
||||
set timercount 4000
|
||||
|
||||
|
||||
tags "modules" {
|
||||
test {Ascending module timers can load in correctly} {
|
||||
start_server [list overrides [list loadmodule "$testmodule ascending $timercount"]] {
|
||||
wait_for_condition [expr round($timercount/10)] 20 {
|
||||
[r timer.elapsed] == $timercount
|
||||
} else {
|
||||
fail "Server failed to load in timers with ascending periods"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
test {Descending module timers can load in correctly} {
|
||||
start_server [list overrides [list loadmodule "$testmodule descending $timercount"]] {
|
||||
wait_for_condition [expr round($timercount/10)] 20 {
|
||||
[r timer.elapsed] == $timercount
|
||||
} else {
|
||||
fail "Server failed to load in timers with descending periods"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
test {Module timers with the same period can load in correctly} {
|
||||
start_server [list overrides [list loadmodule "$testmodule same $timercount"]] {
|
||||
wait_for_condition [expr round($timercount/10)] 20 {
|
||||
[r timer.elapsed] == $timercount
|
||||
} else {
|
||||
fail "Server failed to load in timers with the same period"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user