2023-12-12 18:41:53 +08:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
|
|
#include "session_timer.h"
|
|
|
|
|
#include "session_private.h"
|
|
|
|
|
|
2023-12-13 19:20:34 +08:00
|
|
|
static void session_expire(struct session *sess, void *arg)
|
2023-12-12 18:41:53 +08:00
|
|
|
{
|
|
|
|
|
printf("=== session %lu expired ===\n", session_get_id(sess));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(SESSION_TIMER, ADD_DEL)
|
|
|
|
|
{
|
|
|
|
|
struct session sess;
|
2024-03-08 14:20:36 +08:00
|
|
|
struct session_timer *timer = session_timer_new();
|
2023-12-12 18:41:53 +08:00
|
|
|
EXPECT_TRUE(timer != NULL);
|
|
|
|
|
|
|
|
|
|
session_init(&sess);
|
|
|
|
|
session_set_id(&sess, 1);
|
2023-12-13 19:20:34 +08:00
|
|
|
session_set_expirecb(&sess, session_expire, NULL, 1000);
|
2023-12-12 18:41:53 +08:00
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
session_timer_add(timer, &sess);
|
|
|
|
|
session_timer_del(timer, &sess);
|
2023-12-12 18:41:53 +08:00
|
|
|
|
2024-03-08 14:20:36 +08:00
|
|
|
session_timer_free(timer);
|
2023-12-12 18:41:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(SESSION_TIMER, EXPIRE)
|
|
|
|
|
{
|
|
|
|
|
struct session *sess = NULL;
|
|
|
|
|
struct session sess1;
|
|
|
|
|
struct session sess2;
|
|
|
|
|
struct session sess3;
|
2024-03-08 14:20:36 +08:00
|
|
|
struct session_timer *timer = session_timer_new();
|
2023-12-12 18:41:53 +08:00
|
|
|
EXPECT_TRUE(timer != NULL);
|
|
|
|
|
|
|
|
|
|
session_init(&sess1);
|
|
|
|
|
session_init(&sess2);
|
|
|
|
|
session_init(&sess3);
|
|
|
|
|
session_set_id(&sess1, 1);
|
|
|
|
|
session_set_id(&sess2, 2);
|
|
|
|
|
session_set_id(&sess3, 3);
|
2023-12-13 19:20:34 +08:00
|
|
|
session_set_expirecb(&sess1, session_expire, NULL, 5);
|
|
|
|
|
session_set_expirecb(&sess2, session_expire, NULL, 5);
|
|
|
|
|
session_set_expirecb(&sess3, session_expire, NULL, 10);
|
2023-12-12 18:41:53 +08:00
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
session_timer_add(timer, &sess1);
|
|
|
|
|
session_timer_add(timer, &sess2);
|
|
|
|
|
session_timer_add(timer, &sess3);
|
2023-12-12 18:41:53 +08:00
|
|
|
|
|
|
|
|
for (uint64_t abs_current_ts = 0; abs_current_ts < 15; abs_current_ts++)
|
|
|
|
|
{
|
|
|
|
|
printf("current timestamp %lu\n", abs_current_ts);
|
|
|
|
|
do
|
|
|
|
|
{
|
2024-03-14 10:56:09 +08:00
|
|
|
sess = session_timer_expire(timer, abs_current_ts);
|
2023-12-12 18:41:53 +08:00
|
|
|
if (sess != NULL)
|
|
|
|
|
{
|
|
|
|
|
session_run_expirecb(sess);
|
|
|
|
|
}
|
|
|
|
|
} while (sess);
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-08 14:20:36 +08:00
|
|
|
session_timer_free(timer);
|
2023-12-12 18:41:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(SESSION_TIMER, BEFORE_EXPIRE_DEL)
|
|
|
|
|
{
|
|
|
|
|
struct session *sess = NULL;
|
|
|
|
|
struct session sess1;
|
|
|
|
|
struct session sess2;
|
|
|
|
|
struct session sess3;
|
2024-03-08 14:20:36 +08:00
|
|
|
struct session_timer *timer = session_timer_new();
|
2023-12-12 18:41:53 +08:00
|
|
|
EXPECT_TRUE(timer != NULL);
|
|
|
|
|
|
|
|
|
|
session_init(&sess1);
|
|
|
|
|
session_init(&sess2);
|
|
|
|
|
session_init(&sess3);
|
|
|
|
|
session_set_id(&sess1, 1);
|
|
|
|
|
session_set_id(&sess2, 2);
|
|
|
|
|
session_set_id(&sess3, 3);
|
2023-12-13 19:20:34 +08:00
|
|
|
session_set_expirecb(&sess1, session_expire, NULL, 5);
|
|
|
|
|
session_set_expirecb(&sess2, session_expire, NULL, 5);
|
|
|
|
|
session_set_expirecb(&sess3, session_expire, NULL, 10);
|
2023-12-12 18:41:53 +08:00
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
session_timer_add(timer, &sess1);
|
|
|
|
|
session_timer_add(timer, &sess2);
|
|
|
|
|
session_timer_add(timer, &sess3);
|
2023-12-12 18:41:53 +08:00
|
|
|
|
|
|
|
|
for (uint64_t abs_current_ts = 0; abs_current_ts < 15; abs_current_ts++)
|
|
|
|
|
{
|
|
|
|
|
printf("current timestamp %lu\n", abs_current_ts);
|
|
|
|
|
if (abs_current_ts == 2)
|
|
|
|
|
{
|
|
|
|
|
printf("delete timer 2\n");
|
2024-03-14 10:56:09 +08:00
|
|
|
session_timer_del(timer, &sess2);
|
2023-12-12 18:41:53 +08:00
|
|
|
}
|
|
|
|
|
do
|
|
|
|
|
{
|
2024-03-14 10:56:09 +08:00
|
|
|
sess = session_timer_expire(timer, abs_current_ts);
|
2023-12-12 18:41:53 +08:00
|
|
|
if (sess != NULL)
|
|
|
|
|
{
|
|
|
|
|
session_run_expirecb(sess);
|
|
|
|
|
}
|
|
|
|
|
} while (sess);
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-08 14:20:36 +08:00
|
|
|
session_timer_free(timer);
|
2023-12-12 18:41:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(SESSION_TIMER, BEFORE_EXPIRE_UPDATE)
|
|
|
|
|
{
|
|
|
|
|
struct session *sess = NULL;
|
|
|
|
|
struct session sess1;
|
|
|
|
|
struct session sess2;
|
|
|
|
|
struct session sess3;
|
2024-03-08 14:20:36 +08:00
|
|
|
struct session_timer *timer = session_timer_new();
|
2023-12-12 18:41:53 +08:00
|
|
|
EXPECT_TRUE(timer != NULL);
|
|
|
|
|
|
|
|
|
|
session_init(&sess1);
|
|
|
|
|
session_init(&sess2);
|
|
|
|
|
session_init(&sess3);
|
|
|
|
|
session_set_id(&sess1, 1);
|
|
|
|
|
session_set_id(&sess2, 2);
|
|
|
|
|
session_set_id(&sess3, 3);
|
2023-12-13 19:20:34 +08:00
|
|
|
session_set_expirecb(&sess1, session_expire, NULL, 5);
|
|
|
|
|
session_set_expirecb(&sess2, session_expire, NULL, 5);
|
|
|
|
|
session_set_expirecb(&sess3, session_expire, NULL, 10);
|
2023-12-12 18:41:53 +08:00
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
session_timer_add(timer, &sess1);
|
|
|
|
|
session_timer_add(timer, &sess2);
|
|
|
|
|
session_timer_add(timer, &sess3);
|
2023-12-12 18:41:53 +08:00
|
|
|
|
|
|
|
|
for (uint64_t abs_current_ts = 0; abs_current_ts < 15; abs_current_ts++)
|
|
|
|
|
{
|
|
|
|
|
printf("current timestamp %lu\n", abs_current_ts);
|
|
|
|
|
if (abs_current_ts == 2)
|
|
|
|
|
{
|
|
|
|
|
printf("update timer 2\n");
|
2024-03-14 10:56:09 +08:00
|
|
|
session_timer_del(timer, &sess2);
|
2023-12-13 19:20:34 +08:00
|
|
|
session_set_expirecb(&sess2, session_expire, NULL, 8);
|
2024-03-14 10:56:09 +08:00
|
|
|
session_timer_add(timer, &sess2);
|
2023-12-12 18:41:53 +08:00
|
|
|
}
|
|
|
|
|
do
|
|
|
|
|
{
|
2024-03-14 10:56:09 +08:00
|
|
|
sess = session_timer_expire(timer, abs_current_ts);
|
2023-12-12 18:41:53 +08:00
|
|
|
if (sess != NULL)
|
|
|
|
|
{
|
|
|
|
|
session_run_expirecb(sess);
|
|
|
|
|
}
|
|
|
|
|
} while (sess);
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-08 14:20:36 +08:00
|
|
|
session_timer_free(timer);
|
2023-12-12 18:41:53 +08:00
|
|
|
}
|
|
|
|
|
|
2024-01-25 16:08:55 +08:00
|
|
|
TEST(SESSION_TIMER, NEXT_EXPIRE_INTERVAL)
|
|
|
|
|
{
|
|
|
|
|
struct session sess1;
|
|
|
|
|
struct session sess2;
|
2024-03-08 14:20:36 +08:00
|
|
|
struct session_timer *timer = session_timer_new();
|
2024-01-25 16:08:55 +08:00
|
|
|
EXPECT_TRUE(timer != NULL);
|
|
|
|
|
|
|
|
|
|
session_init(&sess1);
|
|
|
|
|
session_init(&sess2);
|
|
|
|
|
session_set_id(&sess1, 1);
|
|
|
|
|
session_set_id(&sess2, 2);
|
|
|
|
|
session_set_expirecb(&sess1, session_expire, NULL, 1000);
|
|
|
|
|
session_set_expirecb(&sess2, session_expire, NULL, 1000);
|
|
|
|
|
|
|
|
|
|
EXPECT_TRUE(session_timer_next_expire_interval(timer) == UINT64_MAX);
|
|
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
session_timer_add(timer, &sess1);
|
|
|
|
|
session_timer_add(timer, &sess2);
|
2024-01-25 16:08:55 +08:00
|
|
|
EXPECT_TRUE(session_timer_next_expire_interval(timer) < UINT64_MAX);
|
|
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
EXPECT_TRUE(session_timer_expire(timer, 900) == NULL);
|
2024-01-25 16:08:55 +08:00
|
|
|
EXPECT_TRUE(session_timer_next_expire_interval(timer) <= 1000 - 900);
|
|
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
EXPECT_TRUE(session_timer_expire(timer, 950) == NULL);
|
2024-01-25 16:08:55 +08:00
|
|
|
EXPECT_TRUE(session_timer_next_expire_interval(timer) <= 1000 - 950);
|
|
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
EXPECT_TRUE(session_timer_expire(timer, 980) == NULL);
|
2024-01-25 16:08:55 +08:00
|
|
|
EXPECT_TRUE(session_timer_next_expire_interval(timer) <= 1000 - 980);
|
|
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
EXPECT_TRUE(session_timer_expire(timer, 990) == NULL);
|
2024-01-25 16:08:55 +08:00
|
|
|
EXPECT_TRUE(session_timer_next_expire_interval(timer) <= 1000 - 990);
|
|
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
EXPECT_TRUE(session_timer_expire(timer, 1010));
|
2024-01-25 16:08:55 +08:00
|
|
|
EXPECT_TRUE(session_timer_next_expire_interval(timer) == 0);
|
|
|
|
|
|
2024-03-14 10:56:09 +08:00
|
|
|
EXPECT_TRUE(session_timer_expire(timer, 1010));
|
2024-01-25 16:08:55 +08:00
|
|
|
EXPECT_TRUE(session_timer_next_expire_interval(timer) == UINT64_MAX);
|
|
|
|
|
|
2024-03-08 14:20:36 +08:00
|
|
|
session_timer_free(timer);
|
2024-01-25 16:08:55 +08:00
|
|
|
}
|
|
|
|
|
|
2023-12-12 18:41:53 +08:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
|
{
|
|
|
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
|
|
|
return RUN_ALL_TESTS();
|
|
|
|
|
}
|