Add session table & session
This commit is contained in:
132
src/session/gtest_session_table.cpp
Normal file
132
src/session/gtest_session_table.cpp
Normal file
@@ -0,0 +1,132 @@
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
#include "session_address.h"
|
||||
#include "session_pool.h"
|
||||
#include "session_table.h"
|
||||
|
||||
#define SESSION_ADDRESS_IPV4_TCP(name) \
|
||||
struct session_address name = {0}; \
|
||||
(name).layers[0].type = LAYER_IPV4; \
|
||||
(name).layers[0].tuple.ipv4.src.s_addr = inet_addr("192.168.1.2"); \
|
||||
(name).layers[0].tuple.ipv4.dst.s_addr = inet_addr("192.168.1.3"); \
|
||||
(name).layers[1].type = LAYER_TCP; \
|
||||
(name).layers[1].tuple.tcp.src = htons(1234); \
|
||||
(name).layers[1].tuple.tcp.dst = htons(5678); \
|
||||
(name).used = 2;
|
||||
|
||||
#define SESSION_ADDRESS_IPV6_UDP(name) \
|
||||
struct session_address name = {0}; \
|
||||
(name).layers[0].type = LAYER_IPV6; \
|
||||
inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:8329", &(name).layers[0].tuple.ipv6.src); \
|
||||
inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:832a", &(name).layers[0].tuple.ipv6.dst); \
|
||||
(name).layers[1].type = LAYER_UDP; \
|
||||
(name).layers[1].tuple.udp.src = htons(2345); \
|
||||
(name).layers[1].tuple.udp.dst = htons(443); \
|
||||
(name).used = 2;
|
||||
|
||||
#define SESSION_ADDRESS_IPV4_UDP_IPV6_TCP(name) \
|
||||
struct session_address name = {0}; \
|
||||
(name).layers[0].type = LAYER_IPV4; \
|
||||
(name).layers[0].tuple.ipv4.src.s_addr = inet_addr("192.168.1.2"); \
|
||||
(name).layers[0].tuple.ipv4.dst.s_addr = inet_addr("192.168.1.3"); \
|
||||
(name).layers[1].type = LAYER_UDP; \
|
||||
(name).layers[1].tuple.udp.src = htons(1234); \
|
||||
(name).layers[1].tuple.udp.dst = htons(5678); \
|
||||
(name).layers[2].type = LAYER_IPV6; \
|
||||
inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:8329", &(name).layers[2].tuple.ipv6.src); \
|
||||
inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:832a", &(name).layers[2].tuple.ipv6.dst); \
|
||||
(name).layers[3].type = LAYER_TCP; \
|
||||
(name).layers[3].tuple.tcp.src = htons(2345); \
|
||||
(name).layers[3].tuple.tcp.dst = htons(443); \
|
||||
(name).used = 4;
|
||||
|
||||
static void session_free_callback(struct session *sess, void *arg)
|
||||
{
|
||||
if (sess)
|
||||
{
|
||||
struct session_pool *sess_pool = (struct session_pool *)arg;
|
||||
session_pool_free(sess_pool, sess);
|
||||
sess = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
TEST(SESSION_TABLE, OP_SESSION)
|
||||
{
|
||||
struct session *sess1 = NULL;
|
||||
struct session *sess2 = NULL;
|
||||
struct session *sess3 = NULL;
|
||||
struct session_pool *sess_pool = NULL;
|
||||
struct session_table *sess_table = NULL;
|
||||
|
||||
SESSION_ADDRESS_IPV4_TCP(sess1_addr);
|
||||
SESSION_ADDRESS_IPV6_UDP(sess2_addr);
|
||||
SESSION_ADDRESS_IPV4_UDP_IPV6_TCP(sess3_addr);
|
||||
|
||||
// Create
|
||||
sess_pool = session_pool_create(3);
|
||||
EXPECT_TRUE(sess_pool != NULL);
|
||||
sess_table = session_table_create();
|
||||
EXPECT_TRUE(sess_table != NULL);
|
||||
session_table_set_freecb(sess_table, session_free_callback, sess_pool);
|
||||
|
||||
// Add session
|
||||
sess1 = session_pool_alloc(sess_pool);
|
||||
EXPECT_TRUE(sess1 != NULL);
|
||||
session_set_id(sess1, 1);
|
||||
session_set_address(sess1, &sess1_addr);
|
||||
|
||||
sess2 = session_pool_alloc(sess_pool);
|
||||
EXPECT_TRUE(sess2 != NULL);
|
||||
session_set_id(sess2, 2);
|
||||
session_set_address(sess2, &sess2_addr);
|
||||
|
||||
sess3 = session_pool_alloc(sess_pool);
|
||||
EXPECT_TRUE(sess3 != NULL);
|
||||
session_set_id(sess3, 3);
|
||||
session_set_address(sess3, &sess3_addr);
|
||||
|
||||
session_table_add_session(sess_table, sess1);
|
||||
EXPECT_TRUE(session_table_get_count(sess_table) == 1);
|
||||
session_table_add_session(sess_table, sess2);
|
||||
EXPECT_TRUE(session_table_get_count(sess_table) == 2);
|
||||
session_table_add_session(sess_table, sess3);
|
||||
EXPECT_TRUE(session_table_get_count(sess_table) == 3);
|
||||
|
||||
// Search session with id
|
||||
EXPECT_TRUE(session_table_search_session_with_id(sess_table, 1) == sess1);
|
||||
EXPECT_TRUE(session_table_search_session_with_id(sess_table, 2) == sess2);
|
||||
EXPECT_TRUE(session_table_search_session_with_id(sess_table, 3) == sess3);
|
||||
|
||||
// Search session with address
|
||||
session_address_reverse(&sess3_addr);
|
||||
EXPECT_TRUE(session_table_search_session_with_addr(sess_table, &sess1_addr) == sess1);
|
||||
EXPECT_TRUE(session_table_search_session_with_addr(sess_table, &sess2_addr) == sess2);
|
||||
EXPECT_TRUE(session_table_search_session_with_addr(sess_table, &sess3_addr) == sess3);
|
||||
|
||||
// Delete session with id
|
||||
session_table_delete_session_with_id(sess_table, 1);
|
||||
EXPECT_TRUE(session_table_get_count(sess_table) == 2);
|
||||
EXPECT_TRUE(session_table_search_session_with_id(sess_table, 1) == NULL);
|
||||
EXPECT_TRUE(session_table_search_session_with_addr(sess_table, &sess1_addr) == NULL);
|
||||
|
||||
session_table_delete_session_with_id(sess_table, 2);
|
||||
EXPECT_TRUE(session_table_get_count(sess_table) == 1);
|
||||
EXPECT_TRUE(session_table_search_session_with_id(sess_table, 2) == NULL);
|
||||
EXPECT_TRUE(session_table_search_session_with_addr(sess_table, &sess2_addr) == NULL);
|
||||
|
||||
// Delete session with address
|
||||
session_table_delete_session_with_addr(sess_table, &sess3_addr);
|
||||
EXPECT_TRUE(session_table_get_count(sess_table) == 0);
|
||||
EXPECT_TRUE(session_table_search_session_with_id(sess_table, 3) == NULL);
|
||||
EXPECT_TRUE(session_table_search_session_with_addr(sess_table, &sess3_addr) == NULL);
|
||||
|
||||
// Destroy
|
||||
session_table_destroy(sess_table);
|
||||
session_pool_destroy(sess_pool);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
::testing::InitGoogleTest(&argc, argv);
|
||||
return RUN_ALL_TESTS();
|
||||
}
|
||||
Reference in New Issue
Block a user