session manager support output fieldstat
This commit is contained in:
@@ -1,10 +1,4 @@
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
#include "tuple.h"
|
||||
#include "packet_internal.h"
|
||||
#include "packet_parser.h"
|
||||
#include "session_internal.h"
|
||||
#include "default_config.h"
|
||||
#include "test_utils.h"
|
||||
|
||||
/******************************************************************************
|
||||
* case: TCP init -> opening (by TCP Fast Open)
|
||||
@@ -263,11 +257,11 @@ TEST(CASE, TCP_FAST_OPEN)
|
||||
char buffer[1024] = {0};
|
||||
struct packet pkt;
|
||||
struct session *sess = NULL;
|
||||
struct session_manager_runtime *sess_mgr_rt = NULL;
|
||||
struct session_manager_rte *sess_mgr_rte = NULL;
|
||||
struct session_manager_stat *sess_mgr_stat = NULL;
|
||||
|
||||
sess_mgr_rt = session_manager_runtime_new(&sess_mgr_cfg, 1);
|
||||
EXPECT_TRUE(sess_mgr_rt != NULL);
|
||||
sess_mgr_rte = session_manager_rte_new(&sess_mgr_cfg, 1);
|
||||
EXPECT_TRUE(sess_mgr_rte != NULL);
|
||||
|
||||
// C2S SYN Packet
|
||||
printf("\n=> Packet Parse: TCP C2S fast open packet\n");
|
||||
@@ -276,9 +270,10 @@ TEST(CASE, TCP_FAST_OPEN)
|
||||
printf("<= Packet Parse: done\n\n");
|
||||
|
||||
// lookup session
|
||||
EXPECT_TRUE(session_manager_runtime_lookup_session_by_packet(sess_mgr_rt, &pkt) == NULL);
|
||||
EXPECT_TRUE(session_manager_rte_lookup_session_by_packet(sess_mgr_rte, &pkt) == NULL);
|
||||
|
||||
// new session
|
||||
sess = session_manager_runtime_new_session(sess_mgr_rt, &pkt, 1);
|
||||
sess = session_manager_rte_new_session(sess_mgr_rte, &pkt, 1);
|
||||
EXPECT_TRUE(sess);
|
||||
|
||||
EXPECT_TRUE(session_get_id(sess) != 0);
|
||||
@@ -347,7 +342,7 @@ TEST(CASE, TCP_FAST_OPEN)
|
||||
session_free_tcp_segment(sess, seg);
|
||||
|
||||
// check stat
|
||||
sess_mgr_stat = session_manager_runtime_get_stat(sess_mgr_rt);
|
||||
sess_mgr_stat = session_manager_rte_get_stat(sess_mgr_rte);
|
||||
EXPECT_TRUE(sess_mgr_stat);
|
||||
EXPECT_TRUE(sess_mgr_stat->tcp_sess_used == 1);
|
||||
EXPECT_TRUE(sess_mgr_stat->tcp_sess_opening == 1);
|
||||
@@ -355,24 +350,25 @@ TEST(CASE, TCP_FAST_OPEN)
|
||||
EXPECT_TRUE(sess_mgr_stat->tcp_sess_closing == 0);
|
||||
|
||||
// expire session
|
||||
EXPECT_TRUE(session_manager_runtime_get_expired_session(sess_mgr_rt, 1 + sess_mgr_cfg.tcp_timeout_ms.init) == NULL); // opening -> closing
|
||||
sess = session_manager_runtime_get_expired_session(sess_mgr_rt, 1 + sess_mgr_cfg.tcp_timeout_ms.init + sess_mgr_cfg.tcp_timeout_ms.data); // closing -> closed
|
||||
EXPECT_TRUE(session_manager_rte_get_expired_session(sess_mgr_rte, 1 + sess_mgr_cfg.tcp_timeout_ms.init) == NULL); // opening -> closing
|
||||
sess = session_manager_rte_get_expired_session(sess_mgr_rte, 1 + sess_mgr_cfg.tcp_timeout_ms.init + sess_mgr_cfg.tcp_timeout_ms.data); // closing -> closed
|
||||
EXPECT_TRUE(sess);
|
||||
EXPECT_TRUE(session_get_current_state(sess) == SESSION_STATE_CLOSED);
|
||||
EXPECT_TRUE(session_get_closing_reason(sess) == CLOSING_BY_TIMEOUT);
|
||||
session_print(sess);
|
||||
|
||||
// free session
|
||||
session_manager_runtime_free_session(sess_mgr_rt, sess);
|
||||
session_manager_rte_free_session(sess_mgr_rte, sess);
|
||||
|
||||
// check stat
|
||||
sess_mgr_stat = session_manager_runtime_get_stat(sess_mgr_rt);
|
||||
sess_mgr_stat = session_manager_rte_get_stat(sess_mgr_rte);
|
||||
EXPECT_TRUE(sess_mgr_stat);
|
||||
EXPECT_TRUE(sess_mgr_stat->tcp_sess_used == 0);
|
||||
EXPECT_TRUE(sess_mgr_stat->tcp_sess_opening == 0);
|
||||
EXPECT_TRUE(sess_mgr_stat->tcp_sess_active == 0);
|
||||
EXPECT_TRUE(sess_mgr_stat->tcp_sess_closing == 0);
|
||||
|
||||
session_manager_runtime_free(sess_mgr_rt);
|
||||
session_manager_rte_free(sess_mgr_rte);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
Reference in New Issue
Block a user