Pau Espin Pedrol | db0d8ab | 2017-07-05 13:38:33 +0200 | [diff] [blame] | 1 | #!/usr/bin/env python3 |
| 2 | |
| 3 | # This test checks following use-cases: |
| 4 | # * SMPP interface of SMSC accepts SMPP clients (ESMEs) with password previously |
| 5 | # defined in its configuration file. |
| 6 | # * When SMS is sent in 'store & forward' mode, ESME fails to send an SMS to non registered MS. |
| 7 | # * When SMS is sent in 'store & forward' mode, ESME can send an SMS to a not yet registered MS. |
| 8 | # * When SMS is sent in 'store & forward' mode, ESME can send an SMS to an already registered MS. |
| 9 | # * When SMS is sent in 'store & forward' mode, ESME receives a SMS receipt if it asked for it. |
| 10 | |
| 11 | from osmo_gsm_tester.test import * |
| 12 | |
| 13 | SMPP_ESME_RINVDSTADR = 0x0000000B |
| 14 | |
| 15 | hlr = suite.hlr() |
| 16 | bts = suite.bts() |
| 17 | mgcpgw = suite.mgcpgw(bts_ip=bts.remote_addr()) |
Pau Espin Pedrol | 386b78d | 2017-11-09 13:02:09 +0100 | [diff] [blame^] | 18 | mgw_bsc = suite.mgw() |
Pau Espin Pedrol | db0d8ab | 2017-07-05 13:38:33 +0200 | [diff] [blame] | 19 | msc = suite.msc(hlr, mgcpgw) |
Pau Espin Pedrol | 386b78d | 2017-11-09 13:02:09 +0100 | [diff] [blame^] | 20 | bsc = suite.bsc(msc, mgw_bsc) |
Pau Espin Pedrol | db0d8ab | 2017-07-05 13:38:33 +0200 | [diff] [blame] | 21 | stp = suite.stp() |
| 22 | bsc.bts_add(bts) |
| 23 | |
| 24 | ms = suite.modem() |
| 25 | esme = suite.esme() |
| 26 | msc.smsc.esme_add(esme) |
| 27 | |
| 28 | hlr.start() |
| 29 | stp.start() |
| 30 | msc.start() |
| 31 | mgcpgw.start() |
Pau Espin Pedrol | 386b78d | 2017-11-09 13:02:09 +0100 | [diff] [blame^] | 32 | mgw_bsc.start() |
Pau Espin Pedrol | db0d8ab | 2017-07-05 13:38:33 +0200 | [diff] [blame] | 33 | bsc.start() |
| 34 | bts.start() |
| 35 | |
| 36 | esme.connect() |
| 37 | hlr.subscriber_add(ms) |
| 38 | |
| 39 | wrong_msisdn = ms.msisdn + esme.msisdn |
| 40 | print('sending sms with wrong msisdn %s, it will fail' % wrong_msisdn) |
| 41 | msg = Sms(esme.msisdn, wrong_msisdn, 'smpp message with wrong dest') |
| 42 | esme.run_method_expect_failure(SMPP_ESME_RINVDSTADR, esme.sms_send_wait_resp, msg, esme.MSGMODE_STOREFORWARD) |
| 43 | |
Pau Espin Pedrol | 4a22ac7 | 2017-07-06 16:41:02 +0200 | [diff] [blame] | 44 | # Disabled due to known issue, see ticket OsmoSMSC #2354 |
| 45 | #print('sending sms, it will be stored...') |
| 46 | #msg = Sms(esme.msisdn, ms.msisdn, 'smpp send not-yet-registered message') |
| 47 | #umref = esme.sms_send_wait_resp(msg, esme.MSGMODE_STOREFORWARD, receipt=True) |
Pau Espin Pedrol | db0d8ab | 2017-07-05 13:38:33 +0200 | [diff] [blame] | 48 | |
| 49 | print('MS registers and will receive the SMS...') |
| 50 | ms.connect(msc.mcc_mnc()) |
| 51 | wait(ms.is_connected, msc.mcc_mnc()) |
| 52 | wait(msc.subscriber_attached, ms) |
Pau Espin Pedrol | 4a22ac7 | 2017-07-06 16:41:02 +0200 | [diff] [blame] | 53 | #wait(ms.sms_was_received, msg) |
| 54 | #print('Waiting to receive and consume sms receipt with reference', umref) |
| 55 | #wait(esme.receipt_was_received, umref) |
Pau Espin Pedrol | db0d8ab | 2017-07-05 13:38:33 +0200 | [diff] [blame] | 56 | |
| 57 | print('checking MS can receive SMS while registered...') |
| 58 | msg = Sms(esme.msisdn, ms.msisdn, 'smpp send already-registered message') |
| 59 | umref = esme.sms_send_wait_resp(msg, esme.MSGMODE_STOREFORWARD, receipt=True) |
| 60 | wait(ms.sms_was_received, msg) |
| 61 | print('Waiting to receive and consume sms receipt with reference', umref) |
| 62 | wait(esme.receipt_was_received, umref) |
| 63 | esme.disconnect() |