Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 1 | #!/usr/bin/env python3 |
Pau Espin Pedrol | dfe38ad | 2017-11-09 13:57:39 +0100 | [diff] [blame] | 2 | from osmo_gsm_tester.testenv import * |
Pau Espin Pedrol | a5ed18a | 2017-11-23 11:03:07 +0100 | [diff] [blame] | 3 | |
Pau Espin Pedrol | 4385780 | 2018-09-13 15:07:27 +0200 | [diff] [blame] | 4 | print('use resources...') |
| 5 | nitb = suite.nitb() |
| 6 | bts = suite.bts() |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 7 | modems = suite.modems(int(prompt('How many modems?'))) |
| 8 | |
Pau Espin Pedrol | 4385780 | 2018-09-13 15:07:27 +0200 | [diff] [blame] | 9 | print('start nitb and bts...') |
| 10 | nitb.bts_add(bts) |
| 11 | nitb.start() |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 12 | bts.start() |
Pau Espin Pedrol | 4385780 | 2018-09-13 15:07:27 +0200 | [diff] [blame] | 13 | wait(nitb.bts_is_connected, bts) |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 14 | |
| 15 | for m in modems: |
Pau Espin Pedrol | 4385780 | 2018-09-13 15:07:27 +0200 | [diff] [blame] | 16 | nitb.subscriber_add(m) |
| 17 | m.connect(nitb.mcc_mnc()) |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 18 | |
| 19 | while True: |
Pau Espin Pedrol | 4385780 | 2018-09-13 15:07:27 +0200 | [diff] [blame] | 20 | cmd = prompt('Enter command: (q)uit (s)ms (g)et-registered (w)ait-registered, call-list [<ms_msisdn>], call-dial <src_msisdn> <dst_msisdn>, call-wait-incoming <src_msisdn> <dst_msisdn>, call-answer <mt_msisdn> <call_id>, call-hangup <ms_msisdn> <call_id>, ussd <command>') |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 21 | cmd = cmd.strip().lower() |
| 22 | |
| 23 | if not cmd: |
| 24 | continue |
Pau Espin Pedrol | 4897e7a | 2017-10-06 18:41:20 +0200 | [diff] [blame] | 25 | |
| 26 | params = cmd.split() |
| 27 | |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 28 | if 'quit'.startswith(cmd): |
| 29 | break |
Pau Espin Pedrol | 4897e7a | 2017-10-06 18:41:20 +0200 | [diff] [blame] | 30 | |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 31 | elif 'wait-registered'.startswith(cmd): |
| 32 | try: |
Pau Espin Pedrol | 0e57aad | 2017-05-29 14:25:22 +0200 | [diff] [blame] | 33 | for m in modems: |
Pau Espin Pedrol | 4385780 | 2018-09-13 15:07:27 +0200 | [diff] [blame] | 34 | wait(m.is_connected, nitb.mcc_mnc()) |
| 35 | wait(nitb.subscriber_attached, *modems) |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 36 | except Timeout: |
| 37 | print('Timeout while waiting for registration.') |
Pau Espin Pedrol | 4897e7a | 2017-10-06 18:41:20 +0200 | [diff] [blame] | 38 | |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 39 | elif 'get-registered'.startswith(cmd): |
Pau Espin Pedrol | 4385780 | 2018-09-13 15:07:27 +0200 | [diff] [blame] | 40 | print(nitb.imsi_list_attached()) |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 41 | print('RESULT: %s' % |
Pau Espin Pedrol | 4385780 | 2018-09-13 15:07:27 +0200 | [diff] [blame] | 42 | ('All modems are registered.' if nitb.subscriber_attached(*modems) |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 43 | else 'Some modem(s) not registered yet.')) |
Pau Espin Pedrol | 4897e7a | 2017-10-06 18:41:20 +0200 | [diff] [blame] | 44 | |
Neels Hofmeyr | aea2f2c | 2017-05-18 22:01:59 +0200 | [diff] [blame] | 45 | elif 'sms'.startswith(cmd): |
| 46 | for mo in modems: |
| 47 | for mt in modems: |
| 48 | mo.sms_send(mt.msisdn, 'to ' + mt.name()) |
Pau Espin Pedrol | 4897e7a | 2017-10-06 18:41:20 +0200 | [diff] [blame] | 49 | |
| 50 | elif cmd.startswith('call-list'): |
| 51 | if len(params) != 1 and len(params) != 2: |
| 52 | print('wrong format') |
| 53 | continue |
| 54 | for ms in modems: |
| 55 | if len(params) == 1 or str(ms.msisdn) == params[1]: |
| 56 | print('call-list: %r %r' % (ms.name(), ms.call_id_list())) |
| 57 | |
| 58 | elif cmd.startswith('call-dial'): |
| 59 | if len(params) != 3: |
| 60 | print('wrong format') |
| 61 | continue |
| 62 | src_msisdn, dst_msisdn = params[1:] |
| 63 | for mo in modems: |
| 64 | if str(mo.msisdn) == src_msisdn: |
| 65 | print('dialing %s->%s' % (src_msisdn, dst_msisdn)) |
| 66 | call_id = mo.call_dial(dst_msisdn) |
| 67 | print('dial success: call_id=%r' % call_id) |
| 68 | |
| 69 | elif cmd.startswith('call-wait-incoming'): |
| 70 | if len(params) != 3: |
| 71 | print('wrong format') |
| 72 | continue |
| 73 | src_msisdn, dst_msisdn = params[1:] |
| 74 | for mt in modems: |
| 75 | if str(mt.msisdn) == dst_msisdn: |
| 76 | print('waiting for incoming %s->%s' % (src_msisdn, dst_msisdn)) |
| 77 | call_id = mt.call_wait_incoming(src_msisdn) |
| 78 | print('incoming call success: call_id=%r' % call_id) |
| 79 | |
| 80 | elif cmd.startswith('call-answer'): |
| 81 | if len(params) != 3: |
| 82 | print('wrong format') |
| 83 | continue |
| 84 | mt_msisdn, call_id = params[1:] |
| 85 | for mt in modems: |
| 86 | if str(mt.msisdn) == mt_msisdn: |
| 87 | print('answering %s %r' % (mt.name(), call_id)) |
| 88 | mt.call_answer(call_id) |
| 89 | |
| 90 | elif cmd.startswith('call-hangup'): |
| 91 | if len(params) != 3: |
| 92 | print('wrong format') |
| 93 | continue |
| 94 | ms_msisdn, call_id = params[1:] |
| 95 | for ms in modems: |
| 96 | if str(ms.msisdn) == ms_msisdn: |
| 97 | print('hanging up %s %r' % (ms.name(), call_id)) |
| 98 | ms.call_hangup(call_id) |
| 99 | |
Pau Espin Pedrol | d27de2b | 2017-11-06 17:42:41 +0100 | [diff] [blame] | 100 | elif cmd.startswith('ussd'): |
| 101 | if len(params) != 2: |
| 102 | print('wrong format') |
| 103 | continue |
| 104 | ussd_cmd = params[1] |
| 105 | for ms in modems: |
| 106 | print('modem %s: ussd %s' % (ms.name(), ussd_cmd)) |
| 107 | response = ms.ussd_send(ussd_cmd) |
| 108 | print('modem %s: response=%r' % (ms.name(), response)) |
| 109 | |
Pau Espin Pedrol | 4897e7a | 2017-10-06 18:41:20 +0200 | [diff] [blame] | 110 | else: |
| 111 | print('Unknown command: %s' % cmd) |