2012-01-06 14:16:12 +00:00
|
|
|
AT_INIT
|
|
|
|
AT_BANNER([Regression tests.])
|
|
|
|
|
2013-07-13 15:09:56 +00:00
|
|
|
AT_SETUP([smpp])
|
|
|
|
AT_KEYWORDS([smpp])
|
|
|
|
AT_CHECK([test "$enable_smpp_test" != no || exit 77])
|
|
|
|
cat $abs_srcdir/smpp/smpp_test.ok > expout
|
|
|
|
cat $abs_srcdir/smpp/smpp_test.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/smpp/smpp_test], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
2016-06-19 16:06:02 +00:00
|
|
|
AT_SETUP([sms_queue_test])
|
|
|
|
AT_KEYWORDS([sms_queue_test])
|
|
|
|
cat $abs_srcdir/sms_queue/sms_queue_test.ok > expout
|
|
|
|
cat $abs_srcdir/sms_queue/sms_queue_test.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/sms_queue/sms_queue_test], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
2017-01-25 14:04:16 +00:00
|
|
|
|
Introduce initial unit test for db_sms_* API
Since OsmoMSC has built-in SMSC, it needs to store the messages
somewhere. Currently we use libdbi and SQLite3 back-end for that.
For a long time, the db_sms_* API remained uncovered by unit tests.
This change aims to fix that, and does cover the following calls:
- db_sms_store(),
- db_sms_get(),
- db_sms_get_next_unsent(),
- db_sms_mark_delivered(),
- db_sms_delete_sent_message_by_id(),
- db_sms_delete_by_msisdn(),
- db_sms_delete_oldest_expired_message().
Due to performance reasons, the test database is initialized in
RAM using the magic filename ':memory:'. This is a feature of
SQLite3 (and not libdbi), see:
https://www.sqlite.org/inmemorydb.html
Of course, this unit test helped to discover some problems:
1) Storing an SMS with empty TP-User-Data (TP-UDL=0) causes
buffer overruns in both db_sms_store() and db_sms_get().
2) TP-User-Data-Length is always being interpreted in octets,
regardless of DCS (Data Coding Scheme). This results in
storing garbage in the database if the default 7-bit
encoding is used. Fortunately, the 'user_data' buffer
in structure 'gsm_sms' is large emough, so we don't
experience buffer overruns.
3) db_sms_delete_oldest_expired_message() doesn't work
as expected. Instead of removing the *oldest* expired
message, it tries to remove the *newest* one.
The current test expectations do reflect these problems.
All of them will be fixed in the follow-up patches.
Change-Id: Id94ad35b6f78f839137db2e17010fbf9b40111a3
2019-04-09 09:55:44 +00:00
|
|
|
AT_SETUP([db_sms_test])
|
|
|
|
AT_KEYWORDS([db_sms_test])
|
|
|
|
cat $abs_srcdir/db_sms/db_sms_test.ok > expout
|
|
|
|
cat $abs_srcdir/db_sms/db_sms_test.err > experr
|
2019-06-04 09:29:46 +00:00
|
|
|
# swap the output from stderr and stdout so we can drop libdbi prints to stderr when trying to load wrong drivers
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/db_sms/db_sms_test 3>&1 1>&2 2>&3 | grep -v "Failed to load driver" | grep -v "cannot open shared object file"], [], [expout], [experr])
|
Introduce initial unit test for db_sms_* API
Since OsmoMSC has built-in SMSC, it needs to store the messages
somewhere. Currently we use libdbi and SQLite3 back-end for that.
For a long time, the db_sms_* API remained uncovered by unit tests.
This change aims to fix that, and does cover the following calls:
- db_sms_store(),
- db_sms_get(),
- db_sms_get_next_unsent(),
- db_sms_mark_delivered(),
- db_sms_delete_sent_message_by_id(),
- db_sms_delete_by_msisdn(),
- db_sms_delete_oldest_expired_message().
Due to performance reasons, the test database is initialized in
RAM using the magic filename ':memory:'. This is a feature of
SQLite3 (and not libdbi), see:
https://www.sqlite.org/inmemorydb.html
Of course, this unit test helped to discover some problems:
1) Storing an SMS with empty TP-User-Data (TP-UDL=0) causes
buffer overruns in both db_sms_store() and db_sms_get().
2) TP-User-Data-Length is always being interpreted in octets,
regardless of DCS (Data Coding Scheme). This results in
storing garbage in the database if the default 7-bit
encoding is used. Fortunately, the 'user_data' buffer
in structure 'gsm_sms' is large emough, so we don't
experience buffer overruns.
3) db_sms_delete_oldest_expired_message() doesn't work
as expected. Instead of removing the *oldest* expired
message, it tries to remove the *newest* one.
The current test expectations do reflect these problems.
All of them will be fixed in the follow-up patches.
Change-Id: Id94ad35b6f78f839137db2e17010fbf9b40111a3
2019-04-09 09:55:44 +00:00
|
|
|
AT_CLEANUP
|
|
|
|
|
2017-01-25 14:04:16 +00:00
|
|
|
AT_SETUP([msc_vlr_test_no_authen])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_no_authen])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_no_authen.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_no_authen.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_no_authen], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
|
|
|
AT_SETUP([msc_vlr_test_gsm_authen])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_gsm_authen])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_gsm_authen.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_gsm_authen.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_gsm_authen], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
|
|
|
AT_SETUP([msc_vlr_test_gsm_ciph])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_gsm_ciph])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_gsm_ciph.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_gsm_ciph.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_gsm_ciph], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
|
|
|
AT_SETUP([msc_vlr_test_umts_authen])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_umts_authen])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_umts_authen.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_umts_authen.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_umts_authen], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
2017-10-29 01:12:16 +00:00
|
|
|
AT_SETUP([msc_vlr_test_authen_reuse])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_authen_reuse])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_authen_reuse.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_authen_reuse.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_authen_reuse], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
2017-01-25 14:04:16 +00:00
|
|
|
AT_SETUP([msc_vlr_test_hlr_reject])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_hlr_reject])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_hlr_reject.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_hlr_reject.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_hlr_reject], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
|
|
|
AT_SETUP([msc_vlr_test_hlr_timeout])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_hlr_timeout])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_hlr_timeout.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_hlr_timeout.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_hlr_timeout], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
|
|
|
AT_SETUP([msc_vlr_test_ms_timeout])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_ms_timeout])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_ms_timeout.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_ms_timeout.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_ms_timeout], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
|
|
|
AT_SETUP([msc_vlr_test_reject_concurrency])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_reject_concurrency])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_reject_concurrency.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_reject_concurrency.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_reject_concurrency], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
2017-11-21 16:13:23 +00:00
|
|
|
AT_SETUP([msc_vlr_test_call])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_call])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_call.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_call.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_call], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
|
|
|
|
2017-01-25 14:04:16 +00:00
|
|
|
AT_SETUP([msc_vlr_test_rest])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_rest])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_rest.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_rest.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_rest], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
2018-06-15 16:57:30 +00:00
|
|
|
|
|
|
|
AT_SETUP([msc_vlr_test_ss])
|
|
|
|
AT_KEYWORDS([msc_vlr_test_ss])
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_ss.ok > expout
|
|
|
|
cat $abs_srcdir/msc_vlr/msc_vlr_test_ss.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/msc_vlr/msc_vlr_test_ss], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
2019-10-21 01:24:04 +00:00
|
|
|
|
|
|
|
AT_SETUP([sdp_msg_test])
|
|
|
|
AT_KEYWORDS([sdp_msg_test])
|
|
|
|
cat $abs_srcdir/sdp_msg/sdp_msg_test.ok > expout
|
|
|
|
cat $abs_srcdir/sdp_msg/sdp_msg_test.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/sdp_msg/sdp_msg_test], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|
2019-10-21 01:00:26 +00:00
|
|
|
|
|
|
|
AT_SETUP([mncc_test])
|
|
|
|
AT_KEYWORDS([mncc_test])
|
|
|
|
cat $abs_srcdir/mncc/mncc_test.ok > expout
|
|
|
|
cat $abs_srcdir/mncc/mncc_test.err > experr
|
|
|
|
AT_CHECK([$abs_top_builddir/tests/mncc/mncc_test], [], [expout], [experr])
|
|
|
|
AT_CLEANUP
|