#include "core_debug.h" #include "core_pkbuf.h" #include "core_lib.h" #include #include "context.h" #include "mme_context.h" #include "s1ap_message.h" #include "testutil.h" #include "testpacket.h" static void handover_test1(abts_case *tc, void *data) { status_t rv; sock_id sock1, sock2; pkbuf_t *sendbuf; pkbuf_t *recvbuf; s1ap_message_t message; int i; int msgindex = 9; c_uint8_t tmp[MAX_SDU_LEN]; char *_nh1 = "10" "3715a966536b75b4 d46e99774dcdb344 5ce5e893fbbf28f4 9f58508c36f827cc"; char *_nh2 = "18" "a29ed36339514717 481992f77f47a9af 934a7b763afcec39 edf5071461db6ae8"; mongoc_collection_t *collection = NULL; bson_t *doc = NULL; c_int64_t count = 0; bson_error_t error; const char *json = "{" "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2b\" }," "\"imsi\" : \"001010123456801\"," "\"pdn\" : [" "{ \"apn\" : \"internet.ng2.mnet\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd32\" }," "\"qos\" : {" "\"qci\" : 9," "\"arp\" : {" "\"priority_level\" : 8," "\"pre_emption_vulnerability\" : 1," "\"pre_emption_capability\" : 1 } }," "\"type\" : 0 }," "{ \"apn\" : \"internet\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2c\" }," "\"pcc_rule\" : [" "{ \"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2d\" }," "\"qos\" : {" "\"qci\" : 1," "\"gbr\" : {" "\"downlink\" : { \"$numberLong\" : \"64\" }," "\"uplink\" : { \"$numberLong\" : \"44\" } }," "\"mbr\" : {" "\"downlink\" : { \"$numberLong\" : \"64\" }," "\"uplink\" : { \"$numberLong\" : \"44\" } }," "\"arp\" : {" "\"priority_level\" : 3," "\"pre_emption_vulnerability\" : 0," "\"pre_emption_capability\" : 0 } }," "\"flow\" : [" "{ \"direction\" : 2," "\"description\" : \"permit out udp from any 1-65535 to 10.200.136.98/32 23454\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd31\" } }," "{ \"direction\" : 1," "\"description\" : \"permit out udp from any 50020 to 10.200.136.98/32 1-65535\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd30\" } }," "{ \"direction\" : 2," "\"description\" : \"permit out udp from any 1-65535 to 10.200.136.98/32 23455\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2f\" } }," "{ \"direction\" : 1," "\"description\" : \"permit out udp from any 50021 to 10.200.136.98/32 1-65535\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2e\" } } ]" "} ]," "\"ambr\" : {" "\"downlink\" : { \"$numberLong\" : \"35840\" }," "\"uplink\" : { \"$numberLong\" : \"15360\" } }," "\"qos\" : {" "\"qci\" : 7," "\"arp\" : {" "\"priority_level\" : 1," "\"pre_emption_vulnerability\" : 0," "\"pre_emption_capability\" : 1 } }," "\"type\" : 0 }" "]," "\"ambr\" : {" "\"downlink\" : { \"$numberLong\" : \"1024000\" }," "\"uplink\" : { \"$numberLong\" : \"1024000\" } }," "\"subscribed_rau_tau_timer\" : 12," "\"network_access_mode\" : 2," "\"subscriber_status\" : 0," "\"access_restriction_data\" : 32," "\"security\" : {" "\"k\" : \"465B5CE8 B199B49F AA5F0A2E E238A6BC\"," "\"op\" : \"5F1D289C 5D354D0A 140C2548 F5F3E3BA\"," "\"amf\" : \"8000\"," "\"sqn\" : { \"$numberLong\" : \"32\" }, " "\"rand\" : \"0a303a1e 63603f61 404c1241 30320f39\" }, " "\"__v\" : 0" "}"; mme_self()->mme_ue_s1ap_id = 16777689; mme_self()->m_tmsi = 0x0400031f; /* Two eNB connects to MME */ rv = tests1ap_enb_connect(&sock1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_connect(&sock2); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* S1-Setup Reqeust/Response for Source eNB */ rv = tests1ap_build_setup_req( &sendbuf, S1ap_ENB_ID_PR_macroENB_ID, 0x54f64); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* S1-Setup Reqeust/Response for Target eNB */ rv = tests1ap_build_setup_req( &sendbuf, S1ap_ENB_ID_PR_macroENB_ID, 0x54f65); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); collection = mongoc_client_get_collection( context_self()->db_client, context_self()->db_name, "subscribers"); ABTS_PTR_NOTNULL(tc, collection); doc = bson_new_from_json((const uint8_t *)json, -1, &error);; ABTS_PTR_NOTNULL(tc, doc); ABTS_TRUE(tc, mongoc_collection_insert(collection, MONGOC_INSERT_NONE, doc, NULL, &error)); bson_destroy(doc); doc = BCON_NEW("imsi", BCON_UTF8("001010123456801")); ABTS_PTR_NOTNULL(tc, doc); do { count = mongoc_collection_count ( collection, MONGOC_QUERY_NONE, doc, 0, 0, NULL, &error); } while (count == 0); bson_destroy(doc); /*********************************************************************** * Attach Request : Known IMSI, Integrity Protected, No Security Context * Send Initial-UE Message + Attach Request + PDN Connectivity */ rv = tests1ap_build_initial_ue_msg(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Authentication Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Authentication Response */ rv = tests1ap_build_authentication_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Security mode Command */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Security mode Complete */ rv = tests1ap_build_security_mode_complete(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive ESM Information Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send ESM Information Response */ rv = tests1ap_build_esm_information_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Initial Context Setup Request + * Attach Accept + * Activate Default Bearer Context Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send UE Capability Info Indication */ rv = tests1ap_build_ue_capability_info_indication(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /* Send Initial Context Setup Response */ rv = tests1ap_build_initial_context_setup_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Send Attach Complete + Activate default EPS bearer cotext accept */ rv = tests1ap_build_attach_complete(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive EMM information */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Receive E-RAB Setup Request + * Activate dedicated EPS bearer context request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send E-RAB Setup Response */ rv = tests1ap_build_e_rab_setup_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /* Send Activate dedicated EPS bearer context accept */ rv = tests1ap_build_activate_dedicated_bearer_accept(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /* Send Path Switch Request */ rv = tests1ap_build_path_switch_request(&sendbuf, 0); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Path Switch Ack */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); ABTS_TRUE(tc, memcmp(recvbuf->payload + 26, CORE_HEX(_nh1, strlen(_nh1), tmp), 33) == 0); pkbuf_free(recvbuf); /* Send Path Switch Request */ rv = tests1ap_build_path_switch_request(&sendbuf, 1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Path Switch Ack */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); ABTS_TRUE(tc, memcmp(recvbuf->payload + 26, CORE_HEX(_nh2, strlen(_nh2), tmp), 33) == 0); pkbuf_free(recvbuf); /********** Remove Subscriber in Database */ doc = BCON_NEW("imsi", BCON_UTF8("001010123456801")); ABTS_PTR_NOTNULL(tc, doc); ABTS_TRUE(tc, mongoc_collection_remove(collection, MONGOC_REMOVE_SINGLE_REMOVE, doc, NULL, &error)) bson_destroy(doc); mongoc_collection_destroy(collection); /* Two eNB disonncect from MME */ rv = tests1ap_enb_close(sock1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_close(sock2); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); } static void handover_test2(abts_case *tc, void *data) { status_t rv; sock_id sock1, sock2; pkbuf_t *sendbuf; pkbuf_t *recvbuf; s1ap_message_t message; int i; int msgindex = 10; mongoc_collection_t *collection = NULL; bson_t *doc = NULL; c_int64_t count = 0; bson_error_t error; const char *json = "{" "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2b\" }," "\"imsi\" : \"001010123456815\"," "\"pdn\" : [" "{ \"apn\" : \"internet.ng2.mnet\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd32\" }," "\"qos\" : {" "\"qci\" : 9," "\"arp\" : {" "\"priority_level\" : 8," "\"pre_emption_vulnerability\" : 1," "\"pre_emption_capability\" : 1 } }," "\"type\" : 0 }," "{ \"apn\" : \"internet\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2c\" }," "\"pcc_rule\" : [" "{ \"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2d\" }," "\"qos\" : {" "\"qci\" : 1," "\"gbr\" : {" "\"downlink\" : { \"$numberLong\" : \"976\" }," "\"uplink\" : { \"$numberLong\" : \"976\" } }," "\"mbr\" : {" "\"downlink\" : { \"$numberLong\" : \"976\" }," "\"uplink\" : { \"$numberLong\" : \"976\" } }," "\"arp\" : {" "\"priority_level\" : 1," "\"pre_emption_vulnerability\" : 0," "\"pre_emption_capability\" : 0 } }," "\"flow\" : [" "{ \"direction\" : 2," "\"description\" : \"permit out udp from any 1-65535 to 10.200.136.98/32 23454\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd31\" } }," "{ \"direction\" : 1," "\"description\" : \"permit out udp from any 50020 to 10.200.136.98/32 1-65535\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd30\" } }," "{ \"direction\" : 2," "\"description\" : \"permit out udp from any 1-65535 to 10.200.136.98/32 23455\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2f\" } }," "{ \"direction\" : 1," "\"description\" : \"permit out udp from any 50021 to 10.200.136.98/32 1-65535\"," "\"_id\" : { \"$oid\" : \"599eb929c850caabcbfdcd2e\" } } ]" "} ]," "\"ambr\" : {" "\"downlink\" : { \"$numberLong\" : \"35840\" }," "\"uplink\" : { \"$numberLong\" : \"15360\" } }," "\"qos\" : {" "\"qci\" : 7," "\"arp\" : {" "\"priority_level\" : 1," "\"pre_emption_vulnerability\" : 1," "\"pre_emption_capability\" : 0 } }," "\"type\" : 0 }" "]," "\"ambr\" : {" "\"downlink\" : { \"$numberLong\" : \"202400\" }," "\"uplink\" : { \"$numberLong\" : \"202400\" } }," "\"subscribed_rau_tau_timer\" : 12," "\"network_access_mode\" : 2," "\"subscriber_status\" : 0," "\"access_restriction_data\" : 32," "\"security\" : {" "\"k\" : \"465B5CE8 B199B49F AA5F0A2E E238A6BC\"," "\"op\" : \"5F1D289C 5D354D0A 140C2548 F5F3E3BA\"," "\"amf\" : \"8000\"," "\"sqn\" : { \"$numberLong\" : \"161\" }, " "\"rand\" : \"160b4726 39115e14 075f4731 50355216\" }, " "\"__v\" : 0" "}"; mme_self()->mme_ue_s1ap_id = 33554627; mme_self()->m_tmsi = 0x010003e7; /* Two eNB connects to MME */ rv = tests1ap_enb_connect(&sock1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_connect(&sock2); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* S1-Setup Reqeust/Response for Source eNB */ rv = tests1ap_build_setup_req( &sendbuf, S1ap_ENB_ID_PR_macroENB_ID, 0x001f2); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* S1-Setup Reqeust/Response for Target eNB */ rv = tests1ap_build_setup_req( &sendbuf, S1ap_ENB_ID_PR_macroENB_ID, 0x00043); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); collection = mongoc_client_get_collection( context_self()->db_client, context_self()->db_name, "subscribers"); ABTS_PTR_NOTNULL(tc, collection); doc = bson_new_from_json((const uint8_t *)json, -1, &error);; ABTS_PTR_NOTNULL(tc, doc); ABTS_TRUE(tc, mongoc_collection_insert(collection, MONGOC_INSERT_NONE, doc, NULL, &error)); bson_destroy(doc); doc = BCON_NEW("imsi", BCON_UTF8("001010123456815")); ABTS_PTR_NOTNULL(tc, doc); do { count = mongoc_collection_count ( collection, MONGOC_QUERY_NONE, doc, 0, 0, NULL, &error); } while (count == 0); bson_destroy(doc); /*********************************************************************** * Attach Request : Known IMSI, No Security Context * Send Initial-UE Message + Attach Request + PDN Connectivity */ rv = tests1ap_build_initial_ue_msg(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Identity Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Identity Response */ rv = tests1ap_build_identity_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Authentication Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Authentication Response */ rv = tests1ap_build_authentication_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Security mode Command */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Security mode Complete */ rv = tests1ap_build_security_mode_complete(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive ESM Information Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send ESM Information Response */ rv = tests1ap_build_esm_information_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Initial Context Setup Request + * Attach Accept + * Activate Default Bearer Context Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send UE Capability Info Indication */ rv = tests1ap_build_ue_capability_info_indication(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /* Send Initial Context Setup Response */ rv = tests1ap_build_initial_context_setup_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Send Attach Complete + Activate default EPS bearer cotext accept */ rv = tests1ap_build_attach_complete(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive EMM information */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Receive E-RAB Setup Request + * Activate dedicated EPS bearer context request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send E-RAB Setup Response */ rv = tests1ap_build_e_rab_setup_response(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /* Send Activate dedicated EPS bearer context accept */ rv = tests1ap_build_activate_dedicated_bearer_accept(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /* Send Handover Required */ rv = tests1ap_build_handover_required(&sendbuf, 0); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Handover Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Handover Request Ack */ rv = tests1ap_build_handover_request_ack(&sendbuf, 0); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Handover Command */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send eNB Status Transfer */ rv = tests1ap_build_enb_status_transfer(&sendbuf, 0); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive MME Status Transfer */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Handover Notify */ rv = tests1ap_build_handover_notify(&sendbuf, 0); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive UE Context Release Command */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send UE Context Release Complete */ rv = tests1ap_build_ue_context_release_complete(&sendbuf, msgindex-1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /* Send Handover Required */ rv = tests1ap_build_handover_required(&sendbuf, 1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Handover Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Handover Request Ack */ rv = tests1ap_build_handover_request_ack(&sendbuf, 1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Handover Command */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send eNB Status Transfer */ rv = tests1ap_build_enb_status_transfer(&sendbuf, 1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive MME Status Transfer */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Handover Notify */ rv = tests1ap_build_handover_notify(&sendbuf, 1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive UE Context Release Command */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send UE Context Release Complete */ rv = tests1ap_build_ue_context_release_complete(&sendbuf, msgindex); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /* Send Handover Required */ rv = tests1ap_build_handover_required(&sendbuf, 2); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Handover Request */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Handover Request Ack */ rv = tests1ap_build_handover_request_ack(&sendbuf, 2); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Receive Handover Command */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send Handover Cancel */ rv = tests1ap_build_handover_cancel(&sendbuf, 0); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock1, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); /* Recv Handover Cancel Ack */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock1, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Recv UE Context Relase Command */ recvbuf = pkbuf_alloc(0, MAX_SDU_LEN); rv = tests1ap_enb_read(sock2, recvbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); pkbuf_free(recvbuf); /* Send UE Context Release Complete */ rv = tests1ap_build_ue_context_release_complete(&sendbuf, msgindex+1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_send(sock2, sendbuf); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); /********** Remove Subscriber in Database */ doc = BCON_NEW("imsi", BCON_UTF8("001010123456815")); ABTS_PTR_NOTNULL(tc, doc); ABTS_TRUE(tc, mongoc_collection_remove(collection, MONGOC_REMOVE_SINGLE_REMOVE, doc, NULL, &error)) bson_destroy(doc); mongoc_collection_destroy(collection); /* Two eNB disonncect from MME */ rv = tests1ap_enb_close(sock1); ABTS_INT_EQUAL(tc, CORE_OK, rv); rv = tests1ap_enb_close(sock2); ABTS_INT_EQUAL(tc, CORE_OK, rv); core_sleep(time_from_msec(300)); } abts_suite *test_handover(abts_suite *suite) { suite = ADD_SUITE(suite) abts_run_test(suite, handover_test1, NULL); abts_run_test(suite, handover_test2, NULL); return suite; }