diff options
author | Jacob Erlbeck <jerlbeck@sysmocom.de> | 2015-05-21 11:07:53 +0200 |
---|---|---|
committer | Jacob Erlbeck <jerlbeck@sysmocom.de> | 2015-05-28 12:29:40 +0200 |
commit | 7b9f825ae8f8a39c072413820a1a0557f420499d (patch) | |
tree | 7f989065bba29d68101ea0f1242830eff0ddf0d5 /tests/ms/MsTest.cpp | |
parent | b0e5eaf59adbefc44e01850a6784c9da0c3abbf9 (diff) |
ms: Use the IMSI to retrieve the MS object
This commit extends get_ms() to really compare the IMSI if it has
been given. Matching by TLLI has a higher precedence than matching by
IMSI.
Ticket: #1674
Sponsored-by: On-Waves ehf
Diffstat (limited to 'tests/ms/MsTest.cpp')
-rw-r--r-- | tests/ms/MsTest.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/tests/ms/MsTest.cpp b/tests/ms/MsTest.cpp index 75328f48..9c8ec2c3 100644 --- a/tests/ms/MsTest.cpp +++ b/tests/ms/MsTest.cpp @@ -328,6 +328,9 @@ static void test_ms_change_tlli() static void test_ms_storage() { uint32_t tlli = 0xffeeddbb; + const char *imsi1 = "001001987654321"; + const char *imsi2 = "001001987654322"; + gprs_rlcmac_ul_tbf *ul_tbf; GprsMs *ms, *ms_tmp; GprsMsStorage store; @@ -343,19 +346,36 @@ static void test_ms_storage() ms = store.create_ms(tlli + 0, GPRS_RLCMAC_UL_TBF); OSMO_ASSERT(ms != NULL); OSMO_ASSERT(ms->tlli() == tlli + 0); + ms->set_imsi(imsi1); + OSMO_ASSERT(strcmp(ms->imsi(), imsi1) == 0); ms_tmp = store.get_ms(tlli + 0); OSMO_ASSERT(ms == ms_tmp); OSMO_ASSERT(ms->tlli() == tlli + 0); + ms_tmp = store.get_ms(0, 0, imsi1); + OSMO_ASSERT(ms == ms_tmp); + OSMO_ASSERT(strcmp(ms->imsi(), imsi1) == 0); + ms_tmp = store.get_ms(0, 0, imsi2); + OSMO_ASSERT(ms_tmp == NULL); + ms = store.create_ms(tlli + 1, GPRS_RLCMAC_UL_TBF); OSMO_ASSERT(ms != NULL); OSMO_ASSERT(ms->tlli() == tlli + 1); + ms->set_imsi(imsi2); + OSMO_ASSERT(strcmp(ms->imsi(), imsi2) == 0); ms_tmp = store.get_ms(tlli + 1); OSMO_ASSERT(ms == ms_tmp); OSMO_ASSERT(ms->tlli() == tlli + 1); + ms_tmp = store.get_ms(0, 0, imsi1); + OSMO_ASSERT(ms_tmp != NULL); + OSMO_ASSERT(ms_tmp != ms); + ms_tmp = store.get_ms(0, 0, imsi2); + OSMO_ASSERT(ms == ms_tmp); + OSMO_ASSERT(strcmp(ms->imsi(), imsi2) == 0); + /* delete ms */ ms = store.get_ms(tlli + 0); OSMO_ASSERT(ms != NULL); |