From 145528ad3268186fe2cbb1ca3555b1cf1c5cc851 Mon Sep 17 00:00:00 2001 From: David Rupprecht Date: Tue, 12 Jan 2021 14:33:56 +0100 Subject: [PATCH] Added unpacking test for RRC reconfig --- lib/test/asn1/rrc_nr_test.cc | 76 ++++++++++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) diff --git a/lib/test/asn1/rrc_nr_test.cc b/lib/test/asn1/rrc_nr_test.cc index c29559905..185474f1f 100644 --- a/lib/test/asn1/rrc_nr_test.cc +++ b/lib/test/asn1/rrc_nr_test.cc @@ -142,12 +142,88 @@ int test_ue_mrdc_capabilities() return SRSLTE_SUCCESS; } +int test_ue_rrc_reconfiguration() +{ + uint8_t rrc_msg[] = "\x08\x81\x7c\x5c\x40\xb1\xc0\x7d\x48\x3a\x04\xc0\x3e\x01\x04\x54" + "\x1e\xb5\x00\x02\xe8\x53\x98\xdf\x46\x93\x4b\x80\x04\xd2\x69\x34" + "\x00\x00\x08\xc9\x8d\x6d\x8c\xa2\x01\xff\x00\x00\x00\x00\x01\x1b" + "\x82\x21\x00\x00\x04\x04\x00\xd1\x14\x0e\x70\x00\x00\x08\xc9\xc6" + "\xb6\xc6\x44\xa0\x00\x1e\xb8\x95\x63\xe0\x24\x94\x22\x0d\xb8\x44" + "\x70\x0c\x02\x10\xb0\x1d\x80\x48\xf1\x18\x06\xea\x00\x08\x0e\x01" + "\x25\xc0\xc8\x80\x37\x08\x42\x00\x00\x88\x16\x50\x02\x0c\x82\x00" + "\x00\x20\x69\x81\x01\x45\x0a\x00\x0e\x48\x18\x00\x01\x33\x55\x64" + "\x84\x1c\x00\x10\x40\xc2\x05\x0c\x1c\x9c\x40\x91\x42\xc6\x0d\x1c" + "\x3c\x8e\x00\x00\x32\x21\x40\x30\x20\x01\x91\x4a\x01\x82\x00\x0c" + "\x8c\x50\x0c\x18\x00\x64\x42\x80\xe1\x00\x03\x22\x94\x07\x0a\x00" + "\x19\x18\xa0\x38\x60\x00\xc8\x85\x02\xc3\x80\x06\x45\x28\x16\x20" + "\x64\x00\x41\x6c\x48\x04\x62\x82\x18\xa0\x08\xc5\x04\xb1\x60\x11" + "\x8a\x0a\x63\x00\x23\x14\x16\xc6\x80\x46\x28\x31\x8e\x00\x8c\x50" + "\x6b\x1e\x01\x18\xa0\xe6\x40\x00\x32\x31\x40\xb2\x23\x10\x0a\x08" + "\x40\x90\x86\x05\x10\x43\xcc\x3b\x2a\x6e\x4d\x01\xa4\x92\x1e\x2e" + "\xe0\x0c\x10\xe0\x00\x00\x01\x8f\xfd\x29\x49\x8c\x63\x72\x81\x60" + "\x00\x02\x19\x70\x00\x00\x00\x00\x00\x00\x52\xf0\x0f\xa0\x84\x8a" + "\xd5\x45\x00\x47\x00\x18\x00\x08\x20\x00\xe2\x10\x02\x40\x80\x70" + "\x10\x10\x84\x00\x0e\x21\x00\x1c\xb0\x0e\x04\x02\x20\x80\x01\xc4" + "\x20\x03\x96\x01\xc0\xc0\x42\x10\x00\x38\x84\x00\x73\x00\x38\x20" + "\x08\x82\x00\x07\x10\x80\x0e\x60\x00\x40\x00\x00\x04\x10\xc0\x40" + "\x80\xc1\x00\xe0\xd0\x00\x0e\x48\x10\x00\x00\x02\x00\x40\x00\x80" + "\x60\x00\x80\x90\x02\x20\x0a\x40\x00\x02\x38\x90\x11\x31\xc8"; + + uint32_t rrc_msg_len = sizeof(rrc_msg); + cbit_ref bref(&rrc_msg[0], sizeof(rrc_msg)); + rrc_recfg_s rrc_recfg; + + TESTASSERT(rrc_recfg.unpack(bref) == SRSASN_SUCCESS); + TESTASSERT(rrc_recfg.rrc_transaction_id == 0); + json_writer jw; + rrc_recfg.to_json(jw); + srslte::logmap::get("RRC")->info_long("RRC Reconfig: \n %s \n", jw.to_string().c_str()); + + TESTASSERT(rrc_recfg.crit_exts.type() == asn1::rrc_nr::rrc_recfg_s::crit_exts_c_::types::rrc_recfg); + TESTASSERT(rrc_recfg.crit_exts.rrc_recfg().secondary_cell_group_present == true); + + cell_group_cfg_s cell_group_cfg; + cbit_ref bref0(rrc_recfg.crit_exts.rrc_recfg().secondary_cell_group.data(), + rrc_recfg.crit_exts.rrc_recfg().secondary_cell_group.size()); + TESTASSERT(cell_group_cfg.unpack(bref0) == SRSASN_SUCCESS); + json_writer jw1; + cell_group_cfg.to_json(jw1); + srslte::logmap::get("RRC")->info_long("RRC Secondary Cell Group: \n %s \n", jw1.to_string().c_str()); + TESTASSERT(cell_group_cfg.cell_group_id == 1); + TESTASSERT(cell_group_cfg.rlc_bearer_to_add_mod_list_present == true); + TESTASSERT(cell_group_cfg.rlc_bearer_to_add_mod_list.size() == 1); + TESTASSERT(cell_group_cfg.mac_cell_group_cfg_present == true); + TESTASSERT(cell_group_cfg.phys_cell_group_cfg_present == true); + TESTASSERT(cell_group_cfg.sp_cell_cfg_present == true); + return SRSLTE_SUCCESS; +} + +int test_radio_bearer_config() +{ + uint8_t rrc_msg[] = "\x14\x09\x28\x17\x87\xc0\x0c\x28"; + uint32_t rrc_msg_len = sizeof(rrc_msg); + cbit_ref bref(&rrc_msg[0], sizeof(rrc_msg)); + radio_bearer_cfg_s radio_bearer_cfg; + TESTASSERT(radio_bearer_cfg.unpack(bref) == SRSASN_SUCCESS); + json_writer jw; + radio_bearer_cfg.to_json(jw); + srslte::logmap::get("RRC")->info_long("RRC Bearer CFG Message: \n %s \n", jw.to_string().c_str()); + TESTASSERT(radio_bearer_cfg.drb_to_add_mod_list_present == true); + TESTASSERT(radio_bearer_cfg.drb_to_add_mod_list.size() == 1); + TESTASSERT(radio_bearer_cfg.security_cfg_present == true); + TESTASSERT(radio_bearer_cfg.security_cfg.security_algorithm_cfg_present == true); + TESTASSERT(radio_bearer_cfg.security_cfg.key_to_use_present == true); + return SRSLTE_SUCCESS; +} + int main() { srslte::logmap::set_default_log_level(srslte::LOG_LEVEL_DEBUG); TESTASSERT(test_eutra_nr_capabilities() == 0); TESTASSERT(test_ue_mrdc_capabilities() == 0); + TESTASSERT(test_ue_rrc_reconfiguration() == 0); + TESTASSERT(test_radio_bearer_config() == 0); printf("Success\n"); return 0;