diff options
Diffstat (limited to 'tests')
-rw-r--r-- | tests/db/db_test.c | 74 | ||||
-rw-r--r-- | tests/db/db_test.err | 217 |
2 files changed, 291 insertions, 0 deletions
diff --git a/tests/db/db_test.c b/tests/db/db_test.c index 1bdabdb..db3318c 100644 --- a/tests/db/db_test.c +++ b/tests/db/db_test.c @@ -664,6 +664,79 @@ static void test_subscr_aud() comment_end(); } +static void test_subscr_sqn() +{ + int64_t id; + + comment_start(); + + comment("Set SQN for unknown subscriber"); + + ASSERT_RC(db_update_sqn(dbc, 99, 999), -ENOENT); + ASSERT_SEL(id, 99, -ENOENT); + + ASSERT_RC(db_update_sqn(dbc, 9999, 99), -ENOENT); + ASSERT_SEL(id, 9999, -ENOENT); + + comment("Create subscriber"); + + ASSERT_RC(db_subscr_create(dbc, imsi0), 0); + ASSERT_SEL(imsi, imsi0, 0); + + id = g_subscr.id; + ASSERT_SEL_AUD(imsi0, -ENOENT, id); + + comment("Set SQN, but no 3G auth data present"); + + ASSERT_RC(db_update_sqn(dbc, id, 123), -ENOENT); + ASSERT_SEL_AUD(imsi0, -ENOENT, id); + + ASSERT_RC(db_update_sqn(dbc, id, 543), -ENOENT); + ASSERT_SEL_AUD(imsi0, -ENOENT, id); + + comment("Set auth 3G data"); + + ASSERT_RC(db_subscr_update_aud_by_id(dbc, id, + mk_aud_3g(OSMO_AUTH_ALG_MILENAGE, + "BeefedCafeFaceAcedAddedDecadeFee", true, + "C01ffedC1cadaeAc1d1f1edAcac1aB0a", 5)), + 0); + ASSERT_SEL_AUD(imsi0, 0, id); + + comment("Set SQN"); + + ASSERT_RC(db_update_sqn(dbc, id, 23315), 0); + ASSERT_SEL_AUD(imsi0, 0, id); + + ASSERT_RC(db_update_sqn(dbc, id, 23315), 0); + ASSERT_SEL_AUD(imsi0, 0, id); + + ASSERT_RC(db_update_sqn(dbc, id, 423), 0); + ASSERT_SEL_AUD(imsi0, 0, id); + + comment("Set SQN: thru uint64_t range, using the int64_t SQLite bind"); + + ASSERT_RC(db_update_sqn(dbc, id, 0), 0); + ASSERT_SEL_AUD(imsi0, 0, id); + + ASSERT_RC(db_update_sqn(dbc, id, INT64_MAX), 0); + ASSERT_SEL_AUD(imsi0, 0, id); + + ASSERT_RC(db_update_sqn(dbc, id, INT64_MIN), 0); + ASSERT_SEL_AUD(imsi0, 0, id); + + ASSERT_RC(db_update_sqn(dbc, id, UINT64_MAX), 0); + ASSERT_SEL_AUD(imsi0, 0, id); + + comment("Delete subscriber"); + + ASSERT_SEL(imsi, imsi0, 0); + ASSERT_RC(db_subscr_delete_by_id(dbc, id), 0); + ASSERT_SEL(imsi, imsi0, -ENOENT); + + comment_end(); +} + static struct { bool verbose; } cmdline_opts = { @@ -739,6 +812,7 @@ int main(int argc, char **argv) test_subscr_create_update_sel_delete(); test_subscr_aud(); + test_subscr_sqn(); printf("Done\n"); return 0; diff --git a/tests/db/db_test.err b/tests/db/db_test.err index 4813ea6..0b09583 100644 --- a/tests/db/db_test.err +++ b/tests/db/db_test.err @@ -1191,3 +1191,220 @@ DAUC Cannot read subscriber from db: IMSI='123456789000000': No such subscriber ===== test_subscr_aud: SUCCESS + +===== test_subscr_sqn + +--- Set SQN for unknown subscriber + +db_update_sqn(dbc, 99, 999) --> -ENOENT +DAUC Cannot update SQN for subscriber ID=99: no auc_3g entry for such subscriber + +db_subscr_get_by_id(dbc, 99, &g_subscr) --> -ENOENT +DAUC Cannot read subscriber from db: ID=99: No such subscriber + +db_update_sqn(dbc, 9999, 99) --> -ENOENT +DAUC Cannot update SQN for subscriber ID=9999: no auc_3g entry for such subscriber + +db_subscr_get_by_id(dbc, 9999, &g_subscr) --> -ENOENT +DAUC Cannot read subscriber from db: ID=9999: No such subscriber + + +--- Create subscriber + +db_subscr_create(dbc, imsi0) --> 0 + +db_subscr_get_by_imsi(dbc, imsi0, &g_subscr) --> 0 +struct hlr_subscriber { + .id = 1, + .imsi = '123456789000000', +} + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> -2 +DAUC IMSI='123456789000000': No 2G Auth Data +DAUC IMSI='123456789000000': No 3G Auth Data + + + +--- Set SQN, but no 3G auth data present + +db_update_sqn(dbc, id, 123) --> -ENOENT +DAUC Cannot update SQN for subscriber ID=1: no auc_3g entry for such subscriber + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> -2 +DAUC IMSI='123456789000000': No 2G Auth Data +DAUC IMSI='123456789000000': No 3G Auth Data + + +db_update_sqn(dbc, id, 543) --> -ENOENT +DAUC Cannot update SQN for subscriber ID=1: no auc_3g entry for such subscriber + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> -2 +DAUC IMSI='123456789000000': No 2G Auth Data +DAUC IMSI='123456789000000': No 3G Auth Data + + + +--- Set auth 3G data + +db_subscr_update_aud_by_id(dbc, id, mk_aud_3g(OSMO_AUTH_ALG_MILENAGE, "BeefedCafeFaceAcedAddedDecadeFee", true, "C01ffedC1cadaeAc1d1f1edAcac1aB0a", 5)) --> 0 + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> 0 +DAUC IMSI='123456789000000': No 2G Auth Data + +2G: none +3G: struct osmo_sub_auth_data { + .type = UMTS, + .algo = MILENAGE, + .u.umts.opc = 'beefedcafefaceacedaddeddecadefee', + .u.umts.opc_is_op = 1, + .u.umts.k = 'c01ffedc1cadaeac1d1f1edacac1ab0a', + .u.umts.amf = '0000', + .u.umts.ind_bitlen = 5, +} + + +--- Set SQN + +db_update_sqn(dbc, id, 23315) --> 0 + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> 0 +DAUC IMSI='123456789000000': No 2G Auth Data + +2G: none +3G: struct osmo_sub_auth_data { + .type = UMTS, + .algo = MILENAGE, + .u.umts.opc = 'beefedcafefaceacedaddeddecadefee', + .u.umts.opc_is_op = 1, + .u.umts.k = 'c01ffedc1cadaeac1d1f1edacac1ab0a', + .u.umts.amf = '0000', + .u.umts.sqn = 23315, + .u.umts.sqn = 0x5b13, + .u.umts.ind_bitlen = 5, +} + +db_update_sqn(dbc, id, 23315) --> 0 + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> 0 +DAUC IMSI='123456789000000': No 2G Auth Data + +2G: none +3G: struct osmo_sub_auth_data { + .type = UMTS, + .algo = MILENAGE, + .u.umts.opc = 'beefedcafefaceacedaddeddecadefee', + .u.umts.opc_is_op = 1, + .u.umts.k = 'c01ffedc1cadaeac1d1f1edacac1ab0a', + .u.umts.amf = '0000', + .u.umts.sqn = 23315, + .u.umts.sqn = 0x5b13, + .u.umts.ind_bitlen = 5, +} + +db_update_sqn(dbc, id, 423) --> 0 + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> 0 +DAUC IMSI='123456789000000': No 2G Auth Data + +2G: none +3G: struct osmo_sub_auth_data { + .type = UMTS, + .algo = MILENAGE, + .u.umts.opc = 'beefedcafefaceacedaddeddecadefee', + .u.umts.opc_is_op = 1, + .u.umts.k = 'c01ffedc1cadaeac1d1f1edacac1ab0a', + .u.umts.amf = '0000', + .u.umts.sqn = 423, + .u.umts.sqn = 0x1a7, + .u.umts.ind_bitlen = 5, +} + + +--- Set SQN: thru uint64_t range, using the int64_t SQLite bind + +db_update_sqn(dbc, id, 0) --> 0 + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> 0 +DAUC IMSI='123456789000000': No 2G Auth Data + +2G: none +3G: struct osmo_sub_auth_data { + .type = UMTS, + .algo = MILENAGE, + .u.umts.opc = 'beefedcafefaceacedaddeddecadefee', + .u.umts.opc_is_op = 1, + .u.umts.k = 'c01ffedc1cadaeac1d1f1edacac1ab0a', + .u.umts.amf = '0000', + .u.umts.ind_bitlen = 5, +} + +db_update_sqn(dbc, id, INT64_MAX) --> 0 + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> 0 +DAUC IMSI='123456789000000': No 2G Auth Data + +2G: none +3G: struct osmo_sub_auth_data { + .type = UMTS, + .algo = MILENAGE, + .u.umts.opc = 'beefedcafefaceacedaddeddecadefee', + .u.umts.opc_is_op = 1, + .u.umts.k = 'c01ffedc1cadaeac1d1f1edacac1ab0a', + .u.umts.amf = '0000', + .u.umts.sqn = 9223372036854775807, + .u.umts.sqn = 0x7fffffffffffffff, + .u.umts.ind_bitlen = 5, +} + +db_update_sqn(dbc, id, INT64_MIN) --> 0 + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> 0 +DAUC IMSI='123456789000000': No 2G Auth Data + +2G: none +3G: struct osmo_sub_auth_data { + .type = UMTS, + .algo = MILENAGE, + .u.umts.opc = 'beefedcafefaceacedaddeddecadefee', + .u.umts.opc_is_op = 1, + .u.umts.k = 'c01ffedc1cadaeac1d1f1edacac1ab0a', + .u.umts.amf = '0000', + .u.umts.sqn = 9223372036854775808, + .u.umts.sqn = 0x8000000000000000, + .u.umts.ind_bitlen = 5, +} + +db_update_sqn(dbc, id, UINT64_MAX) --> 0 + +db_get_auth_data(dbc, imsi0, &g_aud2g, &g_aud3g, &g_id) --> 0 +DAUC IMSI='123456789000000': No 2G Auth Data + +2G: none +3G: struct osmo_sub_auth_data { + .type = UMTS, + .algo = MILENAGE, + .u.umts.opc = 'beefedcafefaceacedaddeddecadefee', + .u.umts.opc_is_op = 1, + .u.umts.k = 'c01ffedc1cadaeac1d1f1edacac1ab0a', + .u.umts.amf = '0000', + .u.umts.sqn = 18446744073709551615, + .u.umts.sqn = 0xffffffffffffffff, + .u.umts.ind_bitlen = 5, +} + + +--- Delete subscriber + +db_subscr_get_by_imsi(dbc, imsi0, &g_subscr) --> 0 +struct hlr_subscriber { + .id = 1, + .imsi = '123456789000000', +} + +db_subscr_delete_by_id(dbc, id) --> 0 + +db_subscr_get_by_imsi(dbc, imsi0, &g_subscr) --> -ENOENT +DAUC Cannot read subscriber from db: IMSI='123456789000000': No such subscriber + +===== test_subscr_sqn: SUCCESS + |