blob: adc9dae328c6cef6eef0868481c8203f602ba9e8 [file] [log] [blame]
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +02001#!/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.
Pau Espin Pedroldb0d8ab2017-07-05 13:38:33 +02006# * When SMS is sent in 'transaction' mode, ESME can send an SMS to an already registered MS.
7# * When SMS is sent in 'transaction' mode, ESME fails to send an SMS to non registered MS.
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +02008
Pau Espin Pedroldfe38ad2017-11-09 13:57:39 +01009from osmo_gsm_tester.testenv import *
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +020010
11SMPP_ESME_RINVDSTADR = 0x0000000B
12
13nitb = suite.nitb()
14bts = suite.bts()
15ms = suite.modem()
16esme = suite.esme()
17
18print('start nitb and bts...')
19nitb.bts_add(bts)
20nitb.smsc.esme_add(esme)
21nitb.start()
22bts.start()
Pau Espin Pedrol1e191512017-12-11 15:12:55 +010023wait(nitb.bts_is_connected, bts)
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +020024
25esme.connect()
26nitb.subscriber_add(ms)
27ms.connect(nitb.mcc_mnc())
28
29ms.log_info()
30print('waiting for modem to attach...')
31wait(ms.is_connected, nitb.mcc_mnc())
32wait(nitb.subscriber_attached, ms)
33
34print('sending first sms...')
35msg = Sms(esme.msisdn, ms.msisdn, 'smpp send message')
Pau Espin Pedroldb0d8ab2017-07-05 13:38:33 +020036esme.sms_send(msg, esme.MSGMODE_TRANSACTION)
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +020037wait(ms.sms_was_received, msg)
38
39print('sending second sms (unicode chars not in gsm aplhabet)...')
40msg = Sms(esme.msisdn, ms.msisdn, 'chars:[кизаçйж]')
Pau Espin Pedroldb0d8ab2017-07-05 13:38:33 +020041esme.sms_send(msg, esme.MSGMODE_TRANSACTION)
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +020042wait(ms.sms_was_received, msg)
43
Pau Espin Pedroldb0d8ab2017-07-05 13:38:33 +020044wrong_msisdn = ms.msisdn + esme.msisdn
45print('sending third sms (with wrong msisdn %s)' % wrong_msisdn)
46msg = Sms(esme.msisdn, wrong_msisdn, 'smpp message with wrong dest')
47esme.run_method_expect_failure(SMPP_ESME_RINVDSTADR, esme.sms_send_wait_resp, msg, esme.MSGMODE_TRANSACTION)
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +020048
49esme.disconnect()