session table can search session by tuple6 or tuple4 or id

This commit is contained in:
luwenpeng
2024-04-24 11:39:15 +08:00
parent 74f0504d3d
commit 476c5bac56
5 changed files with 233 additions and 105 deletions

View File

@@ -953,9 +953,9 @@ struct session *session_manager_lookup_session(struct session_manager *mgr, cons
switch (key.ip_proto) switch (key.ip_proto)
{ {
case IPPROTO_UDP: case IPPROTO_UDP:
return session_table_find_tuple(mgr->udp_sess_table, &key); return session_table_find_tuple6(mgr->udp_sess_table, &key);
case IPPROTO_TCP: case IPPROTO_TCP:
return session_table_find_tuple(mgr->tcp_sess_table, &key); return session_table_find_tuple6(mgr->tcp_sess_table, &key);
default: default:
return NULL; return NULL;
} }

View File

@@ -39,7 +39,7 @@ struct tcp_half
* *
* session memory usage = 128 * (50000 + 50000) * 1024 = 13107200000 bytes = 12.2 GB * session memory usage = 128 * (50000 + 50000) * 1024 = 13107200000 bytes = 12.2 GB
*/ */
struct session // 1024 bytes struct session
{ {
uint64_t id; // 8 bytes uint64_t id; // 8 bytes
uint64_t stats[MAX_DIRECTION][MAX_STAT]; // 480 bytes uint64_t stats[MAX_DIRECTION][MAX_STAT]; // 480 bytes
@@ -49,7 +49,9 @@ struct session // 1024 bytes
struct list_head lru; // 16 bytes -- used for lru queue struct list_head lru; // 16 bytes -- used for lru queue
struct list_head free; // 16 bytes -- used for free queue struct list_head free; // 16 bytes -- used for free queue
struct list_head evicte; // 16 bytes -- used for evicte queue struct list_head evicte; // 16 bytes -- used for evicte queue
UT_hash_handle hh; // 56 bytes -- used for hash table UT_hash_handle hh1; // 56 bytes -- used for hash table (tuple6)
UT_hash_handle hh2; // 56 bytes -- used for hash table (tuple4)
UT_hash_handle hh3; // 56 bytes -- used for hash table (session id)
struct tuple6 tuple; // 56 bytes struct tuple6 tuple; // 56 bytes
char tuple_str[TUPLE6_STR_SIZE]; // 108 bytes char tuple_str[TUPLE6_STR_SIZE]; // 108 bytes
const struct packet *first_pkt[MAX_DIRECTION]; // 16 bytes const struct packet *first_pkt[MAX_DIRECTION]; // 16 bytes

View File

@@ -6,7 +6,9 @@
struct session_table struct session_table
{ {
struct session *root; struct session *root_tuple6;
struct session *root_tuple4;
struct session *root_sessid;
session_free_cb free_cb; session_free_cb free_cb;
void *arg; void *arg;
uint64_t count; uint64_t count;
@@ -18,29 +20,62 @@ struct session_table
* Private API * Private API
******************************************************************************/ ******************************************************************************/
static void HASH_FUNCTION_OVERWRITE(const struct tuple6 *tuple, unsigned int keylen, uint32_t *hashv) static void HASH_FUNCTION_OVERWRITE(const void *keyptr, unsigned int keylen, uint32_t *hashv)
{ {
*hashv = tuple6_hash(tuple); switch (keylen)
{
case sizeof(struct tuple6):
*hashv = tuple6_hash((const struct tuple6 *)keyptr);
break;
case sizeof(struct tuple4):
*hashv = tuple4_hash((const struct tuple4 *)keyptr);
break;
case sizeof(uint64_t):
HASH_JEN(keyptr, keylen, *hashv);
break;
default:
assert(0);
break;
}
} }
static int HASH_KEYCMP_OVERWRITE(const void *key_a, const void *key_b, size_t len) static int HASH_KEYCMP_OVERWRITE(const void *key_a, const void *key_b, size_t len)
{ {
struct tuple6 *tuple_a = (struct tuple6 *)key_a; if (len == sizeof(struct tuple6))
struct tuple6 *tuple_b = (struct tuple6 *)key_b;
if (tuple6_cmp(tuple_a, tuple_b) == 0)
{ {
return 0; if (tuple6_cmp((const struct tuple6 *)key_a, (const struct tuple6 *)key_b) == -1)
{
struct tuple6 rev;
tuple6_reverse((const struct tuple6 *)key_b, &rev);
return tuple6_cmp((const struct tuple6 *)key_a, &rev);
}
else
{
return 0;
}
} }
else if (len == sizeof(struct tuple4))
struct tuple6 reversed;
tuple6_reverse(tuple_b, &reversed);
if (tuple6_cmp(tuple_a, &reversed) == 0)
{ {
return 0; if (tuple4_cmp((const struct tuple4 *)key_a, (const struct tuple4 *)key_b) == -1)
{
struct tuple4 rev;
tuple4_reverse((const struct tuple4 *)key_b, &rev);
return tuple4_cmp((const struct tuple4 *)key_a, &rev);
}
else
{
return 0;
}
}
else if (len == sizeof(uint64_t))
{
return memcmp(key_a, key_b, len);
}
else
{
assert(0);
return -1;
} }
return -1;
} }
/****************************************************************************** /******************************************************************************
@@ -67,10 +102,12 @@ void session_table_free(struct session_table *table)
{ {
struct session *node = NULL; struct session *node = NULL;
struct session *tmp = NULL; struct session *tmp = NULL;
HASH_ITER(hh, table->root, node, tmp) HASH_ITER(hh1, table->root_tuple6, node, tmp)
{ {
list_del(&node->lru); list_del(&node->lru);
HASH_DELETE(hh, table->root, node); HASH_DELETE(hh1, table->root_tuple6, node);
HASH_DELETE(hh2, table->root_tuple4, node);
HASH_DELETE(hh3, table->root_sessid, node);
if (table->free_cb && node) if (table->free_cb && node)
{ {
table->free_cb(node, table->arg); table->free_cb(node, table->arg);
@@ -109,13 +146,15 @@ int session_table_add(struct session_table *table, const struct tuple6 *tuple, s
return -1; return -1;
} }
if (session_table_find_tuple(table, tuple)) if (session_table_find_tuple6(table, tuple))
{ {
return -1; return -1;
} }
HASH_ADD(hh1, table->root_tuple6, tuple, sizeof(struct tuple6), sess);
HASH_ADD(hh2, table->root_tuple4, tuple, sizeof(struct tuple4), sess);
HASH_ADD(hh3, table->root_sessid, id, sizeof(uint64_t), sess);
list_add_tail(&sess->lru, &table->lru_queue); list_add_tail(&sess->lru, &table->lru_queue);
HASH_ADD(hh, table->root, tuple, sizeof(sess->tuple), sess);
table->count++; table->count++;
return 0; return 0;
@@ -128,14 +167,16 @@ void session_table_del(struct session_table *table, const struct tuple6 *tuple)
return; return;
} }
struct session *sess = session_table_find_tuple(table, tuple); struct session *sess = session_table_find_tuple6(table, tuple);
if (sess == NULL) if (sess == NULL)
{ {
return; return;
} }
list_del(&sess->lru); list_del(&sess->lru);
HASH_DELETE(hh, table->root, sess); HASH_DELETE(hh1, table->root_tuple6, sess);
HASH_DELETE(hh2, table->root_tuple4, sess);
HASH_DELETE(hh3, table->root_sessid, sess);
if (table->free_cb && sess) if (table->free_cb && sess)
{ {
table->free_cb(sess, table->arg); table->free_cb(sess, table->arg);
@@ -143,7 +184,7 @@ void session_table_del(struct session_table *table, const struct tuple6 *tuple)
table->count--; table->count--;
} }
struct session *session_table_find_tuple(struct session_table *table, const struct tuple6 *tuple) struct session *session_table_find_sessid(struct session_table *table, uint64_t id)
{ {
if (table == NULL) if (table == NULL)
{ {
@@ -151,15 +192,43 @@ struct session *session_table_find_tuple(struct session_table *table, const stru
} }
struct session *sess = NULL; struct session *sess = NULL;
HASH_FIND(hh, table->root, tuple, sizeof(struct tuple6), sess); HASH_FIND(hh3, table->root_sessid, &id, sizeof(uint64_t), sess);
if (sess == NULL) if (sess)
{ {
struct tuple6 out; list_del(&sess->lru);
memset(&out, 0, sizeof(struct tuple6)); list_add_tail(&sess->lru, &table->lru_queue);
tuple6_reverse(tuple, &out);
HASH_FIND(hh, table->root, &out, sizeof(struct tuple6), sess);
} }
return sess;
}
struct session *session_table_find_tuple6(struct session_table *table, const struct tuple6 *tuple)
{
if (table == NULL)
{
return NULL;
}
struct session *sess = NULL;
HASH_FIND(hh1, table->root_tuple6, tuple, sizeof(struct tuple6), sess);
if (sess)
{
list_del(&sess->lru);
list_add_tail(&sess->lru, &table->lru_queue);
}
return sess;
}
struct session *session_table_find_tuple4(struct session_table *table, const struct tuple4 *tuple)
{
if (table == NULL)
{
return NULL;
}
struct session *sess = NULL;
HASH_FIND(hh2, table->root_tuple4, tuple, sizeof(struct tuple4), sess);
if (sess) if (sess)
{ {
list_del(&sess->lru); list_del(&sess->lru);

View File

@@ -19,7 +19,9 @@ void session_table_set_freecb(struct session_table *table, session_free_cb free_
// return -1: failed // return -1: failed
int session_table_add(struct session_table *table, const struct tuple6 *tuple, struct session *sess); int session_table_add(struct session_table *table, const struct tuple6 *tuple, struct session *sess);
void session_table_del(struct session_table *table, const struct tuple6 *tuple); void session_table_del(struct session_table *table, const struct tuple6 *tuple);
struct session *session_table_find_tuple(struct session_table *table, const struct tuple6 *tuple); struct session *session_table_find_sessid(struct session_table *table, uint64_t id);
struct session *session_table_find_tuple6(struct session_table *table, const struct tuple6 *tuple);
struct session *session_table_find_tuple4(struct session_table *table, const struct tuple4 *tuple);
struct session *session_table_find_lru(struct session_table *table); struct session *session_table_find_lru(struct session_table *table);
#ifdef __cplusplus #ifdef __cplusplus

View File

@@ -3,38 +3,51 @@
#include "session_pool.h" #include "session_pool.h"
#include "session_table.h" #include "session_table.h"
#define SESSION_KEY_IPV4_TCP(name) \ #define TUPLE6_SET_V4_TCP(t6) \
struct tuple6 name; \ { \
memset(&name, 0, sizeof(struct tuple6)); \ memset(&t6, 0, sizeof(struct tuple6)); \
(name).ip_type = IP_TYPE_V4; \ (t6).ip_type = IP_TYPE_V4; \
(name).src_addr.v4.s_addr = inet_addr("192.168.1.2"); \ (t6).src_addr.v4.s_addr = inet_addr("192.168.1.2"); \
(name).dst_addr.v4.s_addr = inet_addr("192.168.1.3"); \ (t6).dst_addr.v4.s_addr = inet_addr("192.168.1.3"); \
(name).src_port = htons(1234); \ (t6).src_port = htons(1234); \
(name).dst_port = htons(5678); \ (t6).dst_port = htons(5678); \
(name).ip_proto = IPPROTO_TCP; \ (t6).ip_proto = IPPROTO_TCP; \
(name).domain = 0; (t6).domain = 123; \
}
#define SESSION_KEY_IPV6_UDP(name) \ #define TUPLE6_SET_V6_UDP(t6) \
struct tuple6 name; \ { \
memset(&name, 0, sizeof(struct tuple6)); \ memset(&t6, 0, sizeof(struct tuple6)); \
(name).ip_type = IP_TYPE_V6; \ (t6).ip_type = IP_TYPE_V6; \
inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:8329", &(name).src_addr.v6); \ inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:8329", &(t6).src_addr.v6); \
inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:832a", &(name).dst_addr.v6); \ inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:832a", &(t6).dst_addr.v6); \
(name).src_port = htons(1234); \ (t6).src_port = htons(2345); \
(name).dst_port = htons(5678); \ (t6).dst_port = htons(6789); \
(name).ip_proto = IPPROTO_UDP; \ (t6).ip_proto = IPPROTO_UDP; \
(name).domain = 0; (t6).domain = 456; \
}
#define SESSION_KEY_IPV6_TCP(name) \ #define TUPLE6_SET_V6_TCP(t6) \
struct tuple6 name; \ { \
memset(&name, 0, sizeof(struct tuple6)); \ memset(&t6, 0, sizeof(struct tuple6)); \
(name).ip_type = IP_TYPE_V6; \ (t6).ip_type = IP_TYPE_V6; \
inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:8329", &(name).src_addr.v6); \ inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:8329", &(t6).src_addr.v6); \
inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:832a", &(name).dst_addr.v6); \ inet_pton(AF_INET6, "2001:db8:0:0:0:ff00:42:832a", &(t6).dst_addr.v6); \
(name).src_port = htons(1234); \ (t6).src_port = htons(3456); \
(name).dst_port = htons(5678); \ (t6).dst_port = htons(7890); \
(name).ip_proto = IPPROTO_TCP; \ (t6).ip_proto = IPPROTO_TCP; \
(name).domain = 0; (t6).domain = 789; \
}
#define TUPLE6_TO_TUPLE4(t6, t4) \
{ \
memset(&(t4), 0, sizeof(struct tuple4)); \
(t4).ip_type = (t6).ip_type; \
(t4).src_addr = (t6).src_addr; \
(t4).dst_addr = (t6).dst_addr; \
(t4).src_port = (t6).src_port; \
(t4).dst_port = (t6).dst_port; \
}
static void session_free_callback(struct session *sess, void *arg) static void session_free_callback(struct session *sess, void *arg)
{ {
@@ -46,25 +59,47 @@ static void session_free_callback(struct session *sess, void *arg)
} }
} }
#if 1
TEST(SESSION_TABLE, OP_SESSION) TEST(SESSION_TABLE, OP_SESSION)
{ {
struct session *sess1 = NULL; struct session *sess1 = NULL;
struct session *sess2 = NULL; struct session *sess2 = NULL;
struct session *sess3 = NULL; struct session *sess3 = NULL;
struct tuple4 sess1_tup4;
struct tuple4 sess2_tup4;
struct tuple4 sess3_tup4;
struct tuple4 sess1_rev_tup4;
struct tuple4 sess2_rev_tup4;
struct tuple4 sess3_rev_tup4;
struct tuple6 sess1_tup6;
struct tuple6 sess2_tup6;
struct tuple6 sess3_tup6;
struct tuple6 sess1_rev_tup6;
struct tuple6 sess2_rev_tup6;
struct tuple6 sess3_rev_tup6;
struct session_pool *sess_pool = NULL; struct session_pool *sess_pool = NULL;
struct session_table *sess_table = NULL; struct session_table *sess_table = NULL;
SESSION_KEY_IPV4_TCP(tuple_1); TUPLE6_SET_V4_TCP(sess1_tup6);
SESSION_KEY_IPV6_UDP(tuple_2); TUPLE6_SET_V6_UDP(sess2_tup6);
SESSION_KEY_IPV6_TCP(tuple_3); TUPLE6_SET_V6_TCP(sess3_tup6);
struct tuple6 reversed_tuple_1; TUPLE6_TO_TUPLE4(sess1_tup6, sess1_tup4);
struct tuple6 reversed_tuple_2; TUPLE6_TO_TUPLE4(sess2_tup6, sess2_tup4);
struct tuple6 reversed_tuple_3; TUPLE6_TO_TUPLE4(sess3_tup6, sess3_tup4);
tuple6_reverse(&tuple_1, &reversed_tuple_1); tuple4_reverse(&sess1_tup4, &sess1_rev_tup4);
tuple6_reverse(&tuple_2, &reversed_tuple_2); tuple4_reverse(&sess2_tup4, &sess2_rev_tup4);
tuple6_reverse(&tuple_3, &reversed_tuple_3); tuple4_reverse(&sess3_tup4, &sess3_rev_tup4);
tuple6_reverse(&sess1_tup6, &sess1_rev_tup6);
tuple6_reverse(&sess2_tup6, &sess2_rev_tup6);
tuple6_reverse(&sess3_tup6, &sess3_rev_tup6);
// Create // Create
sess_pool = session_pool_new(3); sess_pool = session_pool_new(3);
@@ -77,66 +112,85 @@ TEST(SESSION_TABLE, OP_SESSION)
sess1 = session_pool_pop(sess_pool); sess1 = session_pool_pop(sess_pool);
EXPECT_TRUE(sess1 != NULL); EXPECT_TRUE(sess1 != NULL);
session_set_id(sess1, 1); session_set_id(sess1, 1);
session_set_tuple(sess1, &tuple_1); session_set_tuple(sess1, &sess1_tup6);
sess2 = session_pool_pop(sess_pool); sess2 = session_pool_pop(sess_pool);
EXPECT_TRUE(sess2 != NULL); EXPECT_TRUE(sess2 != NULL);
session_set_id(sess2, 2); session_set_id(sess2, 2);
session_set_tuple(sess2, &tuple_2); session_set_tuple(sess2, &sess2_tup6);
sess3 = session_pool_pop(sess_pool); sess3 = session_pool_pop(sess_pool);
EXPECT_TRUE(sess3 != NULL); EXPECT_TRUE(sess3 != NULL);
session_set_id(sess3, 3); session_set_id(sess3, 3);
session_set_tuple(sess3, &tuple_3); session_set_tuple(sess3, &sess3_tup6);
EXPECT_TRUE(session_table_add(sess_table, &tuple_1, sess1) == 0); EXPECT_TRUE(session_table_add(sess_table, &sess1_tup6, sess1) == 0);
EXPECT_TRUE(session_table_get_count(sess_table) == 1); EXPECT_TRUE(session_table_get_count(sess_table) == 1);
EXPECT_TRUE(session_table_add(sess_table, &tuple_2, sess2) == 0); EXPECT_TRUE(session_table_add(sess_table, &sess2_tup6, sess2) == 0);
EXPECT_TRUE(session_table_get_count(sess_table) == 2); EXPECT_TRUE(session_table_get_count(sess_table) == 2);
EXPECT_TRUE(session_table_add(sess_table, &tuple_3, sess3) == 0); EXPECT_TRUE(session_table_add(sess_table, &sess3_tup6, sess3) == 0);
EXPECT_TRUE(session_table_get_count(sess_table) == 3); EXPECT_TRUE(session_table_get_count(sess_table) == 3);
// Search // Search
EXPECT_TRUE(session_table_find_tuple(sess_table, &tuple_1) == sess1); EXPECT_TRUE(session_table_find_sessid(sess_table, 1) == sess1);
EXPECT_TRUE(session_table_find_tuple(sess_table, &tuple_2) == sess2); EXPECT_TRUE(session_table_find_sessid(sess_table, 2) == sess2);
EXPECT_TRUE(session_table_find_tuple(sess_table, &tuple_3) == sess3); EXPECT_TRUE(session_table_find_sessid(sess_table, 3) == sess3);
EXPECT_TRUE(session_table_find_tuple(sess_table, &reversed_tuple_1) == sess1); EXPECT_TRUE(session_table_find_tuple4(sess_table, &sess1_tup4) == sess1);
EXPECT_TRUE(session_table_find_tuple(sess_table, &reversed_tuple_2) == sess2); EXPECT_TRUE(session_table_find_tuple4(sess_table, &sess2_tup4) == sess2);
EXPECT_TRUE(session_table_find_tuple(sess_table, &reversed_tuple_3) == sess3); EXPECT_TRUE(session_table_find_tuple4(sess_table, &sess3_tup4) == sess3);
EXPECT_TRUE(session_table_find_tuple4(sess_table, &sess1_rev_tup4) == sess1);
EXPECT_TRUE(session_table_find_tuple4(sess_table, &sess2_rev_tup4) == sess2);
EXPECT_TRUE(session_table_find_tuple4(sess_table, &sess3_rev_tup4) == sess3);
EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess1_tup6) == sess1);
EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess2_tup6) == sess2);
EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess3_tup6) == sess3);
EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess1_rev_tup6) == sess1);
EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess2_rev_tup6) == sess2);
EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess3_rev_tup6) == sess3);
// Delete // Delete
session_table_del(sess_table, &tuple_1); session_table_del(sess_table, &sess1_tup6);
EXPECT_TRUE(session_table_get_count(sess_table) == 2); EXPECT_TRUE(session_table_get_count(sess_table) == 2);
EXPECT_TRUE(session_table_find_tuple(sess_table, &tuple_1) == NULL); EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess1_tup6) == NULL);
EXPECT_TRUE(session_table_find_tuple(sess_table, &reversed_tuple_1) == NULL); EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess1_rev_tup6) == NULL);
session_table_del(sess_table, &reversed_tuple_2); session_table_del(sess_table, &sess2_rev_tup6);
EXPECT_TRUE(session_table_get_count(sess_table) == 1); EXPECT_TRUE(session_table_get_count(sess_table) == 1);
EXPECT_TRUE(session_table_find_tuple(sess_table, &tuple_2) == NULL); EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess2_tup6) == NULL);
EXPECT_TRUE(session_table_find_tuple(sess_table, &reversed_tuple_2) == NULL); EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess2_rev_tup6) == NULL);
session_table_del(sess_table, &tuple_3); session_table_del(sess_table, &sess3_tup6);
EXPECT_TRUE(session_table_get_count(sess_table) == 0); EXPECT_TRUE(session_table_get_count(sess_table) == 0);
EXPECT_TRUE(session_table_find_tuple(sess_table, &tuple_3) == NULL); EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess3_tup6) == NULL);
EXPECT_TRUE(session_table_find_tuple(sess_table, &reversed_tuple_3) == NULL); EXPECT_TRUE(session_table_find_tuple6(sess_table, &sess3_rev_tup6) == NULL);
// Destroy // Destroy
session_table_free(sess_table); session_table_free(sess_table);
session_pool_free(sess_pool); session_pool_free(sess_pool);
} }
#endif
#if 1
TEST(SESSION_TABLE, FIND_OLDEST_NEWEST) TEST(SESSION_TABLE, FIND_OLDEST_NEWEST)
{ {
struct session *sess1 = NULL; struct session *sess1 = NULL;
struct session *sess2 = NULL; struct session *sess2 = NULL;
struct session *sess3 = NULL; struct session *sess3 = NULL;
struct tuple6 sess1_tup6;
struct tuple6 sess2_tup6;
struct tuple6 sess3_tup6;
struct session_pool *sess_pool = NULL; struct session_pool *sess_pool = NULL;
struct session_table *sess_table = NULL; struct session_table *sess_table = NULL;
SESSION_KEY_IPV4_TCP(tuple_1); TUPLE6_SET_V4_TCP(sess1_tup6);
SESSION_KEY_IPV6_UDP(tuple_2); TUPLE6_SET_V6_UDP(sess2_tup6);
SESSION_KEY_IPV6_TCP(tuple_3); TUPLE6_SET_V6_TCP(sess3_tup6);
// Create // Create
sess_pool = session_pool_new(3); sess_pool = session_pool_new(3);
@@ -152,39 +206,40 @@ TEST(SESSION_TABLE, FIND_OLDEST_NEWEST)
sess1 = session_pool_pop(sess_pool); sess1 = session_pool_pop(sess_pool);
EXPECT_TRUE(sess1 != NULL); EXPECT_TRUE(sess1 != NULL);
session_set_id(sess1, 1); session_set_id(sess1, 1);
session_set_tuple(sess1, &tuple_1); session_set_tuple(sess1, &sess1_tup6);
EXPECT_TRUE(session_table_add(sess_table, &tuple_1, sess1) == 0); EXPECT_TRUE(session_table_add(sess_table, &sess1_tup6, sess1) == 0);
EXPECT_TRUE(session_table_find_lru(sess_table) == sess1); EXPECT_TRUE(session_table_find_lru(sess_table) == sess1);
sess2 = session_pool_pop(sess_pool); sess2 = session_pool_pop(sess_pool);
EXPECT_TRUE(sess2 != NULL); EXPECT_TRUE(sess2 != NULL);
session_set_id(sess2, 2); session_set_id(sess2, 2);
session_set_tuple(sess2, &tuple_2); session_set_tuple(sess2, &sess2_tup6);
EXPECT_TRUE(session_table_add(sess_table, &tuple_2, sess2) == 0); EXPECT_TRUE(session_table_add(sess_table, &sess2_tup6, sess2) == 0);
EXPECT_TRUE(session_table_find_lru(sess_table) == sess1); EXPECT_TRUE(session_table_find_lru(sess_table) == sess1);
sess3 = session_pool_pop(sess_pool); sess3 = session_pool_pop(sess_pool);
EXPECT_TRUE(sess3 != NULL); EXPECT_TRUE(sess3 != NULL);
session_set_id(sess3, 3); session_set_id(sess3, 3);
session_set_tuple(sess3, &tuple_3); session_set_tuple(sess3, &sess3_tup6);
EXPECT_TRUE(session_table_add(sess_table, &tuple_3, sess3) == 0); EXPECT_TRUE(session_table_add(sess_table, &sess3_tup6, sess3) == 0);
EXPECT_TRUE(session_table_find_lru(sess_table) == sess1); EXPECT_TRUE(session_table_find_lru(sess_table) == sess1);
// Delete Session // Delete Session
session_table_del(sess_table, &tuple_1); session_table_del(sess_table, &sess1_tup6);
EXPECT_TRUE(session_table_find_lru(sess_table) == sess2); EXPECT_TRUE(session_table_find_lru(sess_table) == sess2);
session_table_del(sess_table, &tuple_2); session_table_del(sess_table, &sess2_tup6);
EXPECT_TRUE(session_table_find_lru(sess_table) == sess3); EXPECT_TRUE(session_table_find_lru(sess_table) == sess3);
session_table_del(sess_table, &tuple_3); session_table_del(sess_table, &sess3_tup6);
EXPECT_TRUE(session_table_find_lru(sess_table) == NULL); EXPECT_TRUE(session_table_find_lru(sess_table) == NULL);
// Destroy // Destroy
session_table_free(sess_table); session_table_free(sess_table);
session_pool_free(sess_pool); session_pool_free(sess_pool);
} }
#endif
int main(int argc, char **argv) int main(int argc, char **argv)
{ {