blob: 8bcfb6bf5db70f7cd2286f65e34b71dc75035c54 [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
9from osmo_gsm_tester.test import *
10
11SMPP_ESME_RINVDSTADR = 0x0000000B
12
13hlr = suite.hlr()
14bts = suite.bts()
15mgcpgw = suite.mgcpgw(bts_ip=bts.remote_addr())
16msc = suite.msc(hlr, mgcpgw)
17bsc = suite.bsc(msc)
18stp = suite.stp()
19bsc.bts_add(bts)
20
21ms = suite.modem()
22esme = suite.esme()
23msc.smsc.esme_add(esme)
24
25hlr.start()
26stp.start()
27msc.start()
28mgcpgw.start()
29bsc.start()
30bts.start()
31
32esme.connect()
33hlr.subscriber_add(ms)
34ms.connect(msc.mcc_mnc())
35
36ms.log_info()
37print('waiting for modem to attach...')
38wait(ms.is_connected, msc.mcc_mnc())
39wait(msc.subscriber_attached, ms)
40
41print('sending first sms...')
42msg = Sms(esme.msisdn, ms.msisdn, 'smpp send message')
Pau Espin Pedroldb0d8ab2017-07-05 13:38:33 +020043esme.sms_send(msg, esme.MSGMODE_TRANSACTION)
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +020044wait(ms.sms_was_received, msg)
45
46print('sending second sms (unicode chars not in gsm aplhabet)...')
47msg = Sms(esme.msisdn, ms.msisdn, 'chars:[кизаçйж]')
Pau Espin Pedroldb0d8ab2017-07-05 13:38:33 +020048esme.sms_send(msg, esme.MSGMODE_TRANSACTION)
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +020049wait(ms.sms_was_received, msg)
50
Pau Espin Pedroldb0d8ab2017-07-05 13:38:33 +020051wrong_msisdn = ms.msisdn + esme.msisdn
52print('sending third sms (with wrong msisdn %s)' % wrong_msisdn)
53msg = Sms(esme.msisdn, wrong_msisdn, 'smpp message with wrong dest')
54esme.run_method_expect_failure(SMPP_ESME_RINVDSTADR, esme.sms_send_wait_resp, msg, esme.MSGMODE_TRANSACTION)
Pau Espin Pedrol2d16f6f2017-05-30 15:33:57 +020055
56esme.disconnect()