diff options
Diffstat (limited to 'tests/sms_queue')
-rw-r--r-- | tests/sms_queue/Makefile.am | 57 | ||||
-rw-r--r-- | tests/sms_queue/sms_queue_test.c | 215 | ||||
-rw-r--r-- | tests/sms_queue/sms_queue_test.err | 0 | ||||
-rw-r--r-- | tests/sms_queue/sms_queue_test.ok | 98 |
4 files changed, 0 insertions, 370 deletions
diff --git a/tests/sms_queue/Makefile.am b/tests/sms_queue/Makefile.am deleted file mode 100644 index 06c54bcec..000000000 --- a/tests/sms_queue/Makefile.am +++ /dev/null @@ -1,57 +0,0 @@ -AM_CPPFLAGS = \ - $(all_includes) \ - -I$(top_srcdir)/include \ - $(NULL) - -AM_CFLAGS = \ - -Wall \ - -ggdb3 \ - $(LIBOSMOCORE_CFLAGS) \ - $(LIBOSMOGSM_CFLAGS) \ - $(LIBCRYPTO_CFLAGS) \ - $(LIBOSMOVTY_CFLAGS) \ - $(LIBOSMOABIS_CFLAGS) \ - $(LIBOSMOSIGTRAN_CFLAGS) \ - $(LIBOSMORANAP_CFLAGS) \ - $(LIBASN1C_CFLAGS) \ - $(LIBOSMOLEGACYMGCP_CFLAGS) \ - $(NULL) - -EXTRA_DIST = \ - sms_queue_test.ok \ - sms_queue_test.err \ - $(NULL) - -noinst_PROGRAMS = \ - sms_queue_test \ - $(NULL) - -sms_queue_test_SOURCES = \ - sms_queue_test.c \ - $(NULL) - -sms_queue_test_LDADD = \ - $(top_builddir)/src/libmsc/libmsc.a \ - $(top_builddir)/src/libvlr/libvlr.a \ - $(top_builddir)/src/libbsc/libbsc.a \ - $(top_builddir)/src/libtrau/libtrau.a \ - $(top_builddir)/src/libcommon/libcommon.a \ - $(top_builddir)/src/libcommon-cs/libcommon-cs.a \ - $(LIBSMPP34_LIBS) \ - $(LIBOSMOCORE_LIBS) \ - $(LIBOSMOGSM_LIBS) \ - $(LIBCRYPTO_LIBS) \ - $(LIBOSMOVTY_LIBS) \ - $(LIBOSMOABIS_LIBS) \ - $(LIBOSMOSIGTRAN_LIBS) \ - $(LIBOSMORANAP_LIBS) \ - $(LIBASN1C_LIBS) \ - $(LIBOSMOLEGACYMGCP_LIBS) \ - $(LIBRARY_GSM) \ - -ldbi \ - -lrt \ - $(NULL) - -sms_queue_test_LDFLAGS = \ - -Wl,--wrap=db_sms_get_next_unsent_rr_msisdn \ - $(NULL) diff --git a/tests/sms_queue/sms_queue_test.c b/tests/sms_queue/sms_queue_test.c deleted file mode 100644 index af25b0645..000000000 --- a/tests/sms_queue/sms_queue_test.c +++ /dev/null @@ -1,215 +0,0 @@ -/* Test Osmocom SMS queue */ - -/* - * (C) 2017 by sysmocom s.f.m.c. GmbH - * All Rights Reserved - * - * Author: Neels Hofmeyr <nhofmeyr@sysmocom.de> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU Affero General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Affero General Public License for more details. - * - * You should have received a copy of the GNU Affero General Public License - * along with this program. If not, see <http://www.gnu.org/licenses/>. - * - */ - -#include <osmocom/core/application.h> - -#include <openbsc/debug.h> -#include <openbsc/vlr.h> - -static void *talloc_ctx = NULL; - -struct gsm_sms *smsq_take_next_sms(struct gsm_network *net, - char *last_msisdn, - size_t last_msisdn_buflen); - -static void _test_take_next_sms_print(int i, - struct gsm_sms *sms, - const char *last_msisdn) -{ - printf("#%d: ", i); - if (sms) - printf("sending SMS to %s", sms->text); - else - printf("no SMS to send"); - printf(" (last_msisdn='%s')\n", last_msisdn? last_msisdn : "NULL"); -} - -static struct gsm_sms fake_sms = { 0 }; - -struct { - const char *msisdn; - int nr_of_sms; - int failed_attempts; - bool vsub_attached; -} fake_sms_db[] = { - { - .msisdn = "1111", - .nr_of_sms = 0, - .vsub_attached = true, - }, - { - .msisdn = "2222", - .nr_of_sms = 2, - .failed_attempts = 2, - .vsub_attached = true, - }, - { - .msisdn = "3333", - .nr_of_sms = 2, - .failed_attempts = 3, - .vsub_attached = true, - }, - { - .msisdn = "4444", - .nr_of_sms = 0, - .vsub_attached = true, - }, - { - .msisdn = "5555", - .nr_of_sms = 2, - .failed_attempts = 5, - .vsub_attached = false, - }, -}; - -/* override, requires '-Wl,--wrap=db_sms_get_next_unsent_rr_msisdn' */ -struct gsm_sms *__real_db_sms_get_next_unsent_rr_msisdn(struct gsm_network *net, - const char *last_msisdn, - unsigned int max_failed); -struct gsm_sms *__wrap_db_sms_get_next_unsent_rr_msisdn(struct gsm_network *net, - const char *last_msisdn, - unsigned int max_failed) -{ - static struct vlr_subscr arbitrary_vsub = { .lu_complete = true }; - int i; - printf(" hitting database: looking for MSISDN > '%s', failed_attempts <= %d\n", - last_msisdn, max_failed); - - for (i = 0; i < ARRAY_SIZE(fake_sms_db); i++) { - if (!fake_sms_db[i].nr_of_sms) - continue; - if (strcmp(fake_sms_db[i].msisdn, last_msisdn) <= 0) - continue; - if (fake_sms_db[i].failed_attempts > max_failed) - continue; - osmo_strlcpy(fake_sms.dst.addr, fake_sms_db[i].msisdn, - sizeof(fake_sms.dst.addr)); - fake_sms.receiver = fake_sms_db[i].vsub_attached? &arbitrary_vsub : NULL; - osmo_strlcpy(fake_sms.text, fake_sms_db[i].msisdn, sizeof(fake_sms.text)); - if (fake_sms_db[i].vsub_attached) - fake_sms_db[i].nr_of_sms --; - return &fake_sms; - } - return NULL; -} - -void show_fake_sms_db() -{ - int i; - for (i = 0; i < ARRAY_SIZE(fake_sms_db); i++) { - printf(" %s%s has %u SMS pending, %u failed attempts\n", - fake_sms_db[i].msisdn, - fake_sms_db[i].vsub_attached ? "" : " (NOT attached)", - fake_sms_db[i].nr_of_sms, - fake_sms_db[i].failed_attempts); - } - printf("-->\n"); -} - -static void test_next_sms() -{ - int i; - char last_msisdn[GSM_EXTENSION_LENGTH+1] = ""; - - printf("Testing smsq_take_next_sms()\n"); - - printf("\n- vsub 2, 3 and 5 each have 2 SMS pending, but 5 is not attached\n"); - last_msisdn[0] = '\0'; - show_fake_sms_db(); - for (i = 0; i < 7; i++) { - struct gsm_sms *sms = smsq_take_next_sms(NULL, last_msisdn, sizeof(last_msisdn)); - _test_take_next_sms_print(i, sms, last_msisdn); - OSMO_ASSERT(i >= 4 || sms); - } - - printf("\n- SMS are pending at various nr failed attempts (cutoff at >= 10)\n"); - last_msisdn[0] = '\0'; - for (i = 0; i < ARRAY_SIZE(fake_sms_db); i++) { - fake_sms_db[i].vsub_attached = true; - fake_sms_db[i].nr_of_sms = 1 + i; - fake_sms_db[i].failed_attempts = i*5; - - } - show_fake_sms_db(); - for (i = 0; i < 7; i++) { - struct gsm_sms *sms = smsq_take_next_sms(NULL, last_msisdn, sizeof(last_msisdn)); - _test_take_next_sms_print(i, sms, last_msisdn); - OSMO_ASSERT(i >= 2 || sms); - } - - printf("\n- iterate the SMS DB at most once\n"); - osmo_strlcpy(last_msisdn, "2345", sizeof(last_msisdn)); - for (i = 0; i < ARRAY_SIZE(fake_sms_db); i++) { - fake_sms_db[i].vsub_attached = false; - fake_sms_db[i].nr_of_sms = 1; - fake_sms_db[i].failed_attempts = 0; - } - show_fake_sms_db(); - for (i = 0; i < 3; i++) { - struct gsm_sms *sms = smsq_take_next_sms(NULL, last_msisdn, sizeof(last_msisdn)); - _test_take_next_sms_print(i, sms, last_msisdn); - OSMO_ASSERT(!sms); - } - - printf("\n- there are no SMS in the DB\n"); - last_msisdn[0] = '\0'; - for (i = 0; i < ARRAY_SIZE(fake_sms_db); i++) { - fake_sms_db[i].vsub_attached = true; - fake_sms_db[i].nr_of_sms = 0; - fake_sms_db[i].failed_attempts = 0; - } - show_fake_sms_db(); - for (i = 0; i < 3; i++) { - struct gsm_sms *sms = smsq_take_next_sms(NULL, last_msisdn, sizeof(last_msisdn)); - _test_take_next_sms_print(i, sms, last_msisdn); - OSMO_ASSERT(!sms); - } -} - - -static struct log_info_cat sms_queue_test_categories[] = { -}; - -static struct log_info info = { - .cat = sms_queue_test_categories, - .num_cat = ARRAY_SIZE(sms_queue_test_categories), -}; - -int main(int argc, char **argv) -{ - talloc_ctx = talloc_named_const(NULL, 1, "sms_queue_test"); - msgb_talloc_ctx_init(talloc_ctx, 0); - osmo_init_logging(&info); - - OSMO_ASSERT(osmo_stderr_target); - log_set_use_color(osmo_stderr_target, 0); - log_set_print_timestamp(osmo_stderr_target, 0); - log_set_print_filename(osmo_stderr_target, 0); - log_set_print_category(osmo_stderr_target, 1); - log_parse_category_mask(osmo_stderr_target, "DLOAP,1"); - - test_next_sms(); - printf("Done\n"); - - return 0; -} diff --git a/tests/sms_queue/sms_queue_test.err b/tests/sms_queue/sms_queue_test.err deleted file mode 100644 index e69de29bb..000000000 --- a/tests/sms_queue/sms_queue_test.err +++ /dev/null diff --git a/tests/sms_queue/sms_queue_test.ok b/tests/sms_queue/sms_queue_test.ok deleted file mode 100644 index 146400d21..000000000 --- a/tests/sms_queue/sms_queue_test.ok +++ /dev/null @@ -1,98 +0,0 @@ -Testing smsq_take_next_sms() - -- vsub 2, 3 and 5 each have 2 SMS pending, but 5 is not attached - 1111 has 0 SMS pending, 0 failed attempts - 2222 has 2 SMS pending, 2 failed attempts - 3333 has 2 SMS pending, 3 failed attempts - 4444 has 0 SMS pending, 0 failed attempts - 5555 (NOT attached) has 2 SMS pending, 5 failed attempts ---> - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#0: sending SMS to 2222 (last_msisdn='2222') - hitting database: looking for MSISDN > '2222', failed_attempts <= 9 -#1: sending SMS to 3333 (last_msisdn='3333') - hitting database: looking for MSISDN > '3333', failed_attempts <= 9 - hitting database: looking for MSISDN > '5555', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#2: sending SMS to 2222 (last_msisdn='2222') - hitting database: looking for MSISDN > '2222', failed_attempts <= 9 -#3: sending SMS to 3333 (last_msisdn='3333') - hitting database: looking for MSISDN > '3333', failed_attempts <= 9 - hitting database: looking for MSISDN > '5555', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#4: no SMS to send (last_msisdn='5555') - hitting database: looking for MSISDN > '5555', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#5: no SMS to send (last_msisdn='5555') - hitting database: looking for MSISDN > '5555', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#6: no SMS to send (last_msisdn='5555') - -- SMS are pending at various nr failed attempts (cutoff at >= 10) - 1111 has 1 SMS pending, 0 failed attempts - 2222 has 2 SMS pending, 5 failed attempts - 3333 has 3 SMS pending, 10 failed attempts - 4444 has 4 SMS pending, 15 failed attempts - 5555 has 5 SMS pending, 20 failed attempts ---> - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#0: sending SMS to 1111 (last_msisdn='1111') - hitting database: looking for MSISDN > '1111', failed_attempts <= 9 -#1: sending SMS to 2222 (last_msisdn='2222') - hitting database: looking for MSISDN > '2222', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#2: sending SMS to 2222 (last_msisdn='2222') - hitting database: looking for MSISDN > '2222', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#3: no SMS to send (last_msisdn='') - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#4: no SMS to send (last_msisdn='') - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#5: no SMS to send (last_msisdn='') - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#6: no SMS to send (last_msisdn='') - -- iterate the SMS DB at most once - 1111 (NOT attached) has 1 SMS pending, 0 failed attempts - 2222 (NOT attached) has 1 SMS pending, 0 failed attempts - 3333 (NOT attached) has 1 SMS pending, 0 failed attempts - 4444 (NOT attached) has 1 SMS pending, 0 failed attempts - 5555 (NOT attached) has 1 SMS pending, 0 failed attempts ---> - hitting database: looking for MSISDN > '2345', failed_attempts <= 9 - hitting database: looking for MSISDN > '3333', failed_attempts <= 9 - hitting database: looking for MSISDN > '4444', failed_attempts <= 9 - hitting database: looking for MSISDN > '5555', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 - hitting database: looking for MSISDN > '1111', failed_attempts <= 9 - hitting database: looking for MSISDN > '2222', failed_attempts <= 9 -#0: no SMS to send (last_msisdn='3333') - hitting database: looking for MSISDN > '3333', failed_attempts <= 9 - hitting database: looking for MSISDN > '4444', failed_attempts <= 9 - hitting database: looking for MSISDN > '5555', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 - hitting database: looking for MSISDN > '1111', failed_attempts <= 9 - hitting database: looking for MSISDN > '2222', failed_attempts <= 9 -#1: no SMS to send (last_msisdn='3333') - hitting database: looking for MSISDN > '3333', failed_attempts <= 9 - hitting database: looking for MSISDN > '4444', failed_attempts <= 9 - hitting database: looking for MSISDN > '5555', failed_attempts <= 9 - hitting database: looking for MSISDN > '', failed_attempts <= 9 - hitting database: looking for MSISDN > '1111', failed_attempts <= 9 - hitting database: looking for MSISDN > '2222', failed_attempts <= 9 -#2: no SMS to send (last_msisdn='3333') - -- there are no SMS in the DB - 1111 has 0 SMS pending, 0 failed attempts - 2222 has 0 SMS pending, 0 failed attempts - 3333 has 0 SMS pending, 0 failed attempts - 4444 has 0 SMS pending, 0 failed attempts - 5555 has 0 SMS pending, 0 failed attempts ---> - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#0: no SMS to send (last_msisdn='') - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#1: no SMS to send (last_msisdn='') - hitting database: looking for MSISDN > '', failed_attempts <= 9 -#2: no SMS to send (last_msisdn='') -Done |