add udp init -> opening test case
This commit is contained in:
@@ -75,6 +75,7 @@ static void session_manager_update_session_timer(struct session_manager *mgr, st
|
||||
static void session_manager_update_session_base(struct session_manager *mgr, struct session *sess, const struct tuple6 *key, enum session_dir curr_dir);
|
||||
static void session_manager_update_session_packet(struct session_manager *mgr, struct session *sess, const struct packet *pkt, enum session_dir curr_dir);
|
||||
|
||||
static void session_manager_update_udp_to_opening(struct session_manager *mgr, struct session *sess);
|
||||
static void session_manager_update_udp_to_active(struct session_manager *mgr, struct session *sess);
|
||||
static void session_manager_update_udp_to_closing(struct session_manager *mgr, struct session *sess);
|
||||
static void session_manager_update_tcp_to_opening(struct session_manager *mgr, struct session *sess, int opening_by_syn);
|
||||
@@ -82,8 +83,6 @@ static void session_manager_update_tcp_to_active(struct session_manager *mgr, st
|
||||
static void session_manager_update_tcp_to_closing(struct session_manager *mgr, struct session *sess, int enable_time_wait);
|
||||
static void session_manager_update_session_to_closed(struct session_manager *mgr, struct session *sess);
|
||||
|
||||
static void session_manager_handle_udp_on_active(struct session_manager *mgr, struct session *sess);
|
||||
static void session_manager_handle_udp_on_closing(struct session_manager *mgr, struct session *sess);
|
||||
static void session_manager_handle_tcp_on_opening(struct session_manager *mgr, struct session *sess, enum tcp_state tcp_old_state, enum tcp_state tcp_curr_state);
|
||||
static void session_manager_handle_tcp_on_active(struct session_manager *mgr, struct session *sess, enum tcp_state tcp_old_state, enum tcp_state tcp_curr_state);
|
||||
static void session_manager_handle_tcp_on_closing(struct session_manager *mgr, struct session *sess, enum tcp_state tcp_old_state, enum tcp_state tcp_curr_state);
|
||||
@@ -613,6 +612,12 @@ static void session_manager_update_session_packet(struct session_manager *mgr, s
|
||||
session_set_last_time(sess, timestamp_get_msec());
|
||||
}
|
||||
|
||||
static void session_manager_update_udp_to_opening(struct session_manager *mgr, struct session *sess)
|
||||
{
|
||||
session_manager_update_session_state(mgr, sess, SESSION_STATE_OPENING);
|
||||
session_manager_update_session_timer(mgr, sess, udp_data_timeout_cb, mgr->config.udp_timeout_data);
|
||||
}
|
||||
|
||||
static void session_manager_update_udp_to_active(struct session_manager *mgr, struct session *sess)
|
||||
{
|
||||
session_manager_update_session_state(mgr, sess, SESSION_STATE_ACTIVE);
|
||||
@@ -663,17 +668,6 @@ static void session_manager_update_session_to_closed(struct session_manager *mgr
|
||||
session_timer_del_session(mgr->sess_timer, sess);
|
||||
}
|
||||
|
||||
static void session_manager_handle_udp_on_active(struct session_manager *mgr, struct session *sess)
|
||||
{
|
||||
session_manager_update_session_timer(mgr, sess, udp_data_timeout_cb, mgr->config.udp_timeout_data);
|
||||
}
|
||||
|
||||
static void session_manager_handle_udp_on_closing(struct session_manager *mgr, struct session *sess)
|
||||
{
|
||||
assert(0);
|
||||
session_manager_update_session_timer(mgr, sess, udp_data_timeout_cb, mgr->config.udp_timeout_data);
|
||||
}
|
||||
|
||||
// opening -> opening
|
||||
// opening -> active
|
||||
// opening -> closing
|
||||
@@ -846,7 +840,7 @@ static struct session *session_manager_new_udp_session(struct session_manager *m
|
||||
session_manager_update_session_base(mgr, sess, key, curr_dir);
|
||||
session_manager_update_session_packet(mgr, sess, pkt, curr_dir);
|
||||
session_update_udp_state(sess, NULL, curr_dir);
|
||||
session_manager_update_udp_to_active(mgr, sess); // change session state to active
|
||||
session_manager_update_udp_to_opening(mgr, sess);
|
||||
session_table_add_session(mgr->udp_sess_table, key, sess);
|
||||
|
||||
return sess;
|
||||
@@ -906,13 +900,13 @@ static struct session *session_manager_update_udp_session(struct session_manager
|
||||
switch (sess_state)
|
||||
{
|
||||
case SESSION_STATE_OPENING:
|
||||
assert(0);
|
||||
session_manager_update_udp_to_active(mgr, sess);
|
||||
break;
|
||||
case SESSION_STATE_ACTIVE:
|
||||
session_manager_handle_udp_on_active(mgr, sess);
|
||||
session_manager_update_udp_to_active(mgr, sess);
|
||||
return sess;
|
||||
case SESSION_STATE_CLOSING:
|
||||
session_manager_handle_udp_on_closing(mgr, sess);
|
||||
assert(0);
|
||||
break;
|
||||
case SESSION_STATE_CLOSED:
|
||||
assert(0);
|
||||
|
||||
Reference in New Issue
Block a user